在windows8下安装Oracle VM VirtualBox虚拟机,虚拟机中安装的CentOS操作系统,在CentOS中搭建LNMP环境,安装vsftpd服务器,宿主机在phpStorm编程,将代码FTP上传到虚拟机,在宿主机浏览器输入地址,访问虚拟机中php代码页。虚拟机网络使用桥接方式很方便,但是宿主机进入公司办公网络后,FTP出现问题,因此改用网络采用NAT模式。NAT下虚拟机ip地址10.0.2.15。
安装过程分为三步,
1,在CentOS安装vsftpd服务器,配置好,再安装ftp客户端,可以利用ftp客户端访问vsftpd服务器;
2,在宿主机中通过网页访问虚拟机中ftp服务器;
3,在宿主机phpStorm配置ftp服务器,可以连接虚拟机中ftp服务器;将代码上传到虚拟机中ftp服务器;
1,在CentOS安装vsftpd服务器,配置好,再安装ftp客户端,可以利用ftp客户端访问vsftpd服务器;
1.1,以管理员(root)身份执行以下命令,安装FTP服务器端
yum install vsftpd
1.2,设置开机启动vsftpd ftp服务
chkconfig vsftpd on
1.3,启动vsftpd服务
service vsftpd start
1.4,安装FTP客户端
yum install ftp
1.5,为ftp添加用户
/usr/sbin/adduser -d /opt/ftp1 -g ftp -s /sbin/nologin ftp1
1.6,为ftp1用户设置密码
passwd ftp1
输入新密码即可
1.7,测试vsftp是否安装成功
ftp 10.0.2.15
用户名
密码
显示成功,表示vsftpd安装成功。(有时会出现错误,需要去vsftpd.conf禁用默认用户登录
vim /etc/vsftpd/vsftpd.conf
anonymous_enable = YES 修改为 anonymous_enable = NO
重启vsftpd服务,service vsftpd restart
)。
2,在宿主机中通过网页访问虚拟机中ftp服务器;
由于虚拟机选用NAT网络模式,虚拟机可以访问宿主机,宿主机没法访问虚拟机,需要在NAT中配置接口转换,ftp对应20,21两个接口,需要NAT配置两次,比如
127.0.0.10 2020 10.0.2.15 20 127.0.0.10 2021 10.0.2.15 21
在宿主机的浏览器输入ftp://127.0.0.10:2021,会弹出输入用户名、密码窗口,输入后显示错误。此时通过对ftp了解,知道ftp连接分为两个过程:客户端连接服务器的21端口,认证用户是否合法,验证通过之后;服务器端会将根目录下数据通过20端口发送到客户端。我们可以登陆进去,没法显示服务器端数据。说明20接口有问题。将ftp模式设定为PASV被动模式,设定新的接口。
2.1,在vsftpd.conf中将被动模式接口写进去,
pasv_min_port=2017 pasv_max_port=2020
注意等号左右不能有空格。
2.2,在FTP指令下,将模式设定为PASV。输入passive,使POR和PASV模式切换。
2.3, 在NAT下调整接口
如图所示,LNMP和SSH是配置网页访问虚拟机代码,和ssh连接虚拟机的,此处暂且不考虑。
2.4, 在宿主机的浏览器输入ftp://127.0.0.10:2021,会弹出输入用户名、密码窗口,输入后显示根目录内容;
3,在宿主机phpStorm配置ftp服务器,可以连接虚拟机中ftp服务器;将代码上传到虚拟机中ftp服务器
3.1,在phpStorm配置ftp,点击advanced options选择被动模式;
3.2,mapping需要配置下
3.4.1,确保/opt/ftp1目录对应ftp1用户权限是755或777,如果不是修改;
3.4.2,使用命令getsebool -a|grep ftp 查看ftpd_disable_trans ftp_home_dir allow_ftpd_full_access 是否为on。如果不是需要修改。
第一个修改setsebool ftpd_disable_trans 1,此时又会出错,貌似找不到setsebool ftpd_disable_trans;直接修改setsebool ftp_home_dir 1,只要ftp_home_dir修改成功,就不用管ftpd_disable_trans了。第三个修改setsebool allow_ftpd_full_access 1。至此宿主机可以将代码上传到虚拟机了。但是这个修改只是临时的,关闭虚拟机重启后失效,每次开机都需要修改很麻烦,因此还有种方式直接关闭selinux,然后重启即可。
(
vi /etc/selinux/config
#SELINUX=enforcing #注释掉
#SELINUXTYPE=targeted #注释掉
SELINUX=disabled #增加
:wq #保存,关闭。
shutdown -r now #重启系统
查看SELinux的状态:
getenforce
)