多进程脚本、系统初始化脚本、综合应用脚本

本文介绍了如何编写脚本来管理系统初始化,包括关闭防火墙和SELinux、设置SSH超时以及时间同步。此外,还涉及通过文档处理进行输入重定向、批量创建用户账户并配置密码。进一步地,文章展示了如何制作交互式菜单来控制FTP服务的开关及匿名登录设置。最后,讨论了ftp客户端的安装和每天备份文件的自动化流程,包括文件排除、tar打包和FTP上传。
摘要由CSDN通过智能技术生成

Top

NSD SHELL DAY06

  1. 案例1:系统初始化
  2. 文档处理
  3. 案例2:通过文档批量创建账户并配置密码
  4. 制作菜单
  5. 案例3:制作菜单,可以控制vsftpd服务
  6. 安装ftp客户端
  7. 按要求每天备份文件

1 案例1:系统初始化

编写一个脚本可以匹配不同系统的服务器(包含7版本与8版本的系统)实现以下需求:

1,所有服务器永久关闭防火墙服务和SELinux

2,关闭7版本系统的命令历史记录,修改8版本的命令历史记录最多保存2000条并加上时间戳

3,关闭8版本系统的交换分区

4,定义root远程登录系统后的ssh保持时间为300秒

5,设置时间同步,ntp服务器地址是192.168.88.240

  1. #!/bin/bash
  2. #脚本执行完后,用ssh远程登录测试
  3. #可以先手工备份/etc/fstab和/etc/profile
  4. #1)判断当前账户身份,并关闭防火墙与selinux
  5. [ $UID -ne 0 ] && echo "请使用管理员操作" && exit
  6. systemctl stop firewalld
  7. systemctl disable firewalld
  8. setenforce 0
  9. sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
  10. #2)根据不同版本的系统执行各自的任务
  11. egrep -q "\s+8\.[0-9]" /etc/redhat-release                    #判断系统版本
  12. if [ $? -ne 0 ];then
  13.           sed -ri 's/HISTSIZE=[0-9]+/HISTSIZE=0/' /etc/profile        #关闭历史命令
  14. else
  15.         sed -ri 's/HISTSIZE=[0-9]+/HISTSIZE=2000/' /etc/profile        #历史命令2000条
  16.         sed -i '/^export /i HISTTIMEFORMAT="%F %T "' /etc/profile    #历史命令时间戳
  17.         sed -i '/^export /s/$/ HISTTIMEFORMAT/' /etc/profile        #找到export开头那行,在最后加 HISTTIMEFORMAT,可以在子进程中也显示时间戳
  18.         swap=$(swapon | awk 'NR!=1{print $1}')                #找到交换分区
  19.         for i in $swap
  20.         do
  21.                swapoff $i                                        #循环关闭交换分区
  22.        done
  23.        sed -i '/swap/s/^/#/' /etc/fstab                    #关闭交换分区自动挂载
  24. fi
  25. #3)最后所有机器设置ssh超时时间与时间同步
  26. echo "export TMOUT=300"  >>  ~/.bash_profile                #定义ssh超时退出时间 【追加重定向到家目录下 】
  27. yum -y install chrony
  28. systemctl enable chronyd
  29. sed -ri '/^(pool|server).*iburst/s/^/#/' /etc/chrony.conf
  30. sed -i '1i server 192.168.88.240 iburst' /etc/chrony.conf
  31. systemctl restart chronyd

2 文档处理

首先要了解:

< 符号,输入重定向,可以在后面需要跟文件名,这样让程序不再从键盘读取数据,而是从文件中读取数据。

  1. mail -s test root < /opt/mail.txt

<< 符号也称Here Document,代表你需要的内容在这里,某指令导入字符串时使用,而无需文件

  1. mail -s test root << EOF
  2. hello
  3. test mail~
  4. EOF

使用read指令配合输入重定向可同时定义多个变量

  1. read a b    
  2. abc xyz                    #同时为变量a赋值abc,变量b赋值xyz
  3. read a b < abc.txt        #利用abc.txt文档内容赋值,仅读取第一行

结合while循环批量读取数据并通过read命令给变量赋值

  1. while read a b
  2. do
  3. echo $a $b
  4. done < abc.txt            #利用abc.txt文档内容赋值,读取所有行

根据文档内容,创建账户并同时配置密码

首先准备测试文档user.txt

研发部

zhangsan haha123

人事部

lisi xixi456

wangwu lele789

销售部

zhaoliu kaka765

  1. #!/bin/bash
  2. while read name pass
  3. do
  4. [ -z $pass ] && continue            #如果没有密码则不创建,那个是部门的名字的行
  5. useradd $name
  6. echo $pass | passwd --stdin $name
  7. done < user.txt

3 案例2:通过文档批量创建账户并配置密码

