一.错误问题[root@RedHat-5 pam.d]# tail /var/log/secure
Sep 12 11:39:48 RedHat-5 vsftpd: PAM adding faulty module: /lib/security/pam_mysql.so
Sep 12 11:42:39 RedHat-5 vsftpd: PAM unable to dlopen(/lib/security/pam_mysql.so)
Sep 12 11:42:39 RedHat-5 vsftpd: PAM [error: /lib/security/pam_mysql.so: cannot open shared object file: No such file or directory]
Sep 12 11:42:39 RedHat-5 vsftpd: PAM adding faulty module: /lib/security/pam_mysql.so
Sep 12 11:42:59 RedHat-5 vsftpd: PAM unable to dlopen(/lib/security/pam_mysql.so)
Sep 12 11:42:59 RedHat-5 vsftpd: PAM [error: /lib/security/pam_mysql.so: cannot open shared object file: No such file or directory]
Sep 12 11:42:59 RedHat-5 vsftpd: PAM adding faulty module: /lib/security/pam_mysql.so
Sep 12 11:44:30 RedHat-5 vsftpd: PAM unable to dlopen(/lib/security/pam_mysql.so)
Sep 12 11:44:30 RedHat-5 vsftpd: PAM [error: /lib/security/pam_mysql.so: cannot open shared object file: No such file or directory]
Sep 12 11:44:30 RedHat-5 vsftpd: PAM adding faulty module: /lib/security/pam_mysql.so
二.解决方法
经过仔细查看前面的步骤,发现原来make install的时候默认安装在/usr/local/lib下。修改/etc/pam.d/vsftpd.mysql文件auth required /usr/lib/security/pam_mysql.so user=vsftpd passwd=www.luochen.com host=localhost db=vsftpd table=users usercolumn=name passwdcolumn=password crypt=0
account required /usr/lib/security/pam_mysql.so user=vsftpd passwd=www.luochen.com host=localhost db=vsftpd table=users usercolumn=name passwdcolumn=password crypt=0
在登录,成功!换用其他加密方式,也都可以。然后试验pam_mysql v0.7新加的config_file配置选项。这个选项用来指定一个配置文件,可以把所有pam_mysql的配置放在这个文件中。这样的话,/etc/pam.d/vsftpd.mysql的内容变成这样:auth required /usr/lib/security/pam_mysql.so config_file=/etc/security/pam_mysql.conf
account required /usr/lib/security/pam_mysql.so config_file=/etc/security/pam_mysql.conf
/etc/security/pam_mysql.conf的内容: users.host=localhost
users.database=vsftpd users.db_user=root users.db_passwd=redhat users.table=users users.user_column=name users.password_column=password users.password_crypt=3 verbose=1 log.enabled=1 log.table=logs log.message_column=msg log.pid_column=pid log.user_column=user log.host_column=host log.rhost_column=rhost log.time_column=logtime