免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2468 | 回复: 14
打印 上一主题 下一主题

[FTP] 【求助】vsftpd+pam_mysql+mysql验证问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-08-01 11:38 |只看该作者 |倒序浏览
我参考的配置方案是

VSFTPD是一种在UNIX/Linux中非常安全且快速的FTP服务器,目前已经被许多大型站点所采用。VSFTPD支持将用户名和口令保存在数据库文件或数据库服务器中。VSFTPD称这种形式的用户为虚拟用户。相对于FTP的本地(系统)用户来说,虚拟用户只是FTP服务器的专有用户,虚拟用户只能访问FTP服务器所提供的资源,这大大增强系统本身的安全性。相对于匿名用户而言,虚拟用户需要用户名和密码才能获取FTP服务器中的文件,增加了对用户和下载的可管理性。对于需要提供下载服务,但又不希望所有人都可以匿名下载;既需要对下载用户进行管理,又考虑到主机安全和管理方便的FTP站点来说,虚拟用户是一种极好的解决方案。本文介绍在RedHat Linux 9上如何将VSFTPD的虚拟用户名和密码保存在MySQL数据库服务器中。

  一、VSFTPD的安装

  目前,VSFTPD的最新版本是1.2.0版。官方下载地址为ftp://vsftpd.beasts.org/users/cevan...-1.2.0.tar.gz。
在安装前,需要先做以下准备工作:

  VSFTPD默认配置中需要“nobody”用户。在系统中添加此用户,如果用户已经存在,useradd命令有相应提示。
  [root@hpe45 root]# useradd nobody
  useradd: user nobody exists

  VSFTPD默认配置中需要“/usr/share/empty”目录。在系统中此目录,如果目录已经存在,mkdir命令有相应提示。
  [root@hpe45 root]# mkdir /usr/share/empty/
  mkdir: cannot create directory '/usr/share/empty': File exists

  VSFTPD提供匿名FTP服务时,需要“ftp”用户和一个有效的匿名目录。
  [root@hpe45 root]# mkdir /var/ftp/
  [root@hpe45 root]# useradd -d /var/ftp ftp
  接下来的操作对于ftp用户是否已经存在都是有用的。
  [root@hpe45 root]# chown root.root /var/ftp
  [root@hpe45 root]# chmod og-w /var/ftp

  以上准备工作完成后,我们就可以开始编译源代码了。假定我们下载的vsftpd-1.2.0.tar.gz在/root目录,执行以下命令:
  [root@hpe45 root]# tar zxvf vsftpd-1.2.0.tar.gz
  [root@hpe45 root]# cd vsftpd-1.2.0
  [root@hpe45 vsftpd-1.2.0]# make
  [root@hpe45 vsftpd-1.2.0]# make install

 //// 上面的“make install”命令将编译好的二进制文件、手册等复制到相应目录。在RHL9上,可能需要手动执行以下复制:
 //// [root@hpe45 vsftpd-1.2.0]# cp vsftpd /usr/local/sbin/vsftpd
 //// [root@hpe45 vsftpd-1.2.0]# cp vsftpd.conf.5 /usr/local/share/man/man5
 //// [root@hpe45 vsftpd-1.2.0]# cp vsftpd.8 /usr/local/share/man/man8

  接下来,我们复制一个简单的配置文件作为基础供后面修改。
  [root@hpe45 vsftpd-1.2.1]# cp vsftpd.conf /etc
  
  复制PAM验证文件,以允许本地用户登录VSFTPD。
  [root@hpe45 vsftpd-1.2.1]# cp RedHat/vsftpd.pam /etc/pam.d/ftp

  二、创建guest用户

  VSFTPD采用PAM方式验证虚拟用户。由于虚拟用户的用户名/口令被单独保存,因此在验证时,VSFTPD需要用一个系统用户的身份来读
取数据库文件或数据库服务器以完成验证,这就是VSFTPD的guest用户。这正如同匿名用户也需要有一个系统用户ftp一样。
当然,我们也可以把guest用户看成是虚拟用户在系统中的代表。下面在系统中添加vsftpdguest用户,作为VSFTPD的guest。
  [root@hpe45 vsftpd-1.2.1]# useradd vsftpdguest

  当虚拟用户登录后,所在的位置为vsftpdguest的自家目录/home/vsftpdguest。如果要让虚拟用户登录到/var/ftp等其他目录,