系统中的/dev/urandom可以获得取之不尽的随机字符,但内容太随意有些是不需要的,如果文档中没有密码,可以使用tr处理这些随机字符获取密码

  1. tr -cd '_a-zA-Z0-9' < /dev/urandom | head -c 10 #-c是取反 -d是删除,对_a-zA-Z0-9取反删除,剩下就只是_a-zA-Z0-9这个范围内的字符串,head -c 10 可以得到10位字符

编写脚本:

  1. #!/bin/bash
  2. x=$(awk '/^[a-zA-Z0-9]/&&!/已创建/{print NR}' user.txt)
  3. if [ -z "$x" ];then
  4. echo "没有新用户需要创建"
  5. column -t user.txt
  6. exit
  7. fi
  8. for i in $x
  9. do
  10. pass=$(strings /dev/urandom | tr -cd '_a-zA-Z0-9' | head -c 10)
  11. sed -i "${i}s/$/\t$pass/" user.txt
  12. read name pass << EOF
  13. $(sed -n "${i}p" user.txt)
  14. EOF
  15. useradd $name
  16. echo $pass | passwd --stdin $name
  17. sed -i "${i}s/$/\t已创建/" user.txt
  18. done
  19. column -t user.txt

4 制作菜单

4.1 步骤

实现此案例需要按照如下步骤进行。

步骤一:

  1. #vim menu                #创建菜单函数文件
  2. x=1                    #高亮行号,默认为1即可
  3. y=0                    #第几行
  4. menu (){                #循环显示菜单的函数
  5. clear
  6. for i in 1,安装ftp服务 2,开关ftp服务 3,退出
  7. do
  8. echo "----------------"
  9. let y++
  10. [ $x -eq $y ] && echo -e "\033[43;93m$i\033[0m" && continue
  11. echo "$i"
  12. done
  13. y=0
  14. echo "----------------"
  15. }

步骤二:可动菜单

$'\033[A'代表键盘的 "上" 按键

$'\033[B'代表键盘的 "下" 按键

  1. #vim ftp.sh
  2. #!/bin/bash
  3. . menu            #读入菜单函数
  4. while :
  5. do
  6. menu
  7. read -n 3 c    #-n 3是输入足够3个字符就自动进行下一步,c是存储字符的变量
  8. if [ "$c" == $'\033[A' ];then        #如果按了 "上" 键
  9. [ $x -eq 1 ] && continue        #根据变量x定义高亮行,在第1行就没变化
  10. let x--                        #如果不在第1行,就把x-1
  11. elif [ "$c" == $'\033[B' ];then    #如果按了 "下" 键
  12. [ $x -eq 3 ] && continue        #如果在第3行,没变化
  13. let x++                        #如果不在第3行,就把x+1        
  14. fi
  15. done

之后执行ftp.sh可以看到菜单,按键盘上下键菜单发生变化

5 案例3:制作菜单,可以控制vsftpd服务

本案例需要在上一实验的基础上完成

步骤一:

  1. #vim ftp_install            #创建ftp安装函数文件
  2. ftp_install(){
  3. if rpm -q vsftpd &> /dev/null ;then        #ftp如果已经安装则条件算成功
  4. msg="vsftpd已安装"                    #定义信息变量msg
  5. else
  6. yum -y install vsftpd &> /dev/null
  7. [ $? -eq 0 ] && msg="vsftpd安装成功" || msg="vsftpd安装失败"
  8. fi
  9. }

步骤二:

  1. #vim ser_manager            #创建服务管理函数文件
  2. ser_manager(){
  3. if ! rpm -q vsftpd &>/dev/null ;then    #ftp如果未安装则条件算成功,!是取反
  4. msg="未安装vsftpd软件包"
  5. return                                #结束函数任务,跳出函数
  6. fi
  7. case $1 in
  8. start)                                #调用本函数后追加start就是把服务开启
  9. systemctl start vsftpd
  10. msg="ftp服务已经启动"
  11. ser_manager=start;;
  12. stop)                                    #调用本函数后追加stop就是把服务关闭
  13. systemctl stop vsftpd
  14. msg="ftp服务已经关闭"
  15. ser_manager=stop;;
  16. esac
  17. }

步骤三:

vsftpd服务的配置文件中:

anonymous_enable=YES 是允许匿名账户

