linux 笔记为什么要使用虚拟用户:匿名帐户可以很好的保证FTP服务器的安全性,但是,对匿名用户的权限管理不够灵活.如果想对访问FTP的帐户给予更多的权限,就可以用本地帐户来实现. 但是,本地帐户默认情况下是可以登陆Linux系统的,这样对Linux系统来说是一个安全隐患.那么怎么能在灵活的赋予FTP用户权限的前提下,保证 FTP服务器乃至整个Linux系统的安全呢?使用虚拟用户就是一种解决办法.下面,我们就一起来学习,该怎样在Linux下配置FTP服务器的虚拟用户.开始配置前,让我们先大概了解下FTP虚拟用户的工作原理:虚拟用户,顾名思义,并不是一个合法的Linux系统帐户,但是他可以用来登陆该系统上运行的FTP服务器.当用户在连接上FTP服务器后,会被要求输入用户名和密码.FTP服务器在拿到这个用户名和密码后,会调用相应的PAM认证模块对,和系统中的FTP认证文件进行相比较.如果该用户名和密码与FTP认证文件中的某条记录相符,就通过认证,然后该帐户就被映射成一个Linux下的本地帐户,然后根据使用该本地帐户对FTP资源进行访问.否则则断开该连接请求.了解了FTP虚拟用户的工作原理后,我们就可以开始配置FTP虚拟用户了.
1.准备一个虚拟用户的口令库文件.该文件中保存的用户名和密码是用户连接FTP服务器时,需要输入的用户名和密码.文件可以自己创建,位置无关紧要,文件格式为:奇数行为用户名,偶数行为密码.例如:touch login.txt //创建一个名为login.txt的虚拟用户口令库文件 vi login.txt //编辑该口令库文件 mike //虚拟用户mike 123 //虚拟用户mike的密码 john //虚拟用户john 321 //虚拟用户john的密码保存退出.2.用刚才建立的虚拟用户口令库文件生成FTP服务器的认证文件.该认证文件是一个被加密后的密文.PAM在调用相应的认证模块后,会对从FTP服务器发来的用户名和密码进行加密,然后在跟该文件进行对比,发现相符条目后,登陆用户才会被允许登陆.db_load -T -t hash -f login.txt /etc/vsftpd/vsftpd_login.db //在运行该命令前,别忘记安装db4-utils软件包,该包包含有db_load命令等.关于该命令的使用不在本文讨论范围内.其中-f参数后跟的为刚才创建的虚拟用户口令库文件.最后的路径为生成的FTP认证文件的存放位置.为了进一步保证安全,可以将该FTP认证文件的权限设置为600.3.建立虚拟用户所需要的PAM配置文件.由于FTP服务器在接受到用户的用户名和口令后会调用PAM认证,所以我们还要创建虚拟用户的PAM配置文件.我们将该文件保存在/etc/pam.d目录下,文件名暂时取为:vsftpd.这里要注意一点就是,该文件名要与FTP服务主配置文件(/etc/vsftpd/vsftpd.conf)中的pam_service_name=vsftpd选项的选项值相同.创建好该文件后,将下面的内容加入到该文件中:auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_loginaccount required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login改好后,保存退出(注意,/etc/pam.d/vsftpd 这个文件只能有上面两行代码有效,其他内容请用#号注释掉).注意3个红色文件的文件名.该3个文件为1个文件,只不过在使用中写法不同.4.由于用户在通过PAM的认证后要被映射成一个本地用户,所以我们还要建立一个本地用户供虚拟用户使用.我们只需要对该本地用户赋予FTP主目录的适当访问权限就行.即使FTP服务器遭到攻击,这个本地用户也没有访问其他目录的权限,相对比较安全一些.useradd -d /home/ftpsite virtual //用户名为virtual,主目录为FTP的根chmod 700 /home/ftpsite //将其权限设置为700,可以根据实际情形进行修改**更正(ftp目录归属与被用于ftp的虚拟用户的情况下)**000(---------) 可切仅可登陆500(r-x------) 可见文件列表,可下载,不可上传与ftp上不同名的文件,不可删除、改名、新建文件夹700(rwx------) 可上传下载文件,可修改文件名,可删除文件,可建立文件夹,可移动文件(可做全部操作)(vsftpd 配置许可的情况下)5.在FTP的主配置文件中,启用FTP虚拟用户.增加如下选项即可:guest_enable=YESguest_username=virtual //将虚拟用户映射成本地的哪个用户.这里用的是virtual,刚才建 立的那个用户.pam_service_name=/etc/vsftpd/vsftpd //切记要修改该项的值6.配置到这里就完成了,别忘记重启FTP服务进行测试.7.为不同的虚拟用户分配权限默认情况下,虚拟用户拥有相同的权限,就是virtual的权限,我们可以根据实际需求对不同的虚拟用户分配权限.首先在FTP的主配置文件中加一个选项:user_config_dir=/etc/vsftpd_user_conf //文件名和路径都可以自己定义然后创建该目录.mkdir /etc/vsftpd_user_conf下面就可以在该目录下编辑不同虚拟用户的权限配置文件了,比如要对mike编辑其权限.touch mike //建立mike的权限文件.文件名要与虚拟用户名相同可以根据实际需求为该文件添加下面的选项和值:anon_world_readable_only=NO //表示用户可以浏览FTP目录和下载文件anon_upload_enable=YES //表示用户可以上传文件anon_mkdir_write_enable=YES //表示用户有创建和删除目录的权限anon_other_write_enable=YES //表示用户具有文件改名和删除文件的权限 另外:修改 /etc/selinux 文件夹下的 config 文件,SELINUX=enforcing 修改为 SELINUX=disabled到这里,虚拟用户就算完成配置完成了.不过,有一个问题,好象在配置完虚拟用户后,不关FTP主配置文件里怎样配置,匿名用户和本地用户都不能登陆FTP服务器了.该怎样解决这个问题呢?如果不能上传文件,如果其他配置都和上面一样,而且ftp主目录的权限设置为777都不能上传的话,则可能是防火墙的问题
1、建用户:
adduser phpq //新建phpq用户passwd phpq //给phpq用户设置密码
2、建工作组groupadd test //新建test工作组
3、新建用户同时增加工作组useradd -g test phpq //新建phpq用户并增加到test工作组
注::-g 所属组 -d 家目录 -s 所用的SHELL
4、给已有的用户增加工作组
usermod -G groupname username
或者:gpasswd -a user group
5、临时关闭:在/etc/shadow文件中属于该用户的行的第二个字段(密码)前面加上*就可以了。想恢复该用户,去掉*即可。
或者使用如下命令关闭用户账号:
passwd peter –l
重新释放:
passwd peter –u
6、永久性删除用户账号
userdel peter
groupdel peter
usermod –G peter peter (强制删除该用户的主目录和主目录下的所有文件和子目录)
7、从组中删除用户
编辑/etc/group 找到GROUP1那一行,删除 A 或者用命令 gpasswd -d A GROUP
8、显示用户信息
id usercat /etc/passwd
补充:查看用户和用户组的方法
用户列表文件:/etc/passwd用户组列表文件:/etc/group
查看系统中有哪些用户:cut -d : -f 1 /etc/passwd查看可以登录系统的用户:cat /etc/passwd | grep -v /sbin/nologin | cut -d : -f 1查看用户操作:w命令(需要root权限)查看某一用户:w 用户名查看登录用户:who查看用户登录历史记录:last