修改vsftpdguest的自家目录即可。

  三、设置VSFTPD配置文件

  在/etc/vsftpd.conf文件中,加入以下选项:
  guest_enable=YES
  guest_username=vsftpdguest

  然后执行以下命令,让VSFTPD在后台运行:
  [root@hpe45 vsftpd-1.2.1]# vsftpd &

  四、将虚拟用户保存在MySQL数据库服务器中

  我们建立数据库vsftpdvu,表users,字段name和passwd用于保存虚拟用户的用户名和口令,同时增加两个虚拟用户xiaotong和xiaowang。

  [root@hpe45 vsftpd-1.2.1]# mysql -p
  mysql>;create database vsftpdvu;
  mysql>;use vsftpdvu;
  mysql>;create table users(name char(16) binary,passwd char(16) binary);
  mysql>;insert into users (name,passwd) values ('xiaotong',password('qqmywife'));
  mysql>;insert into users (name,passwd) values ('xiaowang',password('ttmywife'));
  mysql>;quit

  然后,授权vsftpdguest可以读vsftpdvu数据库的users表。执行以下命令:
  [root@hpe45 vsftpd-1.2.0]# mysql -u root mysql -p
  mysql>;grant select on vsftpdvu.users to vsftpdguest@localhost identified by 'i52serial0';
  mysql>;quit

  如果要验证刚才的操作是否成功可以执行下面命令:
  [root@hpe45 vsftpd]#mysql -u vsftpdguest -pi52serial0 vsftpdvu
  mysql>;select * from users;
  如果成功,将会列出xiaotong、xiaowang和加密后的密码

  五、设置MySQL的PAM验证

  这里我们要用到一个利用mysql进行pam验证的开源项目(http://sourceforge.net/projects/pam-mysql/)。
首先从网站下载它的程序包pam_myql-0.5.tar.gz,复制到/root目录中。在编译安装之前,
要确保mysql-devel的RPM包已经安装在你的机器上,如果没有请从RHL安装光盘中安装该包。然后,执行以下命令:
  [root@hpe45 root]#tar xvzf pam_mysql-0.5.tar.gz
  [root@hpe45 root]#cd pam_mysql
  [root@hpe45 pam_mysql]#make
  [root@hpe45 pam_mysql]#make install
  make install这一步可能会出现错误,那只好手动将该目录下生成的pam_mysql.so复制到/lib/security目录下。
  
接下来,我们要设置vsftpd的PAM验证文件。在/etc/pam.d/ftp文件中加入以下两行内容就行:

  auth required /lib/securitypam_mysql.so user=vsftpdguest passwd=i52serial0 host=localhost db=vsftpdvu table=users usercolumn=name passwdcolumn=passwd crypt=2
account required /lib/securitypam_mysql.so user=vsftpdguest passwd=i52serial0 host=localhost db=vsftpdvu table=users usercolumn=name passwdcolumn=passwd crypt=2
  
上面涉及到的参数,只要对应前面数据库的设置就可以明白它们的含义。这里需要说明的是crypt参数。
crypt表示口令字段中口令的加密方式:crypt=0,口令以明文方式(不加密)保存在数据库中;crypt=1,口令使用UNIX系统的DES加密方式加密后保存在数据库中;crypt=2,口令经过MySQL的加密后保存。

  六、进一步的虚拟用户设置

  经过以上的步骤,虚拟用户就可以正常使用了。这里介绍进一步的虚拟用户设置。首先,介绍虚拟用户的权限设置。

  VSFTPD-1.2.0新添了virtual_use_local_privs参数,当该参数激活(YES)时,虚拟用户使用与本地用户相同的权限。
当此参数关闭(NO)时,虚拟用户使用与匿名用户相同的权限,这也就是VSFTPD-1.2.0之前版本对虚拟用户权限的处理方法。
这两者种做法相比,后者更加严格一些,特别是在有写访问的情形下。默认情况下此参数是关闭的(NO)。
  当virtual_use_local_privs=YES时,只需设置write_enable=YES,虚拟用户就可以就拥有写权限。
而virtual_use_local_privs=NO时,对虚拟用户权限的设置就更多一些更严格一些。
  控制虚拟用户浏览目录:如果让用户不能浏览目录,但仍可以对文件操作,
那么需要执行以下二个步骤:
一,配置文件中,anon_world_readable_only=YES。

二,虚拟用户目录的权限改为只能由vsftpdguest操作:
  [root@hpe45 root]# chown vsftpdguest.vsftpdguest /home/vsftpdguest
  [root@hpe45 root]# chmod 700 /home/vsftpdguest
  允许虚拟用户上传文件:
  write_enable=YES
  anon_upload_enable=YES
  允许虚拟用户修改文件名和删除文件:
  anon_other_write_enable=YES
  由于以上选项的设置同样会对匿名用户生效。如果不想匿名用户趁机拥有同样的权限,最好是禁止匿名用户登录。

  其次,由于虚拟用户在系统中是vsftpdguest身份,所以可以访问到系统的其他目录。为了更加安全,
我们可以将虚拟用户限制在自家目录下。

有两种做法:
一,在配置文件中增加以下选项
  chroot_local_user=NO
  chroot_list_enable=YES
  chroot_list_file=/etc/vsftpd.chroot_list
  然后,在/etc/vsftpd.chroot_list文件中加入虚拟用户名xiaotong和xiaowang。
  
第二种做法,在配置文件中修改chroot_local_user=YES。
  经过修改后,虚拟用户登录后其根目录就限制在/home/vsftpdguest下,无法访问其他目录。

  七、虚拟用户的个人目录

  大家可以发现,无论是哪个虚拟用户,登录后所在的目录都是/home/vsftpdguest,
即都是guest_username用户的自家目录。
下面,介绍如何为每个虚拟用户建立自家目录。
首先,在主配置文件中加入以下选项:

  user_config_dir=/etc/vsftpd
  然后,生成/etc/vsftpd目录,并在该目录下建立与特定虚拟用户同名的文件:
  [root@hpe45 root]# mkdir /etc/vsftpd
  [root@hpe45 root]# cd /etc/vsftpd
  [root@hpe45 vsftpd_user_conf]# touch xiaowang
  以上的操作为虚拟用户xiaowang建立了个人配置文件/etc/vsftpd/xiaowang。接下来,
在xiaowang的个人配置文件中将xiaowang的自家目录修改为/home/xiaowang,
配置选项为:
  local_root=/home/xiaowang
  然后,新建xiaowang目录,并将权限设为vsftpdguest:
  [root@hpe45 vsftpd_user_conf]# mkdir /home/xiaowang
  [root@hpe45 vsftpd_user_conf]# chown vsftpdguest.vsftpdguest ./xiaowang
  [root@hpe45 vsftpd_user_conf]# chmod 600 /home/xiaowang
  经过以上设置,xiaowang登录VSFTPD后,用“pwd”指令就可以发现被自己被定位到自己的“/home/xiaowang”目录。
  从文件系统层次来看,由于“/home/xiaowang”目录的权限是属于vsftpdguest的,
所以其他的虚拟用户同样也可以访问xiaowang的自家目录。解决这个问题也很简单,
我们只需要让VSFTPD负责将虚拟用户限制在其自家目录,就可以避免虚拟用户的互相访问。
具体做法参照前面第六步中所述,这里不再赘述。经过以上设置后,虚拟用户就可以拥有属于自己的目录了。

论坛徽章:
0
2 [报告]
发表于 2005-08-01 11:40 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

使用vsftpd-2.0.3+MySQL-devel-4.1.12+pam_mysql-0.5.tar.gz+mysql4.1.12
在登陆的时候出现
Jan 26 02:13:01 dns vsftpd: database changed.
Jan 26 02:13:01 dns vsftpd: table changed.
Jan 26 02:13:01 dns vsftpd: usercolumn changed.
Jan 26 02:13:01 dns vsftpd: passwdcolumn changed.
Jan 26 02:13:01 dns vsftpd: crypt changed.
Jan 26 02:13:01 dns vsftpd: sqllog changed.
Jan 26 02:13:01 dns vsftpd: db_connect called.
Jan 26 02:13:01 dns vsftpd: pam_mysql: MySQL err Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
Jan 26 02:13:01 dns vsftpd: returning 7 .
Jan 26 02:13:01 dns vsftpd: returning 7 after db_connect.
是什么问题?请斑竹跟各位朋友帮帮忙.

同是参考这个资料,我在RH9上配置一点问题没有,但是在FC4上就不行,运用的版本已经在上面叙述了

论坛徽章:
0
3 [报告]
发表于 2005-08-01 13:44 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

数据库启动了吗?有没有/var/lib/mysql/mysql.sock这个文件

错误信息说明连接数据库失败

看看/etc/my.cnf文件,
[mysqld]段中socket的设置是不是
socket=/var/lib/mysql/mysql.sock

如果是,加入新的[client]段(如果没有的话)
[client]
socket=/var/lib/mysql/mysql.sock

重启mysql,再试试

论坛徽章:
0
4 [报告]
发表于 2005-08-01 16:25 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

/var/lib/mysql/mysql.sock这个文件是在[mysqld]中,还有别的可能会造成这个错误吗?

论坛徽章:
0
5 [报告]
发表于 2005-08-03 10:08 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

这个论坛里的高手水平不会这么差吧?

论坛徽章:
0
6 [报告]
发表于 2005-08-03 10:09 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

还是缺了乐于助人的那种风格呀?

论坛徽章:
0
7 [报告]
发表于 2005-08-03 21:38 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

[quote]原帖由 "sjx12880805"]

论坛徽章:
0
8 [报告]
发表于 2005-08-05 13:22 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

[root@localhost vsftpd]# more /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1
log
     
[mysql.server]
user=mysql
basedir=/var/lib

[mysqld_safe]
err-log=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

这是我的my.cnf的文件内容

论坛徽章:
0
9 [报告]
发表于 2005-08-05 13:27 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

在你的my.cnf文件中加入
  1. [client]
  2. socket=/var/lib/mysql/mysql.sock
复制代码


重启mysql后,试试

论坛徽章:
0
10 [报告]
发表于 2005-08-05 17:07 |只看该作者

【求助】vsftpd+pam_mysql+mysql验证问题

还是一样的问题呀,头疼,还有别的可能性吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP