Linux之常用Shell脚本总结

目录

一、简介

二、shell脚本


一、简介

本文将总结一些常用的shell脚本,方便以后工作中使用。

二、shell脚本

【a】定期备份mysql数据库,需结合cronb定时任务调度实现。

#!/bin/bash

#首先声明一些自定义变量

#数据库备份路径
DB_BAK_PATH=/data/db
#当前时间
CURRENTTIME=$(date +%Y%m%d_%H%M%S)
#备份数据库名称
DB_NAME=test_db_bak
#用户名
DB_USERNAME=root
#密码
DB_PASSWORD=0905
#主机名称
DB_HOSTNAME=localhost

echo "=======数据库备份开始【备份路径: $DB_BAK_PATH/$CURRENTTIME.tar.gz 】========"


#创建备份的路径,如果目录不存在,则先创建备份目录
if [ ! -d "$DB_BAK_PATH/$CURRENTTIME" ]; then
	echo "备份目录不存在,准备创建备份目录"
	#创建备份目录
	mkdir -p "$DB_BAK_PATH/$CURRENTTIME" 
else
	echo "备份目录已存在"
fi

#另一种比较简便的写法(前面的命令为true,才执行 &&后面的命令)
#[ ! -d "$DB_BAK_PATH/$CURRENTTIME" ] && mkdir -p "$DB_BAK_PATH/$CURRENTTIME"

#使用mysqldump备份mysql数据库,并进行gzip压缩
mysqldump -u${DB_USERNAME} -p${DB_PASSWORD} --host=$DB_HOSTNAME  $DB_NAME | gzip > $DB_BAK_PATH/$CURRENTTIME/$CURRENTTIME.sql.gz

#tar压缩
cd $DB_BAK_PATH
tar -zcvf $CURRENTTIME.tar.gz $CURRENTTIME

#删除临时目录
rm -rf $DB_BAK_PATH/$CURRENTTIME

#删除一个月之前的数据库备份文件
find $DB_BAK_PATH -mtime +30 -name "*.tar.gz" -exec rm -rf {} \;

#数据库备份完成
echo "========数据库备份成功【备份路径: $DB_BAK_PATH/$CURRENTTIME.tar.gz】==========="

【b】批量创建Linux用户,并且属于同一个用户组wsh,要求用户名和密码一致。

#!/bin/bash

#批量创建Linux用户(user1 - user5),并且属于同一个用户组wsh,要求用户名和密码一致

for I in $(seq 1 5)
do
        #useradd 用户名  -g 用户组名
        useradd user$I -g wsh
        #修改密码
        echo user$I | passwd user$I --stdin
done

【c】将/test目录下大于10k的文件删除(常用于垃圾回收)

#!/bin/bash

#将/test中的大于10k的文件删除
for tmp in $(ls /test)
do
        if [ -f $tmp ]; then
                if [ $(ls -l $tmp|awk '{print $5}') -gt 10000 ]; then
                        #删除文件
                        rm -rf $tmp
                fi
        fi
done

【d】按时批量清除N天前文件(需要结合cronb定时任务调度实现)

#!/bin/bash


#定时清理30天之前的/data/目录下的后缀为.txt的文:wq!i件
find /data/ -mtime +30 -name "*.txt" -exec rm -rf {} \;


#/data:准备要进行清理的目录; 
#-mtime:标准语句写法+30:查找30天前的文件;
#".txt"表示查找扩展名为.txt的所有文件;
#-exec:固定写法 ;
#rm -rf:强制删除文件,包括目录 ;
#{} \ :将find的结果放到里面;

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值