Перейти до змісту

Захищений FTP-сервер - vsftpd

Передумови

  • Вміння працювати з редактором командного рядка (у цьому прикладі використовується vi)
  • Високий рівень комфорту з видачею команд із командного рядка, переглядом журналів та іншими загальними обов’язками системного адміністратора
  • Корисним є розуміння PAM і команд openssl
  • Запуск команд тут за допомогою користувача root або звичайного користувача та sudo

Вступ

vsftpd — це дуже безпечний FTP-демон (FTP — це протокол передачі файлів). Він доступний протягом багатьох років і є демоном FTP за умовчанням у Rocky Linux та багатьох інших дистрибутивах Linux.

vsftpd дозволяє використовувати віртуальних користувачів із підключеними модулями автентифікації (PAM). Ці віртуальні користувачі не існують у системі та не мають інших дозволів, окрім FTP. Якщо віртуального користувача скомпрометовано, особа з такими обліковими даними не матиме інших дозволів після отримання доступу як цей користувач. Це налаштування є дуже безпечним, але вимагає додаткової роботи.

Розгляньте sftp

Навіть з налаштуваннями безпеки, які використовуються тут для налаштування vsftpd, ви можете розглянути sftp замість цього. sftp зашифрує весь потік з’єднання та є більш безпечним. Ми створили документ під назвою Захищений сервер - sftp, який стосується налаштування sftp і блокування SSH.

Встановлення vsftpd

Ви також повинні переконатися, що встановлено openssl. Якщо ви використовуєте веб-сервер, можливо, є вже встановлено, але для перевірки ви можете виконати:

dnf install vsftpd openssl

Ви також захочете ввімкнути службу vsftpd:

systemctl enable vsftpd

Поки що не запускайте службу.

Налаштування vsftpd

Ви бажаєте вимкнути деякі параметри та ввімкнути інші. Як правило, встановлення vsftpd включає в себе найбільш розумні параметри, які вже встановлені. Це все ще гарна ідея перевірити їх.

Щоб перевірити файл конфігурації та за потреби внести зміни, запустіть:

vi /etc/vsftpd/vsftpd.conf

Знайдіть рядок «anonymous_enable=" і переконайтеся, що він «НІ» та НЕ закоментований. (Коментування цього рядка увімкне анонімний вхід). Рядок виглядатиме так, якщо він правильний:

anonymous_enable=NO

Переконайтеся, що «local_enable» має значення «yes»:

local_enable=YES

Додайте рядок для локального користувача root. Якщо сервер є веб-сервером, і ви використовуєте налаштування веб-сервера Apache Multi-Site, це відображатиме ваш локальний корень. Якщо ваші налаштування відрізняються або це не веб-сервер, змініть параметр "local_root":

local_root=/var/www/sub-domains

Також переконайтеся, що «write_enable» має значення «yes»:

write_enable=YES

Знайдіть рядок "chroot_local_user" і видаліть зауваження. Додайте два рядки після показаного тут:

chroot_local_user=YES
allow_writeable_chroot=YES
hide_ids=YES

Під цим ви хочете додати розділ, який стосуватиметься віртуальних користувачів:

# Virtual User Settings
user_config_dir=/etc/vsftpd/vsftpd_user_conf
guest_enable=YES
virtual_use_local_privs=YES
pam_service_name=vsftpd
nopriv_user=vsftpd
guest_username=vsftpd

Вам потрібно додати розділ у нижній частині файлу, щоб примусово шифрувати паролі, надіслані через Інтернет. Вам потрібно встановити openssl і створити сертифікат для цього.

Почніть із додавання цих рядків у нижній частині файлу:

rsa_cert_file=/etc/vsftpd/vsftpd.pem
rsa_private_key_file=/etc/vsftpd/vsftpd.key
ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO

pasv_min_port=7000
pasv_max_port=7500

Збережіть конфігурацію. (Shift+:+W+Q для vi.)

Налаштування сертифіката RSA

Вам потрібно створити файл сертифіката RSA vsftpd. Автор взагалі вважає, що сервер служить 4-5 років. Встановіть дні для цього сертифіката на основі років, за якими ви вважаєте, що сервер буде працювати на цьому обладнанні.

Відредагуйте кількість днів, як вважаєте за потрібне, і використовуйте формат цієї команди, щоб створити файли сертифіката та закритого ключа:

openssl req -x509 -nodes -days 1825 -newkey rsa:2048 -keyout /etc/vsftpd/vsftpd.key -out /etc/vsftpd/vsftpd.pem

Як і всі процеси створення сертифікатів, це запустить сценарій із запитом на певну інформацію. Це не складний процес. Ви залишите багато полів порожніми.

Перше поле – поле коду країни; заповніть цей дволітерний код вашої країни:

Country Name (2 letter code) [XX]:

Далі йде штат або провінція, заповніть це, ввівши повну назву, а не абревіатуру:

State or Province Name (full name) []:

Далі йде назва населеного пункту. Це твоє місто:

Locality Name (eg, city) [Default City]:

Далі йде назва компанії або організації. Ви можете залишити це поле порожнім або заповнити його. Це необов'язково:

Organization Name (eg, company) [Default Company Ltd]:

Далі вказується назва організаційного підрозділу. Ви можете заповнити це поле, якщо сервер призначено для певного підрозділу, або залишити поле порожнім:

Organizational Unit Name (eg, section) []:

Наступне поле потрібно заповнити, але ви можете вирішити, як вам це потрібно. Це загальна назва вашого сервера. Приклад: webftp.domainname.ext:

Common Name (eg, your name or your server's hostname) []:

Поле електронної пошти можна залишити порожнім:

Email Address []:

Після завершення буде створено сертифікат.

Налаштування віртуальних користувачів

Як було сказано раніше, використання віртуальних користувачів для vsftpd набагато безпечніше, оскільки вони не мають системних привілеїв. Тим не менш, вам потрібно додати користувача для віртуальних користувачів. Також потрібно додати групу:

groupadd nogroup
useradd --home-dir /home/vsftpd --gid nogroup -m --shell /bin/false vsftpd

Користувач має відповідати рядку guest_username= у файлі vsftpd.conf.

Перейдіть до каталогу конфігурації для vsftpd:

cd /etc/vsftpd

Потрібно створити базу паролів. Ви використовуєте цю базу даних для автентифікації наших віртуальних користувачів. Вам потрібно створити файл для читання віртуальних користувачів і паролів. Це створить базу даних.

У майбутньому, додаючи користувачів, ви захочете повторити цей процес знову:

vi vusers.txt

Користувач і пароль розділені рядками, введіть користувача, натисніть Enter і введіть пароль. Продовжуйте, доки не додасте всіх користувачів, яким наразі потрібно надати доступ до системи. Приклад:

user_name_a
user_password_a
user_name_b
user_password_b

Після завершення створення текстового файлу ви хочете створити базу даних паролів, яку vsftpd використовуватиме для віртуальних користувачів. Зробіть це за допомогою команди db_load. db_load надається libdb-utils, який має бути завантажений у вашій системі, але якщо це не так, ви можете просто встановити його за допомогою:

dnf install libdb-utils

Створіть базу даних із текстового файлу за допомогою:

db_load -T -t hash -f vusers.txt vsftpd-virtual-user.db

Приділіть хвилинку, щоб переглянути, що робить db_load:

  • Параметр -T дозволяє імпортувати текстовий файл до бази даних
  • Параметр -t каже, що потрібно вказати основний метод доступу
  • Хеш є основним методом доступу, який ви вказуєте
  • Параметр -f говорить про читання з указаного файлу
  • Указаний файл — vusers.txt
  • А база даних, яку ви створюєте чи додаєте, це vsftpd-virtual-user.db

Змініть дозволи за замовчуванням для файлу бази даних:

chmod 600 vsftpd-virtual-user.db

Видаліть файл "vusers.txt":

rm vusers.txt

Додаючи користувачів, використовуйте vi, щоб створити ще один файл «vusers.txt», і повторно запустіть команду db_load, яка додасть користувачів до бази даних.

Налаштування PAM

vsftpd встановлює файл pam за умовчанням, коли ви встановлюєте пакет. Ви збираєтеся замінити це своїм вмістом. Завжди спочатку створюйте резервну копію старого файлу.

Створіть каталог для файлу резервної копії в /root:

mkdir /root/backup_vsftpd_pam

Скопіюйте файл pam до цього каталогу:

cp /etc/pam.d/vsftpd /root/backup_vsftpd_pam/

Відредагуйте вихідний файл:

vi /etc/pam.d/vsftpd

Видаліть у цьому файлі все, крім "#%PAM-1.0", і додайте такі рядки:

auth       required     pam_userdb.so db=/etc/vsftpd/vsftpd-virtual-user
account    required     pam_userdb.so db=/etc/vsftpd/vsftpd-virtual-user
session    required     pam_loginuid.so

Збережіть зміни та вийдіть (Shift+:+W+Q у vi).

Це дозволить ввійти для ваших віртуальних користувачів, визначених у vsftpd-virtual-user.db, і вимкне локальні входи.

Налаштування конфігурації віртуального користувача

Кожен віртуальний користувач має конфігураційний файл із зазначенням власного каталогу "local_root". Власником цього локального кореня є користувач "vsftpd" і група "nogroup".

(Див. розділ «Налаштування віртуальних користувачів»)

Щоб змінити право власності на каталог, введіть це в командному рядку:

chown vsftpd.nogroup /var/www/sub-domains/whatever_the_domain_name_is/html

Вам потрібно створити файл із конфігурацією віртуального користувача:

mkdir /etc/vsftpd/vsftpd_user_conf
vi /etc/vsftpd/vsftpd_user_conf/username

У ньому буде один рядок, який визначає "local_root" віртуального користувача:

local_root=/var/www/sub-domains/com.testdomain/html

Специфікацію цього шляху можна знайти в розділі "Virtual User" файлу vsftpd.conf.

Запуск vsftpd

Запустіть службу vsftpd і перевірте своїх користувачів, припускаючи, що служба запускається правильно:

systemctl restart vsftpd

Тестування vsftpd

Ви можете перевірити налаштування за допомогою командного рядка на машині та спробувати отримати доступ до машини за допомогою FTP. Тим не менш, найпростіший спосіб тестування — це перевірка за допомогою клієнта FTP, наприклад FileZilla.

Коли ви тестуєте віртуального користувача на сервері, на якому працює vsftpd, ви отримаєте повідомлення про довіру сертифіката SSL/TLS. Це довірче повідомлення повідомляє особі, що сервер використовує сертифікат, і просить її підтвердити його перед продовженням. Ви можете розміщувати файли в папці "local_root", якщо підключилися як віртуальний користувач.

Якщо ви не можете завантажити файл, вам, можливо, доведеться повернутися та ще раз перевірити кожен із кроків. Наприклад, можливо, права власності для "local_root" не встановлено для користувача "vsftpd" і групи "nogroup".

Висновок

vsftpd є популярним і поширеним FTP-сервером, який може бути окремим сервером або частиною захищеного веб-сервера Apache. Це досить безпечно, якщо налаштовано використовувати віртуальних користувачів і сертифікат.

Ця процедура містить багато кроків для налаштування vsftpd. Додатковий час для правильного налаштування гарантує, що ваш сервер буде максимально безпечним.

Author: Steven Spencer

Contributors: Ezequiel Bruni, Ganna Zhyrnova