信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
根据文件内容创建账号
#!/bin/bash
for Uname in `cat /root/useradd.txt |gawk '{print $1}'`
do
id $Uname &> /dev/null
if [ $? -eq 0 ]
then
echo -e "这个账号已存在!来源:微信公众号【网络技术干货圈】"
continue
fi
for Upasswd in `cat /root/useradd.txt |gawk '{print $2}'`
do
useradd $Uname &> /dev/null
echo "$Upasswd" |passwd --stdin $Uname &> /dev/null
if [ $? -eq 0 ]
then
echo -e "账号创建成功!"
else
echo -e "创建失败!"
fi
done
done
脚本实现过程
- 读取用户列表:
- Bash
1for Uname in `cat /root/useradd.txt |gawk '{print $1}'`
- 使用
cat
命令读取/root/useradd.txt
文件内容,该文件应包含一行一个用户信息,每行格式为username password
。接着通过gawk
提取每一行的第一列(即用户名),并将这些用户名依次赋值给变量Uname
,通过for
循环遍历所有用户名。 - 检查账号是否存在:
- Bash
1id $Uname &> /dev/null 2if [ $? -eq 0 ] 3then 4 echo -e "这个账号已存在!来源:微信公众号【网络技术干货圈】" 5 continue 6fi
- 对于每个用户名
Uname
,使用id
命令检查该账号是否已经存在于系统中。id
命令的输出被重定向到/dev/null
,即忽略其标准输出,仅关注其退出状态(通过$?
获取)。如果退出状态为0(表示命令执行成功,即账号存在),则输出提示信息并跳过该用户名,继续处理下一个用户名。 - 读取密码并创建账号:
- Bash
1for Upasswd in `cat /root/useradd.txt |gawk '{print $2}'` 2do 3 useradd $Uname &> /dev/null 4 echo "$Upasswd" |passwd --stdin $Uname &> /dev/null 5 if [ $? -eq 0 ] 6 then 7 echo -e "账号创建成功!" 8 else 9 echo -e "创建失败!" 10 fi 11done
- 同样地,通过
cat
和gawk
从/root/useradd.txt
文件中提取每行的第二列(即密码),将这些密码依次赋值给变量Upasswd
。这里使用了第二个for
循环,理论上应该只有一个密码与当前用户名对应,但由于脚本设计问题,实际上会遍历所有行的密码。对于当前的Uname
和Upasswd
:
- 使用
useradd
命令尝试创建用户账号,输出同样被重定向到/dev/null
。 - 通过管道 (
|
) 将密码传递给passwd
命令的--stdin
参数,以非交互方式设置新用户的密码。同样忽略命令输出。 - 检查
passwd
命令的退出状态。如果为0(表示密码设置成功),输出“账号创建成功!”;否则输出“创建失败!”。
问题与建议
注意到脚本中存在一个逻辑错误:第二个 for
循环用于处理密码,但它不应该与第一个处理用户名的循环嵌套。正确的做法是在第一个循环内部直接获取与当前用户名对应的密码,而不是遍历所有密码。修正后的脚本应如下所示:
Bash
1#!/bin/bash 2 3while read -r Uname Upasswd; do 4 id $Uname &> /dev/null 5 if [ $? -eq 0 ]; then 6 echo -e "这个账号已存在!来源:微信公众号【网络技术干货圈】" 7 continue 8 fi 9 10 useradd $Uname &> /dev/null 11 echo "$Upasswd" |passwd --stdin $Uname &> /dev/null 12 if [ $? -eq 0 ]; then 13 echo -e "账号创建成功!" 14 else 15 echo -e "创建失败!" 16 fi 17done < /root/useradd.txt
如何使用
- 准备用户列表文件:创建一个名为
useradd.txt
的文本文件,存放待创建的用户及其密码。每行格式为username password
,例如: - Code
1user1 pass1 2user2 pass2 3user3 pass3
- 保存脚本:将上述修正后的脚本内容保存到一个
.sh
文件中,例如create_accounts.sh
。 - 赋予执行权限:在终端中,使用
chmod +x create_accounts.sh
命令给脚本添加执行权限。 - 运行脚本:执行命令
./create_accounts.sh
来运行脚本。脚本将根据useradd.txt
文件中的用户信息创建系统账号,并输出相应的创建成功或失败消息。请注意,只有具有相应权限(通常为管理员权限)的用户才能运行此脚本。
总结而言,此脚本通过读取指定文件中的用户列表,检查账号是否存在,然后创建新账号并设置密码。用户需按照上述步骤准备用户列表文件、保存并授权脚本,最后运行脚本以批量创建系统用户账号。修正后的脚本消除了原脚本中处理密码的逻辑错误,确保正确关联用户名与密码。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用