二、Shell 案例


一、Shell 案例


1. 案例——系统备份脚本

  • Tar工具全备、增量备份网站,Shell脚本 实现自动打包备份。
#!/bin/bash
# Auto Backup Linux System Files
# by author rivers on 2022-06-30

SOURCE_DIR=(
	$*
)
TARGET_DIR=/data/backup/
YEAR=`date +%Y`
MONTH=`date +%m`
DAY=`date +%d`
WEEK=`date +%u`
A_NAME=`date +%H%M`
FILES=system_backup.tgz
CODE=$?
if
	[ -z "$*" ];then
    echo -e "\033[32mUsage:\nPlease Enter Your Backup Files or Directories\n--------------------------------------------\n\nUsage: { $0 /boot /etc}\033[0m"
    exit
fi
# Determine Whether the Target Directory Exists
if
    [ ! -d $TARGET_DIR/$YEAR/$MONTH/$DAY ];then
    mkdir -p $TARGET_DIR/$YEAR/$MONTH/$DAY
    echo -e "\033[32mThe $TARGET_DIR Created Successfully !\033[0m"
fi
# EXEC Full_Backup Function Command
Full_Backup()
{
if
    [ "$WEEK" -eq "7" ];then
    rm -rf $TARGET_DIR/snapshot
    cd $TARGET_DIR/$YEAR/$MONTH/$DAY ;tar -g $TARGET_DIR/snapshot -czvf $FILES ${SOURCE_DIR[@]}
    [ "$CODE" == "0" ]&&echo -e  "--------------------------------------------\n\033[32mThese Full_Backup System Files Backup Successfully !\033[0m"
fi
}
#Perform incremental BACKUP Function Command
Add_Backup()
{
   if
        [ $WEEK -ne "7" ];then
        cd $TARGET_DIR/$YEAR/$MONTH/$DAY ;tar -g $TARGET_DIR/snapshot -czvf $A_NAME$FILES ${SOURCE_DIR[@]}
        [ "$CODE" == "0" ]&&echo -e  "-----------------------------------------\n\033[32mThese Add_Backup System Files $TARGET_DIR/$YEAR/$MONTH/$DAY/${YEAR}_$A_NAME$FILES Backup Successfully !\033[0m"
   fi
}
sleep 3 
Full_Backup;Add_Backup

2. 案例——服务器信息自动收集

cat <<EOF
++++++++++++++++++++++++++++++++++++++++++++++
++++++++Welcome to use system Collect+++++++++
++++++++++++++++++++++++++++++++++++++++++++++
EOF
ip_info=`ifconfig |grep "Bcast"|tail -1 |awk '{print $2}'|cut -d: -f 2`
cpu_info1=`cat /proc/cpuinfo |grep 'model name'|tail -1 |awk -F: '{print $2}'|sed 's/^ //g'|awk '{print $1,$3,$4,$NF}'`
cpu_info2=`cat /proc/cpuinfo |grep "physical id"|sort |uniq -c|wc -l`
serv_info=`hostname |tail -1`
disk_info=`fdisk -l|grep "Disk"|grep -v "identifier"|awk '{print $2,$3,$4}'|sed 's/,//g'`
mem_info=`free -m |grep "Mem"|awk '{print "Total",$1,$2"M"}'`
load_info=`uptime |awk '{print "Current Load: "$(NF-2)}'|sed 's/\,//g'`
mark_info='BeiJing_IDC'
echo -e "\033[32m-------------------------------------------\033[1m"
echo IPADDR:${ip_info}
echo HOSTNAME:$serv_info
echo CPU_INFO:${cpu_info1} X${cpu_info2}
echo DISK_INFO:$disk_info
echo MEM_INFO:$mem_info
echo LOAD_INFO:$load_info
echo -e "\033[32m-------------------------------------------\033[0m"
echo -e -n "\033[36mYou want to write the data to the databases? \033[1m" ;read ensure

if      [ "$ensure" == "yes" -o "$ensure" == "y" -o "$ensure" == "Y" ];then
        echo "--------------------------------------------"
        echo -e  '\033[31mmysql -uaudit -p123456 -D audit -e ''' "insert into audit_system values('','${ip_info}','$serv_info','${
cpu_info1} X${cpu_info2}','$disk_info','$mem_info','$load_info','$mark_info')" ''' \033[0m '
        mysql -uroot -p123456 -D test -e "insert into audit_system values('','${ip_info}','$serv_info','${cpu_info1} X${cpu_info2}
','$disk_info','$mem_info','$load_info','$mark_info')"
else
        echo "Please wait,exit......"
        exit
fi

3. 案例——批量部署 lnmp 架构

# vim lnmp.sh 
#!/bin/bash
# install lnmp
# by author rivers on 2022-6-30

# nginx 环境准备
Nginx_url=https://nginx.org/download/nginx-1.20.1.tar.gz
Nginx_prefix=/usr/local/nginx

# mysql 环境准备
Mysql_version=mysql-5.5.20.tar.gz
Mysql_dir=mysql-5.5.20
Mysql_url=https://downloads.mysql.com/archives/get/p/23/file/mysql-5.5.20.tar.gz
Mysql_prefix=/usr/local/mysql/

# php 环境准备
Php_version=php-7.2.10.tar.gz
Php_prefix=/usr/local/php-7.2.10/


function nginx_install() {
	if [[ "$1" -eq "1" ]];then
		if [ $? -eq 0 ];then
		        make && make install
		fi
	fi
}

function mysql_install() {
	if [[ "$1" -eq "2" ]];then
		-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
		-DMYSQL_DATADIR=/data/mysql \
		-DSYSCONFDIR=/etc \
		-DMYSQL_USER=mysql \
		-DMYSQL_TCP_PORT=3306 \
		-DWITH_XTRADB_STORAGE_ENGINE=1 \
		-DWITH_INNOBASE_STORAGE_ENGINE=1 \
		-DWITH_PARTITION_STORAGE_ENGINE=1 \
		-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
		-DWITH_MYISAM_STORAGE_ENGINE=1 \
		-DWITH_READLINE=1 \
		-DENABLED_LOCAL_INFILE=1 \
		-DWITH_EXTRA_CHARSETS=1 \
		-DDEFAULT_CHARSET=utf8 \
		-DDEFAULT_COLLATION=utf8_general_ci \
		-DEXTRA_CHARSETS=all \
		echo -e "\033[32mThe $Mysql_dir Server Install Success !\033[0m"
	else
		echo -e "\033[32mThe $Mysql_dir Make or Make install ERROR,Please Check......"
 		exit 0
	fi
/bin/cp support-files/my-small.cnf  /etc/my.cnf
/bin/cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on
fi
}


function php_install(){
if [[ "$1" -eq "3" ]];then
        if [ $? -eq 0 ];then
                make ZEND_EXTRA_LIBS='-liconv' && make install
if [[ "$1" -eq "3" ]];then
 wget $Php_url && tar xf $Php_version && cd $Php_dir && yum install   bxml2* bzip2* libcurl*  libjpeg* libpng* freetype* gmp* libm
crypt* readline* libxslt* -y && ./configure --prefix=$Php_prefix --disable-fileinfo --enable-fpm --with-config-file-path=/etc --wi
  -config-file-scan-dir=/etc/php.d --with-openssl --with-zlib --with-curl --enable-ftp --with-gd --with-xmlrpc --with-jpeg-dir --w
ith-png-dir --with-freetype-dir --enable-gd-native-ttf --enable-mbstring --with-mcrypt=/usr/local/libmcrypt --enable-zip --enable-
mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-mysql-sock=/var/lib/mysql/mysql.sock --without-pear --enable-bcmath
        if [ $? -eq 0 ];then
                make ZEND_EXTRA_LIBS='-liconv' && make install
                echo -e "\n\033[32m-----------------------------------------------\033[0m"
                echo -e "\033[32mThe $Php_version Server Install Success !\033[0m"
        else
                echo -e "\033[32mThe $Php_version Make or Make install ERROR,Please Check......"
                exit 0
        fi
fi
}


PS3="Please enter you select install menu:"
select i in nginx mysql php quit
do
"lnmp.sh" 113L, 3516C written                                                                                   
[root@web-server01~/script]# vim lnmp.sh 
chkconfig --add mysqld
chkconfig mysqld on
fi
}


