最近实在太忙,没时间研究和折腾,所以也没有什么可以分享到博客的。果然,个人博客坚持原创太不不容易了。三叶运维上线 2 年多,从 1 天多更,到一天 1 更、一周一更,直到现在 2 星期可能有一更的节奏。。。
好了,废话不说了。翻了翻在工作上的印象笔记,发现还是有一些存货可以分享的。
挺久之前,组内新申请了一批开发测试机,需要部署环境。除了一些常见的软件要安装之外,还有一个我之前很少用到的 Samba。
Samba 的专业解释我就不贴了,百度百科啥的都有。说白了就是 Samba 安装到 Linux 服务器上之后,就可以将服务器上的目录映射到 Windows、MAC 等个人电脑上,类似于 Windows 的文件共享,使用相当方便,因此,Samba 成了组内开发同事的刚需软件。。。(其实对于使用云服务器的站长,Samba 可比 FTP 好用多了,直接本地开发编辑。。。这个后面有空再介绍吧)
这批开发测试机大部分都是基于 Centos 的 Tlinux 系统,所以使用 yum install -y samba 就能安装了。安装后发现需要在每台服务器上都配置组内 30 多个成员的 samba 账号,手工单个的加太苦逼了,于是写了一个 Samba 批量添加用户的脚本了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
#!/bin/sh
# FileName: addsmbuser.sh
# Useage : sh addsmbuser.sh userlistfile / username
#批量添加用户
add_list(){
#从userlist中读取用户帐号并循环添加
cat $1 | while read username
do
#利用echo -e 的回车功能解决smbpasswd需要交互的问题,比expect简单多了
echo -e "$username\n$username" | smbpasswd -a $username -s
#如果添加成功,则新建家目录,避免首次直接登陆samba失败,适合公司铁将军鉴权方式,其他环境可以省略
if [[ 0 = $? ]]
then
mkdir -p /home/$username
chown -R $username:users /home/$username
fi
done
}
#单个添加用户
add_one() {
echo -e "$1\n$1" | smbpasswd -a $1 -s && (
mkdir -p /home/$1
chown -R $1:users /home/$1
)
}
# 先确认系统安装了samba,如果没有就安装
which smbpasswd || yum install -y samba
#如果参数1是文件那么执行批量添加,否则就单个添加
if [[ ! -z $1 ]];then
test -f $1 && (
add_list $1
) || (
add_one $1
)
else
echo "Usage: $0 username / userlistfile"
exit 1
fi
|
使用也非常简单,将如上代码保存为 addsmbuser.sh,然后将需要添加的用户名一行一个保存到一个文本文件,比如 userlist,然后执行 sh addsmbuser.sh userlist 就能批量添加这些用户了,初始密码和用户名一致。
当然,直接执行 sh addsmbuser.sh + 用户名 还能添加单个用户。
由于 smbpasswd 正常使用是需要交互进行的,也就是输入用户名,再输入密码,这种批量交互的活完全可以使用 expect 脚本来完成。但是本文比较巧妙的利用了 echo -e 可以输出回车符(\n)的特性,非常轻巧的完成了任务。
暂时就写这么多,后面有时间再整理下坑爹的 SuSE 下如何编译安装 Samba,以及 Samba 的简单使用。