扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
在本页阅读全文(共2页)
ZDNetChina服务器站 12月26日操作系统技巧 FreeBSD是个多用户环境;一个系统管理员主要的工作之一就是建立用户账号并向用户提供一个安全的工作环境。要有效地完成此工作需要在建立任何用户之前作一些预期规划。
即使如果你是个人FreeBSD系统的唯一用户,仍需要至少建立一个用户账号来完成常规的工作。记住,只在工作需要超级用户权限的时候才用超级用户账号。
当你建立一个用户时,在后台会发生很多事情:更新一些数据库,建立邮件目录以及用户的宿主目录。当建立用户时,你必须提供一定数量的信息,包括用户名和口令。在这篇文章中,我打算集中于用户策略以及建立用户账号上。
你建立的每个用户账号都必须有一个在FreeBSD系统上唯一的名字。在较小的环境这很容易做到,但如果你必须建立一打,成百甚至上千个用户就稍微要困难一点了。为了有助于确保唯一性,你应该有一套用户命名策略。如果没有适当的策略,你需要建立一套命名方案,紧记一些用于用户名的限制。首先,用户名应被限制在16个字符之内,而一些协议,如NIS,需要用户名少于8个字符。其次,用户名不能以连字符“-”起首。再次,你应该避免使用大写字母和句点,因为这些会搞乱一些邮件程序。
在较小环境中的策略样例可以用用户的名和姓首字母来建立用户名。你可能要对此稍加修改以避免冲突。例如,如果你需要为Mike Smith和Mike Spencer建立账号,可以建立“mikes”和“michaels”,或“mikesm”和“mikesp”。
其它的策略可以用用户的姓和名首字母并作适当的修改来建立用户名以避免冲突。如果你需要为Mark Smith和Michelle Smith建立账号,可以建立“smithma”和“smithmi”。
在稍大的环境中,你可能要用较多字符分别表示名和姓。例如,如果命名策略是名部分的首四个字符后跟姓部分的首四个字符,那么Mark Smith应该是“marksmit”,而Michelle Smith应该是“michsmit”。你仍需要有一份后备计划用于那些姓和名都少于指定的字符数量。例如,如果我需要用上述策略为My Lee建立一个账号,我应该建立“my_lee”。
除非你处于一个相当小的环境之中,避免非说明性的昵称,如我用在自己系统上的“biko”和“genisis”是比较明智的。
总而言之,一个好的用户命名策略表明了对用户名的限制,而且是避免命令冲突的一个应急方法。
一旦你决定了一套命令方案,你就可以用adduser工具建立用户账号了。这个工具有一个配置文件/etc/adduser .conf,它还会读取一个讯息文件/etc/adduser.message。这些文件在你首次使用adduser工具前还没有被创建。下面跟我一起建立一个用户;我会使用v或verbose开关,所以我们将看到所有可能的提示信息。你会看到adduser首先创建它的配置文件,然后在建立用户时把它作为一个模板。
adduser -v
You are not root!
哦。看起来这是个需要root权限的管理工作。让我们再试一次:
su
Password:
adduser -v
/etc/adduser.conf: No such file or directory
可以看到这是我首次在该系统上使用“adduser”工具;它还没有一个配置文件。
Use option "-silent"
if you don't want to see all warnings and questions.
Check /etc/shells
Check /etc/master.passwd
Check /etc/group
Enter your default shell: bash csh date no sh tcsh [sh]: tcsh
adduser读取一个含有系统上安装的所有命令解释器的路径的文件/etc/shells;然后显示用户可以使用的解释器。注意,向用户提供的缺省解释器是Bourne shell (sh),但我把它改为tcsh。
Your default shell is: tcsh -> /bin/tcsh
Enter your default HOME partition: [/home]:
Copy dotfiles from: /usr/share/skel no [/usr/share/skel]:
当我们建完用户并在接受了从/usr/share/skel目录拷贝点文件看到的信息之后,可以去看一下那个目录里的内容。
Send message from file: /etc/adduser.message no
[/etc/adduser.message]:
Create "/etc/adduser.message"? (y/n) [y]:
Use passwords (y/n) [y]:
Write your configuration to /etc/adduser.conf? (y/n) [y]:
可以看到adduser在/etc目录下建立了adduser.message和adduser.conf文件。现在准备建立我们的用户:
Ok, let's go.
Don't worry about mistakes.
I will give you the chance later to correct any input.
Enter username [a-z0-9_-]: dlavigne
Enter full name []: Dru Lavigne
Enter shell bash csh date no sh tcsh [tcsh]:
Enter home directory (full path) [/home/dlavigne]:
Uid [1000]:
Enter login class: default []:
Login group dlavigne [dlavigne]:
Login group is "dlavigne".
Invite dlavigne into other groups: guest no
[no]:
Enter password []:
Enter password again []:
Name: dlavigne
Password: ****
Fullname: Dru Lavigne
Uid: 1000
Gid: 1000 (dlavigne)
Class:
Groups: dlavigne
HOME: /home/dlavigne
Shell: /bin/tcsh
OK? (y/n) [y]:
Added user "dlavigne"
Send message to "dlavigne" and: no root second_mail_address
[no]:
Dru Lavigne,
your account "dlavigne" was created.
Have fun!
See also chpass(1), finger(1), passwd(1)
Add anything to default message (y/n) [n]:
Send message (y/n) [y]:
Copy files from /usr/share/skel to /home/dlavigne
Add another user? (y/n) [y]: n
Goodbye!
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者