Установка и настройка FTP сервера (vsftpd) — различия между версиями

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск
 
Строка 11: Строка 11:
  
 
1. Обновите список пакетов:
 
1. Обновите список пакетов:
<code>sudo apt update</code>
+
<pre>sudo apt update</pre>
  
 
2. Установите vsftpd:
 
2. Установите vsftpd:
<code>sudo apt install vsftpd</code>
+
<pre>sudo apt install vsftpd</pre>
  
 
3. Запустите и включите автозапуск vsftpd:
 
3. Запустите и включите автозапуск vsftpd:
<code>sudo systemctl start vsftpd</code>
+
<pre>sudo systemctl start vsftpd</pre>
<code>sudo systemctl enable vsftpd</code>
+
<pre>sudo systemctl enable vsftpd</pre>
  
 
=== Проверка установки ===
 
=== Проверка установки ===
  
 
1. Проверьте статус сервиса:
 
1. Проверьте статус сервиса:
<code>sudo systemctl status vsftpd</code>
+
<pre>sudo systemctl status vsftpd</pre>
  
 
2. Проверьте, что vsftpd слушает на порту 21:
 
2. Проверьте, что vsftpd слушает на порту 21:
<code>sudo netstat -tlnp | grep :21</code>
+
<pre>sudo netstat -tlnp | grep :21</pre>
  
 
3. Проверьте версию vsftpd:
 
3. Проверьте версию vsftpd:
<code>vsftpd -v</code>
+
<pre>vsftpd -v</pre>
  
 
== 3. Базовая настройка vsftpd ==
 
== 3. Базовая настройка vsftpd ==
Строка 36: Строка 36:
  
 
1. Создайте резервную копию конфигурации:
 
1. Создайте резервную копию конфигурации:
<code>sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.backup</code>
+
<pre>sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.backup</pre>
  
 
2. Отредактируйте файл конфигурации:
 
2. Отредактируйте файл конфигурации:
<code>sudo nano /etc/vsftpd.conf</code>
+
<pre>sudo nano /etc/vsftpd.conf</pre>
  
 
3. Настройте основные параметры:
 
3. Настройте основные параметры:
<code>listen=YES</code>
+
<pre>listen=YES</pre>
<code>listen_ipv6=NO</code>
+
<pre>listen_ipv6=NO</pre>
<code>anonymous_enable=NO</code>
+
<pre>anonymous_enable=NO</pre>
<code>local_enable=YES</code>
+
<pre>local_enable=YES</pre>
<code>write_enable=YES</code>
+
<pre>write_enable=YES</pre>
<code>local_umask=022</code>
+
<pre>local_umask=022</pre>
<code>dirmessage_enable=YES</code>
+
<pre>dirmessage_enable=YES</pre>
<code>use_localtime=YES</code>
+
<pre>use_localtime=YES</pre>
<code>xferlog_enable=YES</code>
+
<pre>xferlog_enable=YES</pre>
<code>connect_from_port_20=YES</code>
+
<pre>connect_from_port_20=YES</pre>
<code>chroot_local_user=YES</code>
+
<pre>chroot_local_user=YES</pre>
<code>secure_chroot_dir=/var/run/vsftpd/empty</code>
+
<pre>secure_chroot_dir=/var/run/vsftpd/empty</pre>
<code>pam_service_name=vsftpd</code>
+
<pre>pam_service_name=vsftpd</pre>
<code>rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem</code>
+
<pre>rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem</pre>
<code>rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key</code>
+
<pre>rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key</pre>
<code>ssl_enable=NO</code>
+
<pre>ssl_enable=NO</pre>
  
 
=== Настройка безопасности ===
 
=== Настройка безопасности ===
  
 
1. Добавьте настройки безопасности:
 
1. Добавьте настройки безопасности:
<code>userlist_enable=YES</code>
+
<pre>userlist_enable=YES</pre>
<code>userlist_file=/etc/vsftpd.userlist</code>
+
<pre>userlist_file=/etc/vsftpd.userlist</pre>
<code>userlist_deny=NO</code>
+
<pre>userlist_deny=NO</pre>
<code>tcp_wrappers=YES</code>
+
<pre>tcp_wrappers=YES</pre>
<code>hide_ids=YES</code>
+
<pre>hide_ids=YES</pre>
  
 
2. Создайте файл пользователей:
 
2. Создайте файл пользователей:
<code>sudo nano /etc/vsftpd.userlist</code>
+
<pre>sudo nano /etc/vsftpd.userlist</pre>
  
 
3. Добавьте разрешенных пользователей:
 
