当前位置:首页 > linux教程 > 列表

linux中vsftpd虚拟用户配置脚本示例

发布:smiling 来源: PHP粉丝网  添加日期:2014-10-11 08:31:15 浏览: 评论:0 

下面来看一段linux中vsftpd虚拟用户配置脚本示例,希望这个例子能帮助到各位快速成功配置好自己的vsftpd服务器.

每次新安装服务器后,都要进行一系列的配置,安装软件,修改配置等,为了今后更好的部署vsftpd,特此写了个脚本用于部署.

登录FTP有三种方式,匿名登录、本地用户登录和虚拟用户登录.

匿名登录:在登录FTP时使用默认的用户名,一般是ftp或anonymous.

本地用户登录:使用系统用户登录,在/etc/passwd中.

虚拟用户登录:这是FTP专有用户,有两种方式实现虚拟用户,本地数据文件和数据库服务器。

FTP虚拟用户是FTP服务器的专有用户,使用虚拟用户登录FTP,只能访问FTP服务器提供的资源,大大增强了系统的安全,代码如下:

  1. #!/bin/bash 
  2. ######################################### 
  3. ######### descprition ################## 
  4. # 1.安装vsftpd 
  5. # 2.配置vsftpd虚拟化 
  6. ######################################## 
  7. #init variables 
  8. PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin 
  9. export PATH 
  10.  
  11. ff_outputdir=/tmp/liufofu 
  12. curdate=$(date +%Y%m%d) 
  13. curtime=$(date +%H%M%S) 
  14. ff_logfile=${ff_outputdir}/$$.log 
  15. if [ ! -e ${ff_outputdir} ];then 
  16.     mkdir -p ${ff_outputdir} 
  17. fi 
  18.  
  19. #处理过程中产生的日志由日志函数来进行处理记录 
  20. function log() 
  21.     echo "`date +"%Y:%m:%d %H-%M-%S"` $1 "  >> ${ff_logfile} 
  22.  
  23. yum -y install vsftpd 
  24. yum -y install db4-utils 
  25. #生成vsftpd配置文件 
  26. cat > /etc/vsftpd/vsftpd.conf<<EOF 
  27. anonymous_enable=NO 
  28. local_enable=YES 
  29. write_enable=YES 
  30. local_umask=022 
  31. log_ftp_protocol=YES 
  32. dirmessage_enable=YES 
  33. xferlog_enable=YES 
  34. connect_from_port_20=YES 
  35. xferlog_file=/var/log/xferlog 
  36. xferlog_std_format=YES 
  37. chroot_list_enable=YES 
  38. chroot_list_file=/etc/vsftpd/chroot_list 
  39. listen=YES 
  40. pam_service_name=vsftpd 
  41. guest_enable=YES 
  42. #guest_username=www 
  43. dual_log_enable=YES 
  44. vsftpd_log_file=/var/log/vsftpd.log 
  45. user_config_dir=/etc/vsftpd/vuser_conf 
  46. userlist_enable=YES 
  47. tcp_wrappers=YES 
  48. #listen_address=172.20.1.175 
  49. #listen_port=21000 
  50. virtual_use_local_privs=YES 
  51. EOF 
  52. log "生成vsftpd配置文件" 
  53. #创建虚拟用户目录 
  54. if [ ! -e /etc/vsftpd/vuser_conf ];then 
  55.     mkdir -p /etc/vsftpd/vuser_conf 
  56. fi 
  57. log "创建虚拟用户目录" 
  58. #创建测试用户的根目录 
  59. if [ ! -e /var/www/html/liufofu ];then 
  60.      mkdir -p /var/www/html/liufofu 
  61. fi 
  62. log "创建虚拟用户目录" 
  63. #创建测试用户 
  64. cat >/etc/vsftpd/vuser_conf/liufofu<<EOF 
  65. local_root=/var/www/html/liufofu 
  66. write_enable=YES 
  67. anon_world_readable_only=NO 
  68. anon_upload_enable=YES 
  69. anon_mkdir_write_enable=YES 
  70. anon_other_write_enable=YES 
  71. EOF 
  72.  
  73. #限制虚拟用户的虚根 
  74. ls -l /etc/vsftpd/vuser_conf| grep -v total | awk '{print $NF}' > /etc/vsftpd/chroot_list  
  75.  
  76. #设置虚拟用户名和密码 
  77. cat >/etc/vsftpd/ftplogins.txt<<EOF 
  78. liufofu 
  79. liufofu 
  80. EOF 
  81.  
  82. if [ -f /etc/vsftpd/ftplogins.txt ];then 
  83.     chmod 600 /etc/vsftpd/ftplogins.txt 
  84. fi 
  85.  
  86. #设置vsftpd的虚拟验证方法 
  87. if [ $(uname -a | grep x86_64 | wc -l) -eq 1 ];then 
  88. cat >/etc/pam.d/vsftpd<<EOF 
  89. #%PAM-1.0 
  90. auth required /lib64/security/pam_userdb.so db=/etc/vsftpd/vsftpd  
  91. account required /lib64/security/pam_userdb.so db=/etc/vsftpd/vsftpd 
  92. EOF 
  93. else  
  94. cat >/etc/pam.d/vsftpd<<EOF 
  95. #%PAM-1.0 
  96. auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd  
  97. account required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd 
  98. EOF 
  99. fi 
  100. log "设置vsftpd的虚拟验证方法" 
  101. #建立vsftpd的宿主用户 
  102. if [ $(grep vsftpd /etc/passwd) -lt 1 ];then 
  103.     useradd vsftpd -s /sbin/nologin 
  104.     usermod -a -G www vsftpd 
  105. fi  --phpfensi.com 
  106. log "建立vsftpd的宿主用户" 
  107.  
  108. db_load -T -t hash -f /etc/vsftpd/ftplogins.txt /etc/vsftpd/vsftpd.db 
  109. log "生成虚拟用户数据库" 
  110. #启动vsftpd 
  111. service vsftpd start

Tags: vsftpd虚拟用户 vsftpd用户配置

分享到: