最近,笔者在校园网应用平台建设中采用了Linux操作系统,为校园网用户提供DNS、Apache、POP3、SMTP、FTP等服务。由于我校学生用户数在3000人以上,笔者在建设整个应用平台的过程中特别重视保证用户管理效率。我的基本思路和做法是:利用shell为每个学生建立一个系统账号——即提供一个E-mail地址(含FTP空间账号),然后学生可以凭借其E-mail再注册论坛用户。基于这样的管理思路,笔者编写了一个批量建立用户的shell,实践证明,利用shell可以有效地管理基于Unix内核的系统用户。
以下是整个shell的[url=http://www.pccode.net].net" class="wordstyle"源码及注释,此代码在Redhat 7.2及Turbo Linux 7.0上调试通过,在其他版本的Linux中使用可能需要做适当的修改。其中“@”部分是代码注释,“()”部分是笔者对于编程思路的解释。
@!/bin/sh(定义使用sh shell)
groupadd users(建立用户组)
@grade code(定义第一个参数为年级代码,赋予变量“grade”)
grade=$1
@class code(定义第二个参数为班级代码,赋予变量“num_class”)
num_class=`expr $2 + 0`
if (test $num_class -le 9)(以下代码是为了保证班级码的位数为两位)
then
num_class="0"$num_class
fi
@max user id(定义第三个参数为该班学生的最大ID号,赋予变量“max_stid”)
max_stid=`expr $3 + 0`
@init user id(该班学生用户ID号从1开始)
num_stid =1
@mkdir user home(在“/home”目录为所有学生建立名为"student"的公共目录)
if [ ! -x /home/student ]
then
mkdir /home/student
fi
if [ ! -x /home/student/$1$num_class ] (在学生公共目录下为每个班级建立以该班代码命名的目录)
then
mkdir /home/student/$1$num_class
fi
while (test $num_stid -le $max_stid)(从用户ID号1开始循环,直到最大ID号)
do
if (test $num_stid -le 9) (以下保证学生代码的位数为两位)
then
num_stid="0"$num_stid
fi
user_name=$grade$num_class$num_stid(把年级、班级、学生ID号三部分代码组合成用户名,并赋予变量user_name)
@save user passwd to file user_pwlist(按“name:passwd”的格式逐行追加写入“user_pwlist”文件,以备初始化用户密码)
echo $user_name":"$user_name >> user_pwlist
@add user(建立该用户,同时赋予“users”组,创建该用户目录)
adduser -g users -d /home/student/$1$num_class/$user_name $user_name
@set quota(为该用户设置配额,限制最大容量为20MB,没有文件数限制)
setquota -u $user_name 10240 20480 0 0 /home
@set directory mode(设置该用户目录的权限为755)
chmod 755 /home/student/$1$num_class/$user_name
@current user id add one(用户ID号加1,准备下一次循环,建立下一个用户)
num_stid=`expr $num_stid + 1`
done
chpasswd < user_pwlist(以下两行为刚才建立的所有用户设置密码)
pwconv
rm user_pwlist -f(删除“user_pwlist”文件)
关于使用:
1. 用vi编辑器逐行写入以上代码部分,并以文件的形式保存,如以“addclass”命名保存,再执行以下步骤。
2. #chmod +x addclass(设置addclass文件为可执行权限)
3. #./addclass ga 1 50(建立ga0101-ga0150用户)
注意:#为提示符。
以上代码只是笔者在使用shell进行系统用户管理时的一点体会。由于shell可以和Linux的系统命令结合使用,所以它在管理中的功能就显得非常强大。就以上代码而言,我们只要稍加改动,就可以建立删除批量用户的shell、批量配置用户配额的shell以及批量初始用户密码的shell。如果再加上一层班级循环语句,就可以生成一次建立一个年级用户的shell。