3. Добавьте разрешенных пользователей:
<code>ftpuser1</code>
+
<pre>ftpuser1</pre>
<code>ftpuser2</code>
+
<pre>ftpuser2</pre>
  
 
== 4. Настройка пользователей FTP ==
 
== 4. Настройка пользователей FTP ==
Строка 80: Строка 80:
  
 
1. Создайте пользователя для FTP:
 
1. Создайте пользователя для FTP:
<code>sudo useradd -m -s /bin/bash ftpuser1</code>
+
<pre>sudo useradd -m -s /bin/bash ftpuser1</pre>
  
 
2. Установите пароль:
 
2. Установите пароль:
<code>sudo passwd ftpuser1</code>
+
<pre>sudo passwd ftpuser1</pre>
  
 
3. Добавьте пользователя в файл разрешений:
 
3. Добавьте пользователя в файл разрешений:
<code>echo "ftpuser1" | sudo tee -a /etc/vsftpd.userlist</code>
+
<pre>echo "ftpuser1" | sudo tee -a /etc/vsftpd.userlist</pre>
  
 
=== Настройка домашних директорий ===
 
=== Настройка домашних директорий ===
  
 
1. Создайте директорию для FTP:
 
1. Создайте директорию для FTP:
<code>sudo mkdir -p /home/ftpuser1/ftp</code>
+
<pre>sudo mkdir -p /home/ftpuser1/ftp</pre>
  
 
2. Установите права доступа:
 
2. Установите права доступа:
<code>sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp</code>
+
<pre>sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp</pre>
<code>sudo chmod 755 /home/ftpuser1/ftp</code>
+
<pre>sudo chmod 755 /home/ftpuser1/ftp</pre>
  
 
3. Создайте директории для загрузки и скачивания:
 
3. Создайте директории для загрузки и скачивания:
<code>sudo mkdir -p /home/ftpuser1/ftp/{upload,download}</code>
+
<pre>sudo mkdir -p /home/ftpuser1/ftp/{upload,download}</pre>
<code>sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp/{upload,download}</code>
+
<pre>sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp/{upload,download}</pre>
<code>sudo chmod 755 /home/ftpuser1/ftp/{upload,download}</code>
+
<pre>sudo chmod 755 /home/ftpuser1/ftp/{upload,download}</pre>
  
== 5. Настройка виртуальных пользователей ===
+
== 5. Настройка виртуальных пользователей ==
  
 
=== Создание виртуальных пользователей ===
 
=== Создание виртуальных пользователей ===
  
 
1. Создайте директорию для виртуальных пользователей:
 
1. Создайте директорию для виртуальных пользователей:
<code>sudo mkdir -p /etc/vsftpd/virtual_users</code>
+
<pre>sudo mkdir -p /etc/vsftpd/virtual_users</pre>
  
 
2. Создайте файл с паролями:
 
2. Создайте файл с паролями:
<code>sudo nano /etc/vsftpd/virtual_users/passwd</code>
+
<pre>sudo nano /etc/vsftpd/virtual_users/passwd</pre>
  
 
3. Добавьте пользователей (пользователь:пароль):
 
3. Добавьте пользователей (пользователь:пароль):
<code>virtualuser1:password1</code>
+
<pre>virtualuser1:password1</pre>
<code>virtualuser2:password2</code>
+
<pre>virtualuser2:password2</pre>
  
 
4. Создайте базу данных пользователей:
 
4. Создайте базу данных пользователей:
<code>sudo db_load -T -t hash -f /etc/vsftpd/virtual_users/passwd /etc/vsftpd/virtual_users/passwd.db</code>
+
<pre>sudo db_load -T -t hash -f /etc/vsftpd/virtual_users/passwd /etc/vsftpd/virtual_users/passwd.db</pre>
  
 
5. Установите права доступа:
 
5. Установите права доступа:
<code>sudo chmod 600 /etc/vsftpd/virtual_users/passwd.db</code>
+
<pre>sudo chmod 600 /etc/vsftpd/virtual_users/passwd.db</pre>
  
 
=== Настройка PAM для виртуальных пользователей ===
 
=== Настройка PAM для виртуальных пользователей ===
  
 
1. Создайте файл PAM:
 
1. Создайте файл PAM:
<code>sudo nano /etc/pam.d/vsftpd_virtual</code>
+
<pre>sudo nano /etc/pam.d/vsftpd_virtual</pre>
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>auth required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd</code>
+
<pre>auth required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd</pre>
<code>account required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd</code>
+
<pre>account required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd</pre>
  
 
=== Настройка конфигурации для виртуальных пользователей ===
 
=== Настройка конфигурации для виртуальных пользователей ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>sudo nano /etc/vsftpd.conf</code>
+
<pre>sudo nano /etc/vsftpd.conf</pre>
  
 
2. Добавьте настройки виртуальных пользователей:
 
2. Добавьте настройки виртуальных пользователей:
<code>guest_enable=YES</code>
+
<pre>guest_enable=YES</pre>
<code>guest_username=ftp</code>
+
<pre>guest_username=ftp</pre>
<code>virtual_use_local_privs=YES</code>
+
<pre>virtual_use_local_privs=YES</pre>
<code>pam_service_name=vsftpd_virtual</code>
+
<pre>pam_service_name=vsftpd_virtual</pre>
<code>user_sub_token=$USER</code>
+
<pre>user_sub_token=$USER</pre>
<code>local_root=/home/vftp/$USER</code>
+
<pre>local_root=/home/vftp/$USER</pre>
  
 
3. Создайте директории для виртуальных пользователей:
 
3. Создайте директории для виртуальных пользователей:
<code>sudo mkdir -p /home/vftp/{virtualuser1,virtualuser2}</code>
+
<pre>sudo mkdir -p /home/vftp/{virtualuser1,virtualuser2}</pre>
<code>sudo chown ftp:ftp /home/vftp/{virtualuser1,virtualuser2}</code>
+
<pre>sudo chown ftp:ftp /home/vftp/{virtualuser1,virtualuser2}</pre>
<code>sudo chmod 755 /home/vftp/{virtualuser1,virtualuser2}</code>
+
<pre>sudo chmod 755 /home/vftp/{virtualuser1,virtualuser2}</pre>
  
== 6. Настройка SSL/TLS ===
+
== 6. Настройка SSL/TLS ==
  
 
=== Генерация SSL сертификата ===
 
=== Генерация SSL сертификата ===
  
 
1. Создайте приватный ключ:
 
1. Создайте приватный ключ:
<code>sudo openssl genrsa -out /etc/ssl/private/vsftpd.key 2048</code>
+
<pre>sudo openssl genrsa -out /etc/ssl/private/vsftpd.key 2048</pre>
  
 
2. Создайте запрос на сертификат:
 
2. Создайте запрос на сертификат:
<code>sudo openssl req -new -key /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.csr</code>
+
<pre>sudo openssl req -new -key /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.csr</pre>
  
 
3. Создайте самоподписанный сертификат:
 
3. Создайте самоподписанный сертификат:
<code>sudo openssl x509 -req -days 365 -in /etc/ssl/certs/vsftpd.csr -signkey /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.crt</code>
+
<pre>sudo openssl x509 -req -days 365 -in /etc/ssl/certs/vsftpd.csr -signkey /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.crt</pre>
  
 
=== Настройка SSL в vsftpd ===
 
=== Настройка SSL в vsftpd ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>sudo nano /etc/vsftpd.conf</code>
+
<pre>sudo nano /etc/vsftpd.conf</pre>
  
 
2. Добавьте настройки SSL:
 
2. Добавьте настройки SSL:
<code>ssl_enable=YES</code>
+
<pre>ssl_enable=YES</pre>
<code>allow_anon_ssl=NO</code>
+
<pre>allow_anon_ssl=NO</pre>
<code>force_local_data_ssl=YES</code>
+
<pre>force_local_data_ssl=YES</pre>
<code>force_local_logins_ssl=YES</code>
+
<pre>force_local_logins_ssl=YES</pre>
<code>ssl_tlsv1=YES</code>
+
<pre>ssl_tlsv1=YES</pre>
<code>ssl_sslv2=NO</code>
+
<pre>ssl_sslv2=NO</pre>
<code>ssl_sslv3=NO</code>
+
<pre>ssl_sslv3=NO</pre>
<code>rsa_cert_file=/etc/ssl/certs/vsftpd.crt</code>
+
<pre>rsa_cert_file=/etc/ssl/certs/vsftpd.crt</pre>
<code>rsa_private_key_file=/etc/ssl/private/vsftpd.key</code>
+
<pre>rsa_private_key_file=/etc/ssl/private/vsftpd.key</pre>
  
 
3. Перезапустите vsftpd:
 
3. Перезапустите vsftpd:
<code>sudo systemctl restart vsftpd</code>
+
<pre>sudo systemctl restart vsftpd</pre>
  
== 7. Настройка файрвола ===
+
== 7. Настройка файрвола ==
  
 
=== Настройка UFW ===
 
=== Настройка UFW ===
  
 
1. Разрешите FTP трафик:
 
1. Разрешите FTP трафик:
<code>sudo ufw allow 20/tcp</code>
+
<pre>sudo ufw allow 20/tcp</pre>
<code>sudo ufw allow 21/tcp</code>
+
<pre>sudo ufw allow 21/tcp</pre>
<code>sudo ufw allow 1024:65535/tcp</code>
+
<pre>sudo ufw allow 1024:65535/tcp</pre>
  
 
2. Проверьте статус:
 
2. Проверьте статус:
<code>sudo ufw status</code>
+
<pre>sudo ufw status</pre>
  
 
=== Настройка iptables ===
 
=== Настройка iptables ===
  
 
1. Разрешите FTP порты:
 
1. Разрешите FTP порты:
<code>sudo iptables -A INPUT -p tcp --dport 20 -j ACCEPT</code>
+
<pre>sudo iptables -A INPUT -p tcp --dport 20 -j ACCEPT</pre>
<code>sudo iptables -A INPUT -p tcp --dport 21 -j ACCEPT</code>
+
<pre>sudo iptables -A INPUT -p tcp --dport 21 -j ACCEPT</pre>
<code>sudo iptables -A INPUT -p tcp --dport 1024:65535 -j ACCEPT</code>
+
<pre>sudo iptables -A INPUT -p tcp --dport 1024:65535 -j ACCEPT</pre>
  
 
2. Сохраните правила:
 
2. Сохраните правила:
<code>sudo iptables-save > /etc/iptables/rules.v4</code>
+
<pre>sudo iptables-save > /etc/iptables/rules.v4</pre>
  
== 8. Настройка пассивного режима ===
+
== 8. Настройка пассивного режима ==
  
 
=== Настройка пассивного FTP ===
 
=== Настройка пассивного FTP ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>sudo nano /etc/vsftpd.conf</code>
+
<pre>sudo nano /etc/vsftpd.conf</pre>
  
 
2. Добавьте настройки пассивного режима:
 
2. Добавьте настройки пассивного режима:
<code>pasv_enable=YES</code>
+
<pre>pasv_enable=YES</pre>
<code>pasv_min_port=21100</code>
+
<pre>pasv_min_port=21100</pre>
<code>pasv_max_port=21110</code>
+
<pre>pasv_max_port=21110</pre>
<code>pasv_address=YOUR_SERVER_IP</code>
+
<pre>pasv_address=YOUR_SERVER_IP</pre>
  
 
3. Замените YOUR_SERVER_IP на IP адрес вашего сервера.
 
3. Замените YOUR_SERVER_IP на IP адрес вашего сервера.
Строка 221: Строка 221:
  
 
1. Добавьте настройки активного режима:
 
1. Добавьте настройки активного режима:
<code>port_enable=YES</code>
+
<pre>port_enable=YES</pre>
<code>connect_from_port_20=YES</code>
+
<pre>connect_from_port_20=YES</pre>
<code>ftp_data_port=20</code>
+
<pre>ftp_data_port=20</pre>
  
 
== 9. Управление vsftpd ==
 
== 9. Управление vsftpd ==
Строка 230: Строка 230:
  
 
* '''Запуск vsftpd''':
 
* '''Запуск vsftpd''':
<code>sudo systemctl start vsftpd</code>
+
<pre>sudo systemctl start vsftpd</pre>
  
 
* '''Остановка vsftpd''':
 
* '''Остановка vsftpd''':
<code>sudo systemctl stop vsftpd</code>
+
<pre>sudo systemctl stop vsftpd</pre>
  
 
* '''Перезапуск vsftpd''':
 
* '''Перезапуск vsftpd''':
<code>sudo systemctl restart vsftpd</code>
+
<pre>sudo systemctl restart vsftpd</pre>
  
 
* '''Проверка статуса''':
 
* '''Проверка статуса''':
<code>sudo systemctl status vsftpd</code>
+
<pre>sudo systemctl status vsftpd</pre>
  
 
* '''Проверка конфигурации''':
 
* '''Проверка конфигурации''':
<code>sudo vsftpd -olisten=NO /etc/vsftpd.conf</code>
+
<pre>sudo vsftpd -olisten=NO /etc/vsftpd.conf</pre>
  
 
=== Управление пользователями ===
 
=== Управление пользователями ===
  
 
1. Добавьте пользователя в разрешенные:
 
1. Добавьте пользователя в разрешенные:
<code>echo "newuser" | sudo tee -a /etc/vsftpd.userlist</code>
+
<pre>echo "newuser" | sudo tee -a /etc/vsftpd.userlist</pre>
  
 
2. Удалите пользователя из разрешенных:
 