anonymous_enable=NO 是禁止匿名账户

  1. #vim anon_config            #创建匿名账户配置函数文件
  2. anon_config(){
  3. conf_file=/etc/vsftpd/vsftpd.conf
  4. if [ ! -f $conf_file ];then            #如果配置文件不存则条件成功
  5. msg="配置文件不存在"
  6. return                                #结束函数任务,跳出函数
  7. fi    
  8. case $1 in
  9. yes)                                        #调用本函数后追加yes就是允许匿名
  10. sed -i '/anonymous_enable=/s/NO/YES/' $conf_file    #允许匿名
  11. systemctl restart vsftpd
  12. msg="匿名已允许登录"
  13. anon_login=yes;;
  14. no)                                        #调用本函数后追加no就是禁止匿名
  15. sed -i '/anonymous_enable=/s/YES/NO/' $conf_file    #禁止匿名
  16. systemctl restart vsftpd
  17. msg="匿名已禁止登录"
  18. anon_login=no;;
  19. esac
  20. }

步骤四:

将menu函数中的菜单增加开关匿名登录

  1. #vim menu
  2. ...
  3. for i in 1,安装ftp服务 2,开关ftp服务 3,开关匿名登录 4,退出
  4. ...

步骤五:

继续完善主程序

  1. #vim ftp.sh
  2. #!/bin/bash
  3. . menu            #读入菜单函数
  4. . ftp_install        #读入安装函数
  5. . ser_manager        #读入服务管理函数
  6. . anon_config        #读入匿名账户配置函数
  7. while :
  8. do
  9. menu
  10. echo "$msg"
  11. read -n 3 c    #-n 3是输入足够3个字符就自动进行下一步,c是存储字符的变量
  12. if [ "$c" == $'\033[A' ];then        #如果按了 "上" 键
  13. [ $x -eq 1 ] && continue        #根据变量x定义高亮行,在第1行就没变化
  14. let x--                        #如果不在第1行,就把x-1
  15. elif [ "$c" == $'\033[B' ];then    #如果按了 "下" 键
  16. [ $x -eq 4 ] && continue        #如果在第4行,没变化
  17. let x++                        #如果不在第4行,就把x+1
  18. elif [ -z $c ] && [ $x -eq 1 ];then        #如果在第1行回车就执行下列任务
  19. msg="ftp服务安装中。。。"
  20. echo "$msg"
  21. ftp_install                        #执行ftp_install函数的任务
  22. elif [ -z $c ] && [ $x -eq 2 ];then        #如果在第2行回车就执行下列任务
  23. [ "$ser_manager" != "start" ] && ser_manager start || ser_manager stop
  24. elif [ -z $c ] && [ $x -eq 3 ];then        #如果在第3行回车就执行下列任务
  25. [ "$anon_login" != "yes" ] && anon_config yes || anon_config no
  26. elif [ -z $c ] && [ $x -eq 4 ];then        #如果在第4行回车就执行下列任务
  27. exit
  28. fi
  29. done

6 安装ftp客户端

步骤一:

在服务端开启匿名上传

anon_upload_enable=YES

  1. #vim /etc/vsftpd/vsftpd.conf
  2. ...
  3. anon_upload_enable=YES
  4. ...

步骤二:

在客户端安装配置lftp并测试

  1. yum -y install lftp
  2. #vim /etc/lftp.conf                 #修改lftp配置
  3. set net:reconnect-interval-base 0        #重试时间0秒
  4. set net:max-retries 1                    #失败后是否重试,1不重试

测试

  1. lftp 192.168.99.5    
  2. cd pub                            #切换目录
  3. mput test.txt                        #上传文件
  4. quit                                #退出

 

7 按要求每天备份文件

1.备份数据/var/www/html 里面除了.tmp类型的所有文件到/opt/backup_data

2.备份文件要带时间戳,打tar包,格式为web_file_年-月-日.tar.gz

3.如果/opt/backup_data中备份的tar包凑齐5个之后,就都上传到ftp中并删除本地的这些tar包

4.任务执行成功或失败都要给出提示信息

使用tar工具可以通过文件选择功能的--exclude对不需要文件进行排除

  1. #!/bin/bash
  2. sou_path=/var/www/html                #定义备份数据的目录变量
  3. tar_path=/opt/backup_data                #定义tar包存储目录变量
  4. date=$(date +%Y-%m-%d)                #时间格式变量
  5. ex_file=*.tmp                            #排除文件变量
  6. tar -zcPf ${tar_path}/web_file_${date}.tar.gz --exclude=$ex_file ${sou_path}
  7. file_total=$(ls ${tar_path} | wc -l)    #定义tar包总数变量
  8. echo "${date}的文件已打tar包放入${tar_path},目前备份文件总数是${file_total}个"
  9. if [ $file_total -ge 5 ];then
  10. lftp 192.168.99.5 << EOF
  11. cd pub
  12. mput -q ${tar_path}/*                #上传时用-q可屏蔽信息输出
  13. quit
  14. EOF
  15. if [ $? -ne 0 ];then
  16. echo "上传ftp出错,请检查文件或服务"
  17. exit
  18. else
  19. rm -rf ${tar_path}/web_file*
  20. echo "上传ftp成功!"
  21. fi
  22. fi

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值