19,612
社区成员
发帖
与我相关
我的任务
分享
Forbidden
You don't have permission to access / on this server.
[root@localhost ~]# ls -la /var/virtual
total 12
drwxrwxr-x 3 root root 4096 Sep 9 00:50 .
drwxr-xr-x 23 root root 4096 Sep 8 23:54 ..
drwxrw---- 5 apache apache 4096 Sep 9 00:50 xxx.com
[root@localhost ~]# ftp localhost
Trying ::1...
ftp: connect to address ::1Connection refused
Trying 127.0.0.1...
Connected to localhost (127.0.0.1).
220 (vsFTPd 3.0.2)
Name (localhost:root): xxx.com
331 Please specify the password.
Password:
500 OOPS: cannot change directory:/var/virtual/xxx.com
Login failed.
ftp> exit
[root@localhost ~]# uname -a
Linux localhost.localdomain 3.15.4-x86_64-linode45 #1 SMP Mon Jul 7 08:42:36 EDT
2014 x86_64 x86_64 x86_64 GNU/Linux
[root@localhost ~]#
[root@localhost ~]# grep xxx.com /etc/passwd
xxx.com:x:1000:48::/var/virtual/xxx.com:/bin/bash
[root@localhost ~]# grep apache /etc/passwd
apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
[root@localhost ~]# finger xxx.com
Login: xxx.com Name:
Directory: /var/virtual/xxx.com Shell: /bin/bash
Never logged in.
No mail.
No Plan.
[root@localhost ~]# finger apache
Login: apache Name: Apache
Directory: /usr/share/httpd Shell: /sbin/nologin
Never logged in.
No mail.
No Plan.
#!/bin/bash
echo "-------------Begin install xgs ftp server-------------"
NUM=`which vsftpd|wc -l`
if [ $NUM -eq 0 ]; then
echo "Now install vsftpd."
apt-get install vsftpd
if [ $? -ne 0 ]; then
echo "Install vsftpd failed! abort!"
exit 1
fi
fi
NUM=`which db_load|wc -l`
if [ $NUM -eq 0 ]; then
echo "Now install db-util."
apt-get install db-util
if [ $? -ne 0 ]; then
echo "Install db-util failed! abort!"
exit 1
fi
fi
if [ ! -d /etc/vsftpd_user_conf ]; then
mkdir -p /etc/vsftpd_user_conf
if [ $? -ne 0 ]; then
echo "Make directory /etc/vsftpd_user_conf failed! abort!"
exit 1
fi
fi
cat > /etc/vsftpd_user_conf/vsftpd_virtual_users.txt << !
guest
guest
vip
vip
admin
admin
!
db_load -T -t hash -f /etc/vsftpd_user_conf/vsftpd_virtual_users.txt /etc/vsftpd_user_conf/vsftpd_virtual_users.db
if [ $? -ne 0 ]; then
echo "Excute db_load virtual users failed! abort!"
exit 1
fi
rm /etc/vsftpd_user_conf/vsftpd_virtual_users.txt
chmod 600 /etc/vsftpd_user_conf/vsftpd_virtual_users.db
#/lib/i386-linux-gnu/security/pam_userdb.so
cat > /etc/pam.d/vsftpd << !
auth required /lib/i386-linux-gnu/security/pam_userdb.so db=/etc/vsftpd_user_conf/vsftpd_virtual_users
account required /lib/i386-linux-gnu/security/pam_userdb.so db=/etc/vsftpd_user_conf/vsftpd_virtual_users
!
groupadd ftpusr
useradd xgsftp -d /home/ftpshare -g ftpusr -s /bin/bash
mkdir -p /home/ftpshare/IMAGE
mkdir -p /home/ftpshare/UPDATE
chown -hR xgsftp /home/ftpshare
chgrp -hR ftpusr /home/ftpshare
chmod 500 /home/ftpshare
cat >> /etc/vsftpd.conf << !
user_config_dir=/etc/vsftpd_user_conf
local_enable=YES
local_root=/home/ftpshare
guest_enable=YES
guest_username=xgsftp
chroot_local_user=YES
max_clients=100
max_per_ip=1
!
cat > /etc/vsftpd_user_conf/guest << !
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_world_readable_only=NO
download_enable=NO
dirlist_enable=NO
!
cat > /etc/vsftpd_user_conf/vip << !
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_world_readable_only=NO
download_enable=YES
!
cat > /etc/vsftpd_user_conf/admin << !
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_world_readable_only=NO
download_enable=YES
anon_other_write_enable=YES
!
service vsftpd restart
echo "-------------Install xgs ftp server success!-------------"
[root@localhost vsftpd]# ftp localhost
Trying ::1...
ftp: connect to address ::1Connection refused
Trying 127.0.0.1...
Connected to localhost (127.0.0.1).
220 (vsFTPd 3.0.2)
Name (localhost:root): xxx.com
331 Please specify the password.
Password:
500 OOPS: cannot change directory:/var/virtual/xxx.com
Login failed.
ftp> exit
[root@localhost vsftpd]# ls -l /var/virtual/xxx.com
total 12
drwxrwxr-x 2 apache apache 4096 Sep 9 00:50 backup
drwxrwxr-x 2 apache apache 4096 Sep 9 00:51 logs
drwxrwxr-x 2 apache apache 4096 Sep 9 23:28 public_html
[root@localhost vsftpd]#
[/quote]
is xxx.com a system account or virtual account under vsftpd?[/quote]
system account。
[root@localhost xxx.com]# grep xxx.com /etc/passwd
xxx.com:x:1000:48::/var/virtual/xxx.com:/bin/bash
[root@localhost xxx.com]# grep apache /etc/passwd
apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
[root@localhost vsftpd]# ftp localhost
Trying ::1...
ftp: connect to address ::1Connection refused
Trying 127.0.0.1...
Connected to localhost (127.0.0.1).
220 (vsFTPd 3.0.2)
Name (localhost:root): xxx.com
331 Please specify the password.
Password:
500 OOPS: cannot change directory:/var/virtual/xxx.com
Login failed.
ftp> exit
[root@localhost vsftpd]# ls -l /var/virtual/xxx.com
total 12
drwxrwxr-x 2 apache apache 4096 Sep 9 00:50 backup
drwxrwxr-x 2 apache apache 4096 Sep 9 00:51 logs
drwxrwxr-x 2 apache apache 4096 Sep 9 23:28 public_html
[root@localhost vsftpd]#
[/quote]
is xxx.com a system account or virtual account under vsftpd?
[root@localhost vsftpd]# ftp localhost
Trying ::1...
ftp: connect to address ::1Connection refused
Trying 127.0.0.1...
Connected to localhost (127.0.0.1).
220 (vsFTPd 3.0.2)
Name (localhost:root): xxx.com
331 Please specify the password.
Password:
500 OOPS: cannot change directory:/var/virtual/xxx.com
Login failed.
ftp> exit
[root@localhost vsftpd]# ls -l /var/virtual/xxx.com
total 12
drwxrwxr-x 2 apache apache 4096 Sep 9 00:50 backup
drwxrwxr-x 2 apache apache 4096 Sep 9 00:51 logs
drwxrwxr-x 2 apache apache 4096 Sep 9 23:28 public_html
[root@localhost vsftpd]#