2. Удалите пользователя из разрешенных:
<code>sudo sed -i '/^newuser$/d' /etc/vsftpd.userlist</code>
+
<pre>sudo sed -i '/^newuser$/d' /etc/vsftpd.userlist</pre>
  
 
3. Заблокируйте пользователя:
 
3. Заблокируйте пользователя:
<code>echo "blockeduser" | sudo tee -a /etc/vsftpd.denied</code>
+
<pre>echo "blockeduser" | sudo tee -a /etc/vsftpd.denied</pre>
  
== 10. Мониторинг и логирование ===
+
== 10. Мониторинг и логирование ==
  
 
=== Настройка логирования ===
 
=== Настройка логирования ===
  
 
1. Отредактируйте конфигурацию:
 
1. Отредактируйте конфигурацию:
<code>sudo nano /etc/vsftpd.conf</code>
+
<pre>sudo nano /etc/vsftpd.conf</pre>
  
 
2. Добавьте настройки логирования:
 
2. Добавьте настройки логирования:
<code>xferlog_enable=YES</code>
+
<pre>xferlog_enable=YES</pre>
<code>xferlog_file=/var/log/vsftpd.log</code>
+
<pre>xferlog_file=/var/log/vsftpd.log</pre>
<code>log_ftp_protocol=YES</code>
+
<pre>log_ftp_protocol=YES</pre>
  
 
3. Создайте файл логов:
 
3. Создайте файл логов:
<code>sudo touch /var/log/vsftpd.log</code>
+
<pre>sudo touch /var/log/vsftpd.log</pre>
<code>sudo chown ftp:ftp /var/log/vsftpd.log</code>
+
<pre>sudo chown ftp:ftp /var/log/vsftpd.log</pre>
  
 
=== Просмотр логов ===
 
=== Просмотр логов ===
  
 
1. Просмотрите логи vsftpd:
 
1. Просмотрите логи vsftpd:
<code>sudo tail -f /var/log/vsftpd.log</code>
+
<pre>sudo tail -f /var/log/vsftpd.log</pre>
  
 
2. Просмотрите системные логи:
 
2. Просмотрите системные логи:
<code>sudo journalctl -u vsftpd -f</code>
+
<pre>sudo journalctl -u vsftpd -f</pre>
  
 
3. Просмотрите логи аутентификации:
 
3. Просмотрите логи аутентификации:
<code>sudo tail -f /var/log/auth.log | grep vsftpd</code>
+
<pre>sudo tail -f /var/log/auth.log | grep vsftpd</pre>
  
 
=== Создание скрипта мониторинга ===
 
=== Создание скрипта мониторинга ===
  
 
1. Создайте скрипт мониторинга:
 
1. Создайте скрипт мониторинга:
<code>sudo nano /usr/local/bin/ftp-monitor.sh</code>
+
<pre>sudo nano /usr/local/bin/ftp-monitor.sh</pre>
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>if systemctl is-active --quiet vsftpd; then</code>
+
<pre>if systemctl is-active --quiet vsftpd; then</pre>
<code>echo "vsftpd is running"</code>
+
<pre>echo "vsftpd is running"</pre>
<code>CONNECTIONS=$(netstat -an | grep :21 | wc -l)</code>
+
<pre>CONNECTIONS=$(netstat -an | grep :21 | wc -l)</pre>
<code>echo "Active FTP connections: $CONNECTIONS"</code>
+
<pre>echo "Active FTP connections: $CONNECTIONS"</pre>
<code>MEMORY=$(ps aux | grep vsftpd | grep -v grep | awk '{print $6}')</code>
+
<pre>MEMORY=$(ps aux | grep vsftpd | grep -v grep | awk '{print $6}')</pre>
<code>echo "Memory usage: $MEMORY KB"</code>
+
<pre>echo "Memory usage: $MEMORY KB"</pre>
<code>else</code>
+
<pre>else</pre>
<code>echo "vsftpd is not running"</code>
+
<pre>echo "vsftpd is not running"</pre>
<code>echo "vsftpd is down" | mail -s "FTP Alert" admin@example.com</code>
+
<pre>echo "vsftpd is down" | mail -s "FTP Alert" admin@example.com</pre>
<code>fi</code>
+
<pre>fi</pre>
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
<code>sudo chmod +x /usr/local/bin/ftp-monitor.sh</code>
+
<pre>sudo chmod +x /usr/local/bin/ftp-monitor.sh</pre>
  
== 11. Устранение неполадок ===
+
== 11. Устранение неполадок ==
  
 
=== Частые проблемы ===
 
