如何在谷歌云计算引擎中创建ftp?我可以通过SFTP连接而没有任何问题,但我的公司正在使用软件通过FTP连接从服务器下载XML文件。不幸的是,该软件没有SFTP连接设施。
我从互联网上看到很多例子,并通过SFTP而不是FTP连接。
任何想法或教程?
答案 0 :(得分:7)
我找到了一种方法来做到这一点,请建议有任何风险。
apt-get install vsftpd libpam-pwdfile
nano /etc/vsftpd.conf
在vsftpd.conf配置文件中。
# vim /etc/vsftpd.conf
listen=YES
listen_ipv6=NO
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
nopriv_user=vsftpd
chroot_local_user=YES
allow_writeable_chroot=yes
guest_username=vsftpd
virtual_use_local_privs=YES
guest_enable=YES
user_sub_token=$USER
local_root=/var/www/$USER
hide_ids=YES
listen_address=0.0.0.0
pasv_min_port=12000
pasv_max_port=12100
pasv_address=888.888.888.888 # My server IP
listen_port=211
从文件中删除所有内容并添加这些行
auth required pam_pwdfile.so pwdfile /etc/ftpd.passwd
account required pam_permit.so
创建虚拟用户将用于进行身份验证的主要用户:
useradd --home /home/vsftpd --gid nogroup -m --shell /bin/false vsftpd
完成后,我们可以创建用户/密码文件。
htpasswd -cd /etc/ftpd.passwd helloftp
接下来,为用户添加目录,因为vsftpd不会自动创建它们。
mkdir /var/www/helloproject
chown vsftpd:nogroup /var/www/helloproject
chmod +w /var/www/helloproject
最后,启动vsftp守护程序并将其设置为在系统引导时自动启动。
systemctl start vsftpd && systemctl enable vsftpd
检查状态以确保服务已启动:
systemctl status vsftpd
● vsftpd.service - vsftpd FTP server
Loaded: loaded (/lib/systemd/system/vsftpd.service; enabled)
Active: active (running) since Sat 2016-12-03 11:07:30 CST; 23min ago
Main PID: 5316 (vsftpd)
CGroup: /system.slice/vsftpd.service
├─5316 /usr/sbin/vsftpd /etc/vsftpd.conf
├─5455 /usr/sbin/vsftpd /etc/vsftpd.conf
└─5457 /usr/sbin/vsftpd /etc/vsftpd.conf
最后添加防火墙规则以通过云访问。
后来我更改了 0.0.0.0 的IP以获得更多限制
答案 1 :(得分:1)
是的,可以在Google Cloud上托管FTP服务器。实际上,我写了一个有关How to set up an FTP server on Google Cloud的深入博客。
如果您的VM基于Linux,则必须使用vsftpd之类的应用程序来设置FTP服务器。
以下是步骤:
第1步:在Google Cloud上部署虚拟实例
第2步:打开SSH终端
步骤3:安装VSFTPD
步骤4:创建用户
步骤5:配置vsftpd.conf文件
步骤6:准备FTP目录
步骤7:FTP / S或SSL上的FTP设置(可选)
步骤8:在Google Cloud Firewall中打开端口
第9步:测试并连接