温馨提示×

如何在CentOS上搭建FTPServer

小樊
53
2025-07-16 19:44:30
栏目: 智能运维

在CentOS上搭建FTPServer(FTP over SSL/TLS)可以通过多种方式实现,其中一种常见的方法是使用vsftpd服务器软件,并配置它以支持FTPS。以下是详细的步骤:

1. 安装vsftpd

首先,确保你的CentOS系统是最新的,然后安装vsftpd

sudo yum update -y
sudo yum install vsftpd -y

2. 配置vsftpd

编辑vsftpd的配置文件/etc/vsftpd/vsftpd.conf

sudo vi /etc/vsftpd/vsftpd.conf

在配置文件中进行以下修改:

  • 启用SSL/TLS:

    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/pki/tls/certs/your_certificate.crt
    rsa_private_key_file=/etc/pki/tls/private/your_private_key.key
    
  • 配置用户认证:

    local_enable=YES
    write_enable=YES
    chroot_local_user=YES
    allow_writeable_chroot=YES
    
  • 其他常用配置:

    listen=YES
    listen_ipv6=NO
    pam_service_name=vsftpd
    userlist_enable=YES
    tcp_wrappers=YES
    

3. 生成SSL证书

如果你还没有SSL证书,可以使用openssl生成自签名证书。

sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/pki/tls/private/your_private_key.key -out /etc/pki/tls/certs/your_certificate.crt

按照提示输入相关信息。

4. 重启vsftpd服务

保存并退出配置文件后,重启vsftpd服务以应用更改。

sudo systemctl restart vsftpd

5. 配置防火墙

确保防火墙允许FTP和FTPS流量。

sudo firewall-cmd --permanent --add-service=ftp
sudo firewall-cmd --permanent --add-service=ftp-data
sudo firewall-cmd --reload

6. 测试FTPS连接

你可以使用FTP客户端(如FileZilla)来测试FTPS连接。在FileZilla中,设置以下参数:

  • 主机:你的服务器IP地址
  • 协议:FTPS - FTP over TLS
  • 加密:要求显式FTP over TLS
  • 用户名:你的FTP用户名
  • 密码:你的FTP密码

连接到服务器,如果一切配置正确,你应该能够成功登录并传输文件。

7. 可选:配置被动模式

如果你需要通过防火墙进行FTP连接,可能需要配置被动模式。

编辑/etc/vsftpd/vsftpd.conf,添加或修改以下配置:

pasv_enable=YES
pasv_min_port=1024
pasv_max_port=1048

然后重启vsftpd服务:

sudo systemctl restart vsftpd

并在防火墙中打开这些端口:

sudo firewall-cmd --permanent --add-port=1024-1048/tcp
sudo firewall-cmd --reload

通过以上步骤,你应该能够在CentOS上成功搭建一个FTPServer。

0