=== Частые проблемы ===
  
 
1. '''FTP сервер не запускается''':
 
1. '''FTP сервер не запускается''':
* Проверьте конфигурацию: <code>sudo vsftpd -olisten=NO /etc/vsftpd.conf</code>
+
* Проверьте конфигурацию: <pre>sudo vsftpd -olisten=NO /etc/vsftpd.conf</pre>
* Проверьте логи: <code>sudo journalctl -u vsftpd</code>
+
* Проверьте логи: <pre>sudo journalctl -u vsftpd</pre>
* Проверьте права на файлы: <code>ls -la /etc/vsftpd.conf</code>
+
* Проверьте права на файлы: <pre>ls -la /etc/vsftpd.conf</pre>
  
 
2. '''Пользователи не могут подключиться''':
 
2. '''Пользователи не могут подключиться''':
* Проверьте файрвол: <code>sudo ufw status</code>
+
* Проверьте файрвол: <pre>sudo ufw status</pre>
* Проверьте порты: <code>sudo netstat -tlnp | grep :21</code>
+
* Проверьте порты: <pre>sudo netstat -tlnp | grep :21</pre>
* Проверьте пользователей: <code>cat /etc/vsftpd.userlist</code>
+
* Проверьте пользователей: <pre>cat /etc/vsftpd.userlist</pre>
  
 
3. '''Ошибка "500 Illegal PORT command"''':
 
3. '''Ошибка "500 Illegal PORT command"''':
Строка 323: Строка 323:
  
 
1. Проверьте статус сервиса:
 
1. Проверьте статус сервиса:
<code>sudo systemctl status vsftpd</code>
+
<pre>sudo systemctl status vsftpd</pre>
  
 
2. Проверьте подключения:
 
2. Проверьте подключения:
<code>sudo netstat -an | grep :21</code>
+
<pre>sudo netstat -an | grep :21</pre>
  
 
3. Проверьте логи:
 
3. Проверьте логи:
<code>sudo tail -f /var/log/vsftpd.log</code>
+
<pre>sudo tail -f /var/log/vsftpd.log</pre>
  
== 12. Дополнительные настройки ===
+
== 12. Дополнительные настройки ==
  
 
=== Настройка ограничений ===
 
=== Настройка ограничений ===
  
 
1. Добавьте ограничения в конфигурацию:
 
1. Добавьте ограничения в конфигурацию:
<code>max_clients=50</code>
+
<pre>max_clients=50</pre>
<code>max_per_ip=5</code>
+
<pre>max_per_ip=5</pre>
<code>local_max_rate=1000000</code>
+
<pre>local_max_rate=1000000</pre>
<code>anon_max_rate=500000</code>
+
<pre>anon_max_rate=500000</pre>
  
 
=== Настройка баннеров ===
 
=== Настройка баннеров ===
  
 
1. Создайте файл баннера:
 
1. Создайте файл баннера:
<code>sudo nano /etc/vsftpd/banner</code>
+
<pre>sudo nano /etc/vsftpd/banner</pre>
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>Welcome to FTP Server</code>
+
<pre>Welcome to FTP Server</pre>
<code>Authorized users only</code>
+
<pre>Authorized users only</pre>
  
 
3. Добавьте в конфигурацию:
 
3. Добавьте в конфигурацию:
<code>ftpd_banner=/etc/vsftpd/banner</code>
+
<pre>ftpd_banner=/etc/vsftpd/banner</pre>
  
 
=== Настройка автоматического отключения ===
 
=== Настройка автоматического отключения ===
  
 
1. Добавьте настройки таймаутов:
 
1. Добавьте настройки таймаутов:
<code>idle_session_timeout=600</code>
+
<pre>idle_session_timeout=600</pre>
<code>data_connection_timeout=120</code>
+
<pre>data_connection_timeout=120</pre>
  
 
== Заключение ==
 
== Заключение ==

Текущая версия на 10:42, 15 октября 2025

Содержание

Установка и настройка FTP сервера (vsftpd)

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Убедитесь, что у вас есть доступ к серверу через SSH или консоль.

2. Установка vsftpd

Установка пакета

1. Обновите список пакетов:

sudo apt update

2. Установите vsftpd:

sudo apt install vsftpd

3. Запустите и включите автозапуск vsftpd:

sudo systemctl start vsftpd
sudo systemctl enable vsftpd

Проверка установки

1. Проверьте статус сервиса:

sudo systemctl status vsftpd

2. Проверьте, что vsftpd слушает на порту 21:

sudo netstat -tlnp | grep :21

