Drupal для параноиков: безопасность сайта и системного окружения VPS и выделенных серверов А.Графов < [email_address] >
Проблемы <ul><li>Нежелательный контент (спам, трояны) </li></ul><ul><li>Изменение кода сайта (кража данных пользователей, ...
Причины проблем <ul><li>Сеть: </li></ul><ul><ul><li>Скрипты сайта </li></ul></ul><ul><ul><li>Вебсервер </li></ul></ul><ul>...
Способы защиты <ul><li>Контроль работы скриптов </li></ul><ul><li>Защита сетевых сервисов </li></ul><ul><li>Разграничение ...
Drupal: защита изнутри <ul><li>Обновления ядра и модулей </li></ul><ul><ul><li>Модуль  update status </li></ul></ul><ul><l...
Drupal + HTTPS <ul><li>Вариант использования: </li></ul><ul><ul><li>http://example.com/ * - контент пользователям </li></u...
Фильтруем контент: технические средства <ul><li>«Фейсконтроль» сайта — роботам вход воспрещён: captcha </li></ul><ul><li>С...
Фильтруем контент: организационные методы <ul><li>Общественная модерация </li></ul><ul><ul><ul><li>Премодерация </li></ul>...
Apache mod_security <ul><li>mod_security — «файрвол для вебприложений» </li></ul><ul><ul><li>Проверка GET и POST </li></ul...
Установка PHP <ul><li>mod_php в Apache — один пользователь на все процессы </li></ul><ul><li>open_base_dir — можно указыва...
Средства ОС <ul><li>Кража паролей — самый частый способ «взлома» </li></ul><ul><li>FTP на продуктиве лучше отключать (use ...
Средства ОС <ul><li>POSIX ACL на файловой системе: </li></ul><ul><ul><li>Более гибкая схема, чем механизм user:group:other...
Блокировка перебора паролей <ul><li>Можно сделать в друпале через hook_user() </li></ul><ul><li>Fail2ban — защита от переб...
Сетевой файрвол <ul><li>Ограничения доступа на уровне сетевых протоколов и портов </li></ul><ul><li>Не всем приложениям ну...
Последний рубеж <ul><li>ФС в файле через loopback-интерфейс </li></ul><ul><li>Или ФС в отдельном разделе </li></ul><ul><li...
Мониторинг работы <ul><li>Мониторинг работы основных сервисов локально и перезапуск при необходимости (вебсервер, СУБД, PH...
Ссылки на самое вкусное <ul><li>Коды примеров и файлов конфигурации можно скачать: </li></ul><ul><li>Ссылки на п/о: </li><...
 
 
 
Презентация подготовлена в OpenOffice Использована иллюстрация из мультсериала Futurama Вопросы? А.Графов < [email_address...
Upcoming SlideShare
Loading in...5
×

Drupal Paranoia

562

Published on

Published in: Technology, Education
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
562
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
5
Comments
0
Likes
0
Embeds 0
No embeds

No notes for slide
  • Некоторые меры защиты, о которых я расскажу в этом докладе могут показаться чрезмерными. Поэтому я перестраховался и назвал тему — «Друпал для параноиков» - то что для нормальных людей примут за сумасшествие, для сисадминов — норма жизни. Но тем не менее, всё о чем будет рассказано испльзовалось в различных коммерческих проектах и вылезло не просто так. Этот доклад — не мастеркласс, поэтому я не дам здесь детальных примеров кода и настроек программ, я только дам обзор возможных опасностей и обзор решений, которые позволят их избежать или уменьшить их последствия. Доклад насыщен информацией, поэтому я не буду углубляться в детали примеров — ссылки на код и программы о которых пойдёт речь — в конце доклада.
  • Я буду говорить в расчёте на выделенные сервера и VPS. Часть вещей, особенно касающихся настроек друпала можно использовать и на shared-хостинге, но на shared-хостинге возможности настройки системного окружения сильно ограничены. И по-хорошему защита shared-хостинга — забота админов техподдержки. Мы же рассмотрим те варианты, когда вы хотите сами настроить защиту системы и отвечать за неё. &gt;&gt;&gt;&gt; Итак, каковы возможные проблемы для сайта? Нежелательный контент — то что попадает на сайт легальным путём, через те вебформы, которые сайт предоставляет для постинга. Более серьёзный вариант, когда в результате успешного применения эксплоита, злоумышленник может изменять файлы скриптов. И самый неприятный вариант, когда получена возможность запуска новых процессов или ещё хуже права суперпользователя. Тогда вы можете получить такой своего рода «shared-хостинг», где ресурсы вашей машины, CPU, память, трафик - вы будете использовать совместно с незнакомыми вам людьми, которые смогут использовать их в неизвестных вам целях. А вы даже не будете этого знать.
  • Причины можно условно разделить на три группы. Различные атаки сетевых сервисов с целью организовать исполнение своего кода. А может быть заблокировать работу сервиса — так называемые «атаки отказа доступа» - DOS. Задействование уязвимостей, когда уже имеется shell-доступ — может быть легальный, а может быть полученный в результате успешного эксплойта применённого к сетевым сервисам. И самый маловероятный вариант, от которого однако проблематичней всего защититься — получение непосредственного доступа к дискам, когда сервер выключен и права операционной системы на процессы и файлы уже не действуют.
  • Большинство методов о которых я расскажу тривиальны и наверняка известны администраторам. Но я надеюсь даже опытным админам временами будет интересно, ведь сколько ни изучай тему, всегда можно пропустить какие-нибудь любопытные мелочи. Итак, о чём пойдёт речь в докладе? Очевидно о том, что надо следить за установленными в системе программами. В первую очередь за скриптами вашего сайта, а также за системными программами, работающими с сетью. К каждой адекватной ОС регулярно выходят апдейты безопасности, за которыми стоит следить и регулярно их устанавливать. Мы поговорим о разграничения прав между пользователями на процессы и ограничения прав на файловой системе — это основные меры защиты системного окружения. А также рассмотрим случай, когда злоумышленники добрались до сервера физически и сняли жёсткий диск с данными. Разграничения прав здесь больше не помогут. Что делать чтобы помешать им завладеть данными? Чтобы на руках у них остался только мусор из байтов, а не данные вашей базы. Нет, не подумайте, я не рекомендую минировать сервер, есть другие методы о которых поговорим в конце.
  • Базовые методы защиты — следите за обновлениями модулей друпала, модуль update status в этом вам поможет. Этот модуль обращается к drupal.org и сообщает о вышедших новых версиях модулей. Фильтры исполнения PHP — гибкая вещь, которая очень нравится разработчикам, позволяя сокращать время разработки — вставляем код прямо в текст страниц и блоков, и не нужно писать свой модуль. Но на продуктивных сайтах исполнение PHP обычно не требуются, разве что на очень специфичных ресурсах. Безопаснее — его отключить. Общий принцип — отключайте всё что не требуется, все лишние модули, темы, неиспользуемые роли. Если при повседневной работе с сайтом вам постоянно требуется пользователь #1, то значит что-то при создании сайта было спроектировано неправильно. Создайте роль с необходимыми для администрирования правами, используйте пользователя с этой ролью. Модуль paranoia — следит за всем этим за вас.
  • Вообще Друпал без лишних телодвижений работает через защищённый канал. Настройте вебсервер, сгенерируйте ключи — обращайтесь к сайту через HTTPS — друпал будет корректно обрабатывать эти запросы. А вот пример когда нужно только часть сайта, например работу с платежами или админку завернуть на https. В друпале это делается также легко, хотя потребуется немного попрограммировать. [SKIPED — в принципе всё на картинке показано] Задача кстати вполне реальная. Ко мне обращались один раз, чтобы настроить сайт таким образом.
  • Рассмотрим как избавляться от нежелательного контента. Очевидно, что большинство спама рассылается автоматически — программами-ботами и чтобы отделить роботов от нормальных людей есть универсальный механизм — капча. Механизм основан на том, что роботы пока умеют не всё, что умеют люди и в частности хуже умеют распознавать образы. С помощью капчи мы можем не допустить роботов-спамеров на сайт. Альтернатива — самообучающиеся фильтры отделяющие спам от не спама. В друпале это одноимённый модуль — Spam. Недостаток таких фильтров — есть вероятность ложного срабатывания. По похожему принципу работают публичные сервисы. Отметить: опыт использования Mollom на drupal.ru — неудачно. Вероятно он ориентируется больше на англоязычный контент. Дрис писал в твиттере об успешном применении Mollom например на сайте памяти Майкла Джексона, который к слову сделан на друпале.
  • Кроме технических средств борьбы со спамом не стоит забывать об организационных мерах. Таких как модерация силами посетителей сайта или специально выделенных для этой цели сотрудников. Тут есть два метода, каждый со своими недостатками — первый, это предварительная проверка всех поступающих материалов, перед их публикацией; второй способ — снятие с публикации уже размещённых на сайте материалов, если они нарушают правила сайта. Если для модерации вы привлекаете не сотрудников, а самих посетителей сайта, как собственно происходит на сайтах сообществ, то тут встают вопросы доверия и контроля за действиями модераторов. Но тут тоже есть решения, как снизить последствия от ошибок модераторов. В качестве примера приведу drupal.ru: принцип - контент не удаляется!
  • С большой вероятностью в качестве вебсервера у вас установлен Apache или Nginx. Под Апач есть замечательный модуль — mod_security, это по сути такой «файрвол для вебприложений». Модуль проверяет поступающие на сервер запросы и также проверяет ответы сервера. И на основе заданных правил производит фильтрацию тела и заголовков запроса. Проверяются и GET и POST запросы. С помощью этого модуля можно глобально для всех скриптов сервера избавиться от таких уязвимостей как вставки SQL, кросс-скриптинг, вызов команд операционной системы. Модуль может обнаруживать код троянов и аномалии HTTP-запросов. Одной установки модуля недостаточно. Нужно обязательно прочесть документацию и сконфигурировать набор правил, которые могут быть специфичны для ваших задач. На сайте проекта впрочем есть много примеров с правилами и шаблонами правил.
  • Наиболее частый вариант работы PHP в Apache — модулем. Недостаток: все процессы работают под одним пользователем и скрипт одного виртхоста может получить доступ к файлам другого виртхоста. Альтернативный способ исполнения PHP — использование FastCGI, его преимущество: можно запускать скрипты разных виртхостов под разными пользователями и таким образом разделить права доступа. Suhosin состоит из двух независимых частей, которые могут использоваться раздельно или совместно. Первая часть – небольшой патч к ядру осуществляющий низкоуровневую защиту структур данных против переполнения буфера и других уязвимостей ядра PHP, впрочем со времени выхода патча часть проблем была исправлена в новых версиях PHP. Вторая часть реализована в виде расширения к PHP, которое фактически осуществляет всю основную защиту и добавляет ряд возможностей по ограничениям в конфигурации PHP. Хотя оригинальный патч Suhosin вышел ещё в 2007 году, но он адаптирован и к последним версиями PHP и идёт в поставке многих дистрибутивов Linux и во FreeBSD.
  • По моим наблюдениям чаще крадут пароли на ftp, нежели находят уязвимость в системе. К слову, даже сайт киевского друпалкемпа взломали таким образом — был украден ftp-пароль и изменён файл скрипта, внедрён троян, так что потом ещё сутки в Файрфоксе красовалась надпись «Reported attack site», пока сайт не вытащили из блок-листа. Подробнее о работе с secure-shell можно послушать в моём докладе DrupalDo.
  • Гибкая альтернатива классической юниксовой схеме разграничения прав на файлы — access control lists (ACL). Если вы ещё не используете ACL для разграничения прав на файлы — рекомендую это сделать. Я не буду здесь подробно объяснять возможности ACL, разве только в конце доклада возникнут вопросы по этой теме и останется время. Поставьте пакет в своей ОС и прочтите маны по setfacl и getfacl.
  • Ещё вариант получения доступа к сайту — зная логин подобрать к нему пароль. Вручную это нелегко, а вот скриптом перебора — очень даже просто, если п/о не предоставляет защиты от таких переборов. Интересно, что в друпале в формах авторизации такой защиты по умолчанию нет. Да, можно организовать это через капчу — об этом поговорим дальше. Можно написать свой код... готовых модулей я не знаю, но это несложно сделать самому через hook_user(). А можно использовать fail2ban...
  • Файрвол часто используют не глядя на любых серверах, но по сути он нужен тоже не всегда. Скажем классическая конфигурация сервера для хостинга с установленным вебсером, mysql и ssh для доступа. Mysql сконфигурирован только для прослушивания локального хоста — наружу смотрят только два tcp-порта — вебсервер и ssh доступные отовсюду, что собственно и требуется. Файрволу тут ограничивать нечего, так как все ограничения уже указаны в настройках сетевых служб. И можно его не устанавливать и отключить поддержку сетевой фильтрации в ядре. С другой стороны дополнительный контроль сетевых настроек файрволом позволяет избежать ошибок администрирования — например случайно выставить в сеть сервис, который не должен быть публично доступен, например мемкеш или mysql. Поэтому в общем случае, если не знаете зачем вам не нужен файрвол, лучше его оставить и корректно настроить.
  • Та проблема о которой я говорил в начале доклада. И последняя стадия админской паранойи. Страшный сон: когда злоумышленники получают физический доступ к дискам с данными. С помощью шифрования файловой системы мы можем избежать неприятных последствий кражи данных. Это накладная операция, поэтому стоит использовать её только на самых критичных данных. Например вынести какие-нибудь данные пользователей в отдельную БД и хранить эту БД на шифрованном разделе. Есть ещё вариант применения: вы разрабатываете сайт и на серверных ресурсах заказчика. Очень удобно при этом взять администрирование сервера тоже на себя и хранить весь код и базы на шифрованных разделах — на этапе разработки такой перерасход ресурсов не критичен, зато если заказчик вдруг взбрыкнёт и заберёт управление сервером себе — он не получит доступа к данным. Ситуация вовсе не надуманная. В вебстудии с которой я работал, был такой инцидент с одним заказчиком и после него я решил, что конфиги всех новых проектов я буду строить таким образом.
  • Важное средство предупреждения проблем — мониторинг системы. Это повышает надёжность системы и таким образом косвенно влияет на безопасность. Есть немало инструментов для мониторинга, я рекомендую вам обратить внимание на Zabbix, он позволяет мониторить ряд параметров и гибко настраивается [см слайд]. Агент zabbix — ставится на машину, параметры которой надо контролировать, под сервер zabbix лучше использовать отдельную машину.
  • Это всё, что я хотел сказать. Я понимаю, что мой поверхностный рассказ врядли мог прояснить какие-то моменты по настройке, но может быть он обратил ваше внимание на вещи, которые вы раньше не замечали? Для заинтересовавшихся — подробности по ссылкам. TODO: найти ссылку на статью по ACL.
  • Файл с презентацией распространяется под Creative Commons SA последней версии.
  • Drupal Paranoia

    1. 1. Drupal для параноиков: безопасность сайта и системного окружения VPS и выделенных серверов А.Графов < [email_address] >
    2. 2. Проблемы <ul><li>Нежелательный контент (спам, трояны) </li></ul><ul><li>Изменение кода сайта (кража данных пользователей, вставка нежелательного контента — показ скрытой рекламы, перенаправление на другой ресурс) </li></ul><ul><li>Несанкционированное использование ресурсов сервера (рассылка спама и др.) </li></ul>
    3. 3. Причины проблем <ul><li>Сеть: </li></ul><ul><ul><li>Скрипты сайта </li></ul></ul><ul><ul><li>Вебсервер </li></ul></ul><ul><ul><li>Другие сетевые службы (ftp, ssh, СУБД...) </li></ul></ul><ul><li>Локальный доступ: </li></ul><ul><ul><li>Пользователи имеющие доступ (ssh, ftp) </li></ul></ul><ul><ul><li>Или получившие доступ к серверу при успешной атаке по сети </li></ul></ul><ul><li>Физический доступ к серверу: </li></ul><ul><ul><li>Данные на жёстких дисках </li></ul></ul>
    4. 4. Способы защиты <ul><li>Контроль работы скриптов </li></ul><ul><li>Защита сетевых сервисов </li></ul><ul><li>Разграничение прав между пользователями на исполняемые процессы </li></ul><ul><li>Разграничение прав на доступ к файловой систему </li></ul><ul><li>Ограничение доступа к сетевым сервисам </li></ul><ul><li>Защита данных хранимых на жёстком диске </li></ul>
    5. 5. Drupal: защита изнутри <ul><li>Обновления ядра и модулей </li></ul><ul><ul><li>Модуль update status </li></ul></ul><ul><li>Фильтр исполнения PHP </li></ul><ul><li>Лишние модули </li></ul><ul><li>Пользователь №1 </li></ul><ul><li>Модуль paranoia </li></ul><ul><ul><li>Блокирует создание форматов включающих исполнение PHP </li></ul></ul><ul><ul><li>Блокирует изменения аккаунта №1 </li></ul></ul><ul><ul><li>Блокирует отключение модуля paranoia </li></ul></ul>
    6. 6. Drupal + HTTPS <ul><li>Вариант использования: </li></ul><ul><ul><li>http://example.com/ * - контент пользователям </li></ul></ul><ul><ul><li>Запрет доступа к http://example.com/admin * </li></ul></ul><ul><ul><li>Доступ к админке https://example.com only! </li></ul></ul><ul><li>Как сделать? Нам поможет: </li></ul><ul><ul><li>custom_url_rewrite_inbound( &$result, $path, $path_language) </li></ul></ul><ul><ul><li>Переменные например </li></ul></ul><ul><ul><ul><li>$_SERVER['HTTP_X_SSL_CONNECT'] </li></ul></ul></ul><ul><ul><ul><li>$_SERVER['HTTP_X_FORWARDED_HOST'] </li></ul></ul></ul><ul><ul><ul><li>$_SERVER['HTTP_HOST'] и др. </li></ul></ul></ul>
    7. 7. Фильтруем контент: технические средства <ul><li>«Фейсконтроль» сайта — роботам вход воспрещён: captcha </li></ul><ul><li>Самобучающиеся фильтры </li></ul><ul><ul><li>Модуль Spam на алгоритме Байеса </li></ul></ul><ul><ul><li>Правила для URL в модуле Spam </li></ul></ul><ul><li>Публичные спамбазы и блоклисты </li></ul><ul><ul><ul><li>Mollom — проект Дриса Байтаерта </li></ul></ul></ul><ul><ul><ul><li>Akismet </li></ul></ul></ul>
    8. 8. Фильтруем контент: организационные методы <ul><li>Общественная модерация </li></ul><ul><ul><ul><li>Премодерация </li></ul></ul></ul><ul><ul><ul><li>Постмодерация </li></ul></ul></ul><ul><ul><ul><li>Пример вики-модерации на drupal.ru </li></ul></ul></ul><ul><ul><ul><ul><li>Ничего не удаляется! </li></ul></ul></ul></ul><ul><ul><ul><ul><li>Больше 100 модераторов </li></ul></ul></ul></ul><ul><ul><ul><ul><li>Легкость внесения правок </li></ul></ul></ul></ul><ul><ul><ul><ul><li>Бан одним кликом </li></ul></ul></ul></ul><ul><li>Тем эффективнее, чем больше человек задействовано в модерации </li></ul>
    9. 9. Apache mod_security <ul><li>mod_security — «файрвол для вебприложений» </li></ul><ul><ul><li>Проверка GET и POST </li></ul></ul><ul><ul><li>Фильтрация подозрительного содержимого (ввод-вывод) на основе правил </li></ul></ul><ul><ul><ul><li>SQL injections </li></ul></ul></ul><ul><ul><ul><li>XSS </li></ul></ul></ul><ul><ul><ul><li>Команды ОС </li></ul></ul></ul><ul><ul><li>Обнаружение троянов </li></ul></ul><ul><ul><li>Аномалии HTTP-запросов </li></ul></ul>
    10. 10. Установка PHP <ul><li>mod_php в Apache — один пользователь на все процессы </li></ul><ul><li>open_base_dir — можно указывать для каждого виртуального хоста </li></ul><ul><li>FastCGI в Apache и NGINX — можно легко разделить пользователей виртуальных хостов </li></ul><ul><li>Suhosin — патч и модуль расширения к PHP </li></ul>
    11. 11. Средства ОС <ul><li>Кража паролей — самый частый способ «взлома» </li></ul><ul><li>FTP на продуктиве лучше отключать (use SFTP) </li></ul><ul><li>Защита от последствий украденного пароля на VPS/сервере: </li></ul><ul><ul><li>Права владения на скрипты сайта передаются другому пользователю (например root) </li></ul></ul><ul><ul><li>Папки files и tmp — единственные места, куда Drupal требует прав на запись </li></ul></ul><ul><ul><li>Совет: index.html с правами на запись </li></ul></ul>
    12. 12. Средства ОС <ul><li>POSIX ACL на файловой системе: </li></ul><ul><ul><li>Более гибкая схема, чем механизм user:group:other – rwx </li></ul></ul><ul><ul><li>Упрощённо говоря ACL задавать отдельные права на файл для нескольких пользователей и групп </li></ul></ul><ul><ul><li>Пакет acltools: getfacl/setfacl </li></ul></ul>
    13. 13. Блокировка перебора паролей <ul><li>Можно сделать в друпале через hook_user() </li></ul><ul><li>Fail2ban — защита от перебора паролей и от DOS </li></ul><ul><ul><li>Защита входов SSH и FTP </li></ul></ul><ul><ul><li>Защита авторизационных форм вебсервера </li></ul></ul><ul><ul><li>Защита авторизации Drupal: </li></ul></ul><ul><ul><ul><li>failregex = |user|<HOST>|.*|Login attempt failed (.+).$ </li></ul></ul></ul><ul><ul><li>Блокирует IP или производит другие действия </li></ul></ul>
    14. 14. Сетевой файрвол <ul><li>Ограничения доступа на уровне сетевых протоколов и портов </li></ul><ul><li>Не всем приложениям нужен доступ отовсюду из сети: ограничения по IP </li></ul><ul><li>Всегда ли нужен файрвол? </li></ul>
    15. 15. Последний рубеж <ul><li>ФС в файле через loopback-интерфейс </li></ul><ul><li>Или ФС в отдельном разделе </li></ul><ul><li>Включить поддержку криптографии в ядре </li></ul><ul><ul><li>AES, Blowfish, DES... </li></ul></ul><ul><li>Критичные данные на шифрованном разделе </li></ul><ul><li>Пример для Linux: </li></ul>
    16. 16. Мониторинг работы <ul><li>Мониторинг работы основных сервисов локально и перезапуск при необходимости (вебсервер, СУБД, PHP) </li></ul><ul><li>Комплексный мониторинг (Zabbix, ZenOSS) </li></ul><ul><ul><li>CPU </li></ul></ul><ul><ul><li>Память </li></ul></ul><ul><ul><li>Место на ФС </li></ul></ul><ul><ul><li>Доступность сетевых сервисов </li></ul></ul><ul><ul><li>Уведомления по почте, СМС </li></ul></ul><ul><ul><li>Вебинтерфейс с таблицами и графиками </li></ul></ul><ul><ul><li>Агенты под Linux, *BSD, Windows </li></ul></ul>
    17. 17. Ссылки на самое вкусное <ul><li>Коды примеров и файлов конфигурации можно скачать: </li></ul><ul><li>Ссылки на п/о: </li></ul><ul><ul><li>http://fail2ban.org </li></ul></ul><ul><ul><li>http://modsecurity.org </li></ul></ul><ul><ul><li>http://suhosin.org </li></ul></ul><ul><ul><li>http://zabbix.com </li></ul></ul><ul><li>Статьи по теме: </li></ul><ul><ul><li>www.drupal.ru/node/31163 - fail2ban + Drupal </li></ul></ul><ul><ul><li>http://tr.im/x5cQ - настройка шифрования ФС </li></ul></ul>
    18. 21. Презентация подготовлена в OpenOffice Использована иллюстрация из мультсериала Futurama Вопросы? А.Графов < [email_address] >
    1. A particular slide catching your eye?

      Clipping is a handy way to collect important slides you want to go back to later.

    ×