[Из песочницы] Ставили MongoDB с дефолтными настройками? Поздравляем, она абсолютно открыта всем
Все, наверное, слышали про NoSQL базы, в частности, про MongoDB. Может даже быть кто-то ставил эту базу на свой сервер. Возможно, с дефолтными настройками. Если это так, пора срочно нырнуть под кат. Потому что MongoDB с дефолтными настройками абсолютно открыта извне всем и каждому.
ВступлениеИтак, все началось с письма от весьма недурственного хостинга Hetzner. Вот как оно выглядело:
Коротко суть в следующем:
MongoDB — это популярная база в вебе, но вот беда — она во многих местах ну абсолютно открыта всем. Это неправильно, поэтому вот рекомендации по безопасности. Ну, вы получили это письмо, потому что у вас она открыта тоже. Будете подобные письма и впредь, пока не закроете.
Я удивился. Блин, да я очень удивился.
Решил проверить, насколько же она открыта. Я, просто несказанно удивился результатам, understatement.
А результаты таковы: лучшего троянского коня мир просто не знал.
Ну, а теперь конкретика.
Проверяем доступность извне Это просто. Пробуем открыть сайт в браузере по порту 28017. Набираем — ваш_домен_ру:28017И, вуаля:
Ну, да, да. Пока особого криминала пока нет, но как минимум неприятно, что служебная информация доступна всем.
Проверяем дальше.
Пробуем подключиться снаружи mongo-клиентом. Набираем в консоле на ноутбуке:
mongo ваш_домен.зона:27017
И, снова вуаля:
Вот так, не спрося пароля, просто подключаемся к шеллу MongoDB. Теперь мы можем создавать, менять, удалять, просматривать содержимое всех баз. Это уже полный абзац. Но, к сожалению, это только цветочки.
Набираем в shell MongoDB команду ls ():
Ну и на закуску cat (»/etc/passwd»):
Дальше ковыряться не стал. Мне хватило.
Смотрим настройки на сервере: less /etc/mongodb.conf. И вот что мы видим:
Настройки авторизации по дефолту выключены.
Ну и по дефолту слушаем все интерфейсы:
Что нужно сделать, чтобы починить? Как минимум добавить строчки в конфиг: bind_ip = 127.0.0.1
И опционально настроить авторизацию:
# Turn on/off security. Off is currently the default#noauth = trueauth = true
При этом проверьте, чтобы сайт/сервис не сломался, поскольку, возможно, придется научить авторизоваться и его. Плюс обязательно нужно провести полный аудит системы на предмет проникновения.
Немного лирики и статитики Статистика удручает. Только в Германии студенты, с которых все началось, обнаружили десятки тысяч открытых баз. Картина в мировых масштабах может быть в десятки, а то и сотни раз хуже.Не буду задавать риторические вопросы, а впрочем, какого черта? Задам.
1) Зачем делать такие дефолтные настройки?2) Зачем в Mongo shell встраивать доступ к файловой системе?
Понятно, что сам виноват, RTFM. Но зачем такие настройки?
Поневоле закрадывается мысль: «такая «странная логика» встречается только в дефолтных настройках или, может, еще где нибудь, например, в ядре?»
Выводы: хотите кого-то взломать? Посоветуйте установить ему дефолтную MongoDB.