Установка FTP сервера proftpd

По умолчанию в системах семейства ОС Linux доступен только суперпользователь root.
Подключение с данными root по протоколу FTP невозможно т.к. FTP сервер не включен в стандартные пакет программ OS.
Если у Вас возникла необходимость использования FTP сервера без панели управления, можно сделать следующее.

Ознакомиться с тарифами хостинга можно тут

Подключитесь к серверу по протоколу SSH с правами root.

Установка FTP-сервера proftpd

CentOS:
yum install epel-release -y
yum install proftpd -y


Debian/Ubuntu:
apt install proftpd -y


Добавляем FTP в автозапуск сервера и запускаем его

systemctl start proftpd.service
systemctl enable proftpd.service


Добавление разрешающих правил для брандмауэра

В зависимости от используемой утилиты управления

Iptables:

iptables -I INPUT -p tcp -m tcp --dport 21 -j ACCEPT
systemctl iptables save

firewalld:

firewall-cmd --permanent --zone=public --add-port=21/tcp
firewall-cmd --reload


Ограничение FTP-пользователей пределами домашнего каталога

По умолчанию в настройках FTP сервера ProFTP пользователь может выходить за пределы своего домашнего каталога, и хотя прав на работу с другими папками у него, скорее всего, нет, но при недостаточно строгой конфигурации сервера это может представлять угрозу безопасности. 

Решить описанную проблему можно добавив одну строку в файл proftpd.conf:

DefaultRoot ~

Добавить её можно в конец файла.

После сохранения перезапустите FTP-сервер:

systemctl restart proftpd.service


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

Простым FTP-пользователям нет необходимости иметь доступ к командной оболочке (выполнять команды на сервере).
Поэтому при создании пользователей, мы будем отключать им эту возможность.


Добавление пользователя FTP:

useradd имя_пользователя -d /home/имя_папки -m -s /bin/false


Смена пароля пользователя FTP:

passwd имя_пользователя


Командами выше мы создали пользователя (имя_пользователя нужно заменить на незанятое имя) и соответствующую группу, назначили и создали (ключ -m можно опустить, если каталог уже существует) домашний каталог /home/имя_папки и выбрали /bin/false в качестве командной оболочки пользователя, тем самым отключив её в целях безопасности.

Командой passwd мы задали пользователю необходимый пароль.

В большинстве случаев на данном этапе вы уже можете подключаться с созданным пользователем к FTP-серверу, который по умолчанию работает на 21 порту.
Однако, есть еще несколько шагов, которые вы, возможно, захотите выполнить.


Дополнительная информация

Расположение proftpd.conf

Debian/Ubuntu: /etc/proftpd/proftpd.conf
CentOS: /etc/proftpd.conf

Используйте этот файл для более детальной настройки своего FTP-сервера при необходимости.

Ограничение прав FTP-пользователя

При необходимости вы можете ограничить права пользователя на запись в домашнюю директорию, позволив ему работать только с какой-нибудь внутренней папкой, например upload.
От имени суперпользователя измените права:

chmod 555 /home/имя_папки
mkdir /home/имя_папки/upload
chown имя_пользователя:имя_пользователя /home/имя_папки/upload


Описание команд:

В данном случае второе имя_пользователя является именем группы, которое по умолчанию совпадает с созданным вами именем пользователя.
passwd - смена пароля
mkdir - создание каталога
chmod - установка прав на каталог
chown - смена владельца и группы пользователь на каталог

  • 1 Пользователи нашли это полезным

Помог ли вам данный ответ?

Ищете что-то другое?

mhost.by