记一次shell脚本入门编写

最近入门linux的bashshell脚本语言,笔者看了一些入门的知识之后,便想写一些简单的脚本入门。

比如服务器的数据库远程连接

mysql -hhost -uroot -ppassword

 

 

数据库定时备份

#保存备份个数
number=3
#备份保存路径
backup_dir=/root/mysqlbackup
#日期
dd=`date +%Y%m%d`
#备份工具
tool=mysqldump
#用户名
username=
#密码
password=
#将要备份的数据库
database_name=mbike

if [ ! -d "$backup_dir" ];then
  mkdir "$backup_dir"
fi

#简单写法 mysqldump -u root -p123456 users > /root/mysqlbackup/users-$filename.dump
$tool -u $username -p$password $database_name > $backup_dir/$database_name-$dd.dump

#写创建备份日志
echo "create $backup_dir/$database_name-$dd.dump" >> $backup_dir/log.txt

#找出需要删除的备份
delfile='ls -l -crt $backup_dir/*.dump | awk '{print $9}' | head -1'

#判断现在的备份数量是否大于$number
count='ls -l -crt $backup_dir/*.dump | awk '{print $9}' | wc -l'

if [ $count -gt $number ]
then
  rm $delfile  //删除最早生成的备份,只保留number数量的备份
  #写删除文件日志
  echo "delete $delfile" >> $backup_dir/log.txt
fi

 

然后创建定时任务

crontab -e

然后笔者想到,测试环境经常要重新部署项目需要删除项目和停止服务器,每次更新都需要删除项目,然后找到服务器进程kill掉,步骤有点繁琐。所以在想能不能写个脚本能一键处理,于是笔者就开始用着个作为练手机会,写了一段脚本,但是由于对awk的命令不太熟,一开始写的脚本非常非常冗余

psname="ccl"
stu="Sl"
names=$(ls -l |ps aux | grep tomcat|awk '{print $1}')
statu=$(ls -l |ps aux | grep tomcat|awk '{print $8}')
pid=$(ls -l |ps aux | grep tomcat|awk '{print $2}')
echo "have been clear"
:<

写不下去了。。。

然后经过优化一下,知道了awk可以直接用if条件判断,于是就一下子简化了

psname="ccl"
stu="Sl"
pid=$(ls -l |ps aux | grep tomcat|awk '{if ($8=$stu && $1=$psname && $3!=0.0) print $2;}')
echo $pid
kill -9 $pid
rm -rf ../webapps/ccl-web*
echo "have been clear"

嗯。。看来还有很远的一段学习距离。

 


 

你可能感兴趣的:(Linux)