3. Проверьте версию vsftpd:

vsftpd -v

3. Базовая настройка vsftpd

Основная конфигурация

1. Создайте резервную копию конфигурации:

sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.backup

2. Отредактируйте файл конфигурации:

sudo nano /etc/vsftpd.conf

3. Настройте основные параметры:

listen=YES
listen_ipv6=NO
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
ssl_enable=NO

Настройка безопасности

1. Добавьте настройки безопасности:

userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
tcp_wrappers=YES
hide_ids=YES

2. Создайте файл пользователей:

sudo nano /etc/vsftpd.userlist

3. Добавьте разрешенных пользователей:

ftpuser1
ftpuser2

4. Настройка пользователей FTP

Создание пользователей

1. Создайте пользователя для FTP:

sudo useradd -m -s /bin/bash ftpuser1

2. Установите пароль:

sudo passwd ftpuser1

3. Добавьте пользователя в файл разрешений:

echo "ftpuser1" | sudo tee -a /etc/vsftpd.userlist

Настройка домашних директорий

1. Создайте директорию для FTP:

sudo mkdir -p /home/ftpuser1/ftp

2. Установите права доступа:

sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp
sudo chmod 755 /home/ftpuser1/ftp

3. Создайте директории для загрузки и скачивания:

sudo mkdir -p /home/ftpuser1/ftp/{upload,download}
sudo chown ftpuser1:ftpuser1 /home/ftpuser1/ftp/{upload,download}
sudo chmod 755 /home/ftpuser1/ftp/{upload,download}

5. Настройка виртуальных пользователей

Создание виртуальных пользователей

1. Создайте директорию для виртуальных пользователей:

sudo mkdir -p /etc/vsftpd/virtual_users

2. Создайте файл с паролями:

sudo nano /etc/vsftpd/virtual_users/passwd

3. Добавьте пользователей (пользователь:пароль):

virtualuser1:password1
virtualuser2:password2

4. Создайте базу данных пользователей:

sudo db_load -T -t hash -f /etc/vsftpd/virtual_users/passwd /etc/vsftpd/virtual_users/passwd.db

5. Установите права доступа:

sudo chmod 600 /etc/vsftpd/virtual_users/passwd.db

Настройка PAM для виртуальных пользователей

1. Создайте файл PAM:

sudo nano /etc/pam.d/vsftpd_virtual

2. Добавьте содержимое:

auth required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd
account required pam_userdb.so db=/etc/vsftpd/virtual_users/passwd

Настройка конфигурации для виртуальных пользователей

1. Отредактируйте конфигурацию:

sudo nano /etc/vsftpd.conf

2. Добавьте настройки виртуальных пользователей:

guest_enable=YES
guest_username=ftp
virtual_use_local_privs=YES
pam_service_name=vsftpd_virtual
user_sub_token=$USER
local_root=/home/vftp/$USER

3. Создайте директории для виртуальных пользователей:

sudo mkdir -p /home/vftp/{virtualuser1,virtualuser2}
sudo chown ftp:ftp /home/vftp/{virtualuser1,virtualuser2}
sudo chmod 755 /home/vftp/{virtualuser1,virtualuser2}

6. Настройка SSL/TLS

Генерация SSL сертификата

1. Создайте приватный ключ:

sudo openssl genrsa -out /etc/ssl/private/vsftpd.key 2048

2. Создайте запрос на сертификат:

sudo openssl req -new -key /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.csr

3. Создайте самоподписанный сертификат:

sudo openssl x509 -req -days 365 -in /etc/ssl/certs/vsftpd.csr -signkey /etc/ssl/private/vsftpd.key -out /etc/ssl/certs/vsftpd.crt

Настройка SSL в vsftpd

1. Отредактируйте конфигурацию:

sudo nano /etc/vsftpd.conf

2. Добавьте настройки SSL:

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
rsa_cert_file=/etc/ssl/certs/vsftpd.crt
rsa_private_key_file=/etc/ssl/private/vsftpd.key

3. Перезапустите vsftpd:

sudo systemctl restart vsftpd

7. Настройка файрвола

Настройка UFW

1. Разрешите FTP трафик:

sudo ufw allow 20/tcp
sudo ufw allow 21/tcp
sudo ufw allow 1024:65535/tcp

2. Проверьте статус:

sudo ufw status

Настройка iptables

1. Разрешите FTP порты:

sudo iptables -A INPUT -p tcp --dport 20 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 21 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 1024:65535 -j ACCEPT

2. Сохраните правила:

sudo iptables-save > /etc/iptables/rules.v4

8. Настройка пассивного режима