function php_install(){
if [[ "$1" -eq "3" ]];then
        if [ $? -eq 0 ];then
                make ZEND_EXTRA_LIBS='-liconv' && make install
                echo -e "\n\033[32m-----------------------------------------------\033[0m"
                echo -e "\033[32mThe $Php_version Server Install Success !\033[0m"
        else
                echo -e "\033[32mThe $Php_version Make or Make install ERROR,Please Check......"
                exit 0
        fi
fi
}


PS3="Please enter you select install menu:"
select i in nginx mysql php quit
do

case $i in
        nginx)
        nginx_install 1
        ;;
        mysql)
        mysql_install 2
        ;;
        php)
        php_install 3
        ;;
        quit)
        exit
esac
done

4. 案例——MySQL 备份脚本

#!/bin/bash
# `MySQL`备份脚本。


username='root'
password='123456'
#备份目录
backup_dir='/data/backup/'
#备份库名(多个`空格`隔开)。
db_name_array="all"
#备份时间
current_time=$(date +%Y%m%d_%H%M%S)
#备份文件名。
filepath=$backup_dir$db_name'_'$current_time'.sql'
#循环备份多个数据库(利用管道命令,连接gzip命令,直接备份为gz压缩文件)。
for db_name in ${db_name_array[*]}
do
	#备份核心语句(单个数据库备份,可以直接这一个语句)。
	mysqldump -u$username -p$password --all-databases | gzip > $backup_dir$db_name'_'$current_time'.sql.gz'
done
 
#删除7天前备份的文件(防止数据多了太占内存)。
#看其最后访问时间是否在7天以前(-atime +7)
find $backup_dir -name "*.sql.gz" -atime +7 -exec rm -rf {} \;

  • [Warning] Using a password on the command line interface can be insecure
vim /etc/mysql/my.cnf

[mysqldump]
user=root
password=123456
#!/bin/bash

db_name=test
#备份目录。
backup_dir=/root/mysql/backup/
#备份时间。
current_time=$(date +%Y-%m-%d_%H-%M-%S)

#备份核心语句。
/usr/local/mysql/bin/mysqldump $db_name > $backup_dir$db_name'_'$current_time'.sql'
echo 'bk' = $?

#删除15天前备份的文件。
find $backup_dir -name "*.sql" -atime +15 -exec rm -rf {} \;
echo 'rm' = $?

二、crontab 定时任务

  • crontab [-u username] [-l|-e|-r]
参数 描述
-u 只有 root 才能进行这个任务,也即帮其他用户新建、删除 crontab 工作调度。
-e 编辑 crontab 的工作内容。
-l 查阅 crontab 的工作内容。
-r 删除所有 crontab 的工作内容,若仅要删除一项,请用 -e 去编辑。

1. 设置定时任务

  • 两种设置定时任务:
  1. 直接输入命令 crontab -e
  2. 编辑文件 /etc/crontab
# 1、输入命令。
crontab -e
# 可以指定用户。
#crontab [-u username] -e
#crontab -u root -e

# 2、按下`a`键进入到编辑模式。

# 3、输入命令(每10分钟一次)。 
0 */10 * * * /root/mysql_backup.sh 

# 4、同时按下`Ctrl+C`退出编辑模式。

# 5、按下`Shift+:`输入`wq`退出`crontab`。

# 6、查看任务集。
crontab -l
# crontab -u root -l
# 每个30秒执行一次任务。
# 没办法直接通过cron表达式去执行,因为最小的是1min。但是可以通过如下的方法。
* * * * * /root/mysql/backup/mysql_backup.sh
* * * * * sleep 30; /root/mysql/backup/mysql_backup.sh


# 每分钟一次。
*/1 * * * * /root/mysql/backup/mysql_backup.sh
* * * * * /root/mysql/backup/mysql_backup.sh
# 每四个小时执行一个任务。
0 */4 * * * /root/mysql/backup/mysql_backup.sh
# 每年执行一次任务。
#`@yearly`类似于`0 0 1 1 *`。
#它会在每年的第一分钟内执行,通常我们可以用这个发送新年的问候。
@yearly /scripts/script.sh
# 每月执行一次任务
@yearly /scripts/script.sh
# 每周执行一次任务
@yearly /scripts/script.sh
# 每天执行一次任务
@yearly /scripts/script.sh
# 每分钟执行一次任务
@yearly /scripts/script.sh
# 系统重启时执行
@reboot /scripts/script.sh


# 每天10点一次。
0 10 * * * /root/mysql/backup/mysql_backup.sh
# 每天5点和17点执行任务。
0 5,17 * * * /root/mysql/backup/mysql_backup.sh
# 每周一、周日执行任务
0 4,17 * * sun,mon /root/mysql/backup/mysql_backup.sh


# 每周日17点一次。
0 17 * * sun /root/mysql/backup/mysql_backup.sh
# 在特定的某几个月执行任务。
* * * jan,may,aug * /root/mysql/backup/mysql_backup.sh
# 在特定的某几天执行任务。
0 17 * * sun,fri /root/mysql/backup/mysql_backup.sh
# 在每周五、周日的17点执行任务。
# 在某个月的第一个周日执行任务。
0 2 * * sun [ $(date +%d) -le 07 ] && /root/mysql/backup/mysql_backup.sh


# 多个任务在一条命令中配置。
* * * * * /scripts/script.sh; /scripts/scrit2.sh

# 或者`vi`编辑文件步骤一样。
vi /etc/crontab

2. 定时任务格式

二、Shell 案例_第1张图片

# * * * * * command
# 分 时 日 月 周 命令

# `第1列`表示分钟`1~59`,每分钟用`*`或`*/1`表示。
# `第2列`表示小时`1~23`(0表示0点)。
# `第3列`表示日期`1~31`。
# `第4列`表示月份`1~12`。
# `第5列`表示星期`0~6`(0星期天)。
# `第6列`要运行的命令。

# 星号(*):代表所有可能的值。
# 例如`month字段`如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。

# 逗号(,):可以用逗号隔开的值指定一个列表范围。
# 例如`'1,2,5,7,8,9'`。

# 中杠(-):可以用整数之间的中杠表示一个整数范围。
# 例如`'2-6'`表示`'2,3,4,5,6'`。

# 正斜线(/):可以用正斜线指定时间的间隔频率。
# 例如`'0-23/2'`表示每两小时执行一次。

# 同时正斜线可以和星号一起使用。
# 例如`*/10`。如果用在`minute字段`,表示每十分钟执行一次。

2. 安装 crontab

# 1、检测系统是否安装`crond`服务。
service crond status

# 2、安装。
yum -y install vixie-cron
yum -y install crontabs
  • vixie-cron 软件包是 cron的主程序。
  • crontabs 软件包是用来 安装、卸装、或 列举用来驱动 cron 守护进程 的表格的程序。

# 3、启动服务。
service crond start
# 关闭服务。
service crond stop
# 重启服务。
service crond restart
# 重新载入配置。
service crond reload
# 查看crontab服务状态。
service crond status

# 4、设置开机自动启动。
chkconfig --level 345 crond on

你可能感兴趣的:(Linux,linux,运维,服务器)