Настройка пассивного FTP

1. Отредактируйте конфигурацию:

sudo nano /etc/vsftpd.conf

2. Добавьте настройки пассивного режима:

pasv_enable=YES
pasv_min_port=21100
pasv_max_port=21110
pasv_address=YOUR_SERVER_IP

3. Замените YOUR_SERVER_IP на IP адрес вашего сервера.

Настройка активного режима

1. Добавьте настройки активного режима:

port_enable=YES
connect_from_port_20=YES
ftp_data_port=20

9. Управление vsftpd

Основные команды управления

  • Запуск vsftpd:
sudo systemctl start vsftpd
  • Остановка vsftpd:
sudo systemctl stop vsftpd
  • Перезапуск vsftpd:
sudo systemctl restart vsftpd
  • Проверка статуса:
sudo systemctl status vsftpd
  • Проверка конфигурации:
sudo vsftpd -olisten=NO /etc/vsftpd.conf

Управление пользователями

1. Добавьте пользователя в разрешенные:

echo "newuser" | sudo tee -a /etc/vsftpd.userlist

2. Удалите пользователя из разрешенных:

sudo sed -i '/^newuser$/d' /etc/vsftpd.userlist

3. Заблокируйте пользователя:

echo "blockeduser" | sudo tee -a /etc/vsftpd.denied

10. Мониторинг и логирование

Настройка логирования

1. Отредактируйте конфигурацию:

sudo nano /etc/vsftpd.conf

2. Добавьте настройки логирования:

xferlog_enable=YES
xferlog_file=/var/log/vsftpd.log
log_ftp_protocol=YES

3. Создайте файл логов:

sudo touch /var/log/vsftpd.log
sudo chown ftp:ftp /var/log/vsftpd.log

Просмотр логов

1. Просмотрите логи vsftpd:

sudo tail -f /var/log/vsftpd.log

2. Просмотрите системные логи:

sudo journalctl -u vsftpd -f

3. Просмотрите логи аутентификации:

sudo tail -f /var/log/auth.log | grep vsftpd

Создание скрипта мониторинга

1. Создайте скрипт мониторинга:

sudo nano /usr/local/bin/ftp-monitor.sh

2. Добавьте содержимое:

if systemctl is-active --quiet vsftpd; then
echo "vsftpd is running"
CONNECTIONS=$(netstat -an | grep :21 | wc -l)
echo "Active FTP connections: $CONNECTIONS"
MEMORY=$(ps aux | grep vsftpd | grep -v grep | awk '{print $6}')
echo "Memory usage: $MEMORY KB"
else
echo "vsftpd is not running"
echo "vsftpd is down" | mail -s "FTP Alert" admin@example.com
fi

3. Сделайте скрипт исполняемым:

sudo chmod +x /usr/local/bin/ftp-monitor.sh

11. Устранение неполадок

Частые проблемы

1. FTP сервер не запускается:

  • Проверьте конфигурацию:
    sudo vsftpd -olisten=NO /etc/vsftpd.conf
  • Проверьте логи:
    sudo journalctl -u vsftpd
  • Проверьте права на файлы:
    ls -la /etc/vsftpd.conf

2. Пользователи не могут подключиться:

  • Проверьте файрвол:
    sudo ufw status
  • Проверьте порты:
    sudo netstat -tlnp | grep :21
  • Проверьте пользователей:
    cat /etc/vsftpd.userlist

3. Ошибка "500 Illegal PORT command":

  • Проверьте настройки пассивного режима
  • Проверьте файрвол для пассивных портов

Диагностика

1. Проверьте статус сервиса:

sudo systemctl status vsftpd

2. Проверьте подключения:

sudo netstat -an | grep :21

3. Проверьте логи:

sudo tail -f /var/log/vsftpd.log

12. Дополнительные настройки

Настройка ограничений

1. Добавьте ограничения в конфигурацию:

max_clients=50
max_per_ip=5
local_max_rate=1000000
anon_max_rate=500000

Настройка баннеров

1. Создайте файл баннера:

sudo nano /etc/vsftpd/banner

2. Добавьте содержимое:

Welcome to FTP Server
Authorized users only

3. Добавьте в конфигурацию:

ftpd_banner=/etc/vsftpd/banner

Настройка автоматического отключения

1. Добавьте настройки таймаутов:

idle_session_timeout=600
data_connection_timeout=120

Заключение

FTP сервер vsftpd успешно установлен и настроен! Теперь вы можете предоставлять файловые услуги.

Для размещения ваших FTP серверов на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой FTP и обеспечением безопасности вашего сервера!