작업 중 Shell 유 틸 리 티 스 크 립 트 사용
10256 단어 Shell실 용 스 크 립 트
#!/bin/bash
#memory use
mem_war_file=/tmp/mem_war.txt
mem_use=`free -m | grep Mem | awk '{print $3}'`
mem_total=`free -m | grep Mem | awk '{print $2}'`
mem_percent=$((mem_use*100/mem_total))
# echo "$mem_percent"%
if (($mem_percent > 80));then
echo "`date +%F-%H-%M` mem: ${mem_percent}%" >$mem_war_file
echo "`date +%F-%H-%M` mem: ${mem_percent}%" | mail -s "mem warning" root
fi
2.네트워크 카드 트 래 픽 을 검사 하고 정 해진 형식 으로 로그 에 기록 합 니 다.
#!/bin/bash
#######################################################
# ,
#
# :
#2021-07-08 18:55
#eth0 input: 1234bps
#eth0 output: 1235bps
######################################################3
while :
do
# , , bug
LANG=en
logfile=/tmp/`date +%d`.log
# logfile
exec >> $logfile
date +"%F %H:%M"
#sar kb/s, bps, *1000*8
sar -n DEV 1 59|grep Average|grep eth0|awk '{print $2,"\t","input:","\t",$5*1000*8,"bps","
",$2,"\t","output:","\t",$6*1000*8,"bps"}'
echo "####################"
# sar 59 , sleep
done
3.Nginx 방문 로그 502 상황 을 모니터링 하고 해당 동작 을 한다.서버 가 lnmp 환경 이 라 고 가정 하면 최근 에 자주 502 현상 이 발생 하고 502 오류 가 php-fpm 서 비 스 를 다시 시작 한 후에 사라 집 니 다.따라서 모니터링 스 크 립 트 를 작성 하고 502 가 발생 하면 자동 으로 php-fpm 서 비 스 를 다시 시작 합 니 다.
# :
#1. :/data/log/access.log
#2. , 10 ,10 300 , 502 10%(30 ) php-fpm
#3. :/etc/init.d/php-fpm restart
#!/bin/bash
###########################################################
# Nginx 502 ,
###########################################################
log=/data/log/access.log
N=30 #
while :
do
# 300 , 502
err=`tail -n 300 $log |grep -c '502" '`
if [ $err -ge $N ]
then
/etc/init.d/php-fpm restart 2> /dev/null
# 60s bug php-fpm
sleep 60
fi
sleep 10
done
4.호스트 포트 상태 스 캔
#!/bin/bash
HOST=$1
PORT="22 80 8080 3306"
for PORT in $PORT; do
if echo &>/dev/null > /dev/tcp/$HOST/$PORT; then
echo "$PORT open"
else
echo "$PORT close"
fi
done
5.두 서버 의 한 디 렉 터 리 에 있 는 파일 일치 성 검사
#!/bin/bash
#####################################
#
#####################################
# md5 ,
dir=/data/web
b_ip=192.168.88.10
# md5sum , md5 ,
find $dir -type f|xargs md5sum > /tmp/md5_a.txt
ssh $b_ip "find $dir -type f|xargs md5sum > /tmp/md5_b.txt"
scp $b_ip:/tmp/md5_b.txt /tmp
#
for f in `awk '{print 2} /tmp/md5_a.txt'`
do
# a , b
if grep -qw "$f" /tmp/md5_b.txt
then
md5_a=`grep -w "$f" /tmp/md5_a.txt|awk '{print 1}'`
md5_b=`grep -w "$f" /tmp/md5_b.txt|awk '{print 1}'`
# , md5
if [ $md5_a != $md5_b ]
then
echo "$f changed."
fi
else
echo "$f deleted."
fi
done
6.정 해진 시간 에 파일 내용 을 비우 고 정 해진 시간 에 파일 크기 를 기록 합 니 다.
#!/bin/bash
################################################################
# ( ), 0 12 , , , , , , 、
################################################################
logfile=/tmp/`date +%H-%F`.log
n=`date +%H`
if [ $n -eq 00 ] || [ $n -eq 12 ]
then
# for , find ,
for i in `find /data/log/ -type f`
do
true > $i
done
else
for i in `find /data/log/ -type f`
do
du -sh $i >> $logfile
done
fi
7.랜 내 호스트 가 살아 있 는 지 확인
#!/usr/bin/bash
# check host status
for i in {1..254}
do
{
ip=192.168.8.$i
ping -c 2 -W 1 $ip &>/dev/null
if [ $? -eq 0 ];then
echo "$ip is online" | tee -a /tmp/host_online.txt
else
# echo "$ip is offline" | tee -a /tmp/host_offline.txt
echo "$ip is offline" &>/dev/null
fi
}&
done
wait
8.자동 응답 배포 비밀 로그 인 면제
#!/usr/bin/bash
# ssh keygen
>ip_ok.txt
>ip_false.txt
user=root
passwd=123456
rpm -qa | grep expect &>/dev/null
if [ $? -ne 0 ];then
echo "expect is not install"
yum -y install expect
fi
if [ ! -f ~/.ssh/id_rsa ];then
ssh-keygen -P "" -f ~/.ssh/id_rsa
fi
for i in {15..30}
do
{
ip=192.168.1."$i"
ping -c 1 -W1 "$ip"
if [ $? -eq 0 ];then
echo "$ip" >> ip_ok.txt
/usr/bin/expect <<-EOF
spawn ssh-copy-id $user@$ip
expect {
"yes/no" { send "yes\r"; exp_continue }
"password:" { send "$passwd\r" };
}
expect eof
EOF
else
echo "$ip" >>ip_false.txt
fi
}&
done
wait
echo "finish"
9.코드 온라인 스 크 립 트
#!/bin/bash
# code online
# author: ren
PROJT_DIR=/usr/local/nginx/html
OLD_DIR=/usr/local/nginx/html/web1
PROJT=web1
BACKUP_DIR=/data/backup
DATA_CHMOD=www
DATE=`date +%F`
NEW_DIR=/data/web1
# nginx
function stop_nginx() {
/usr/bin/systemctl stop nginx
if [ $? -eq 0 ];then
echo "nginx is stopd"
else
echo "nginx is not stop please check..."
exit 1
fi
}
#2
function backup_data() {
if [ -d $BACKUP_DIR/$DATE'-'$PROJT ];then
echo "DIR $BACKUP_DIR/$DATE'-'$PROJT is exist"
exit 2
else
mv $OLD_DIR $BACKUP_DIR/$DATE'-'$PROJT
fi
}
# 3 :
function new_code() {
if [ -d $NEW_DIR ];then
mv $NEW_DIR $PROJT_DIR
else
echo "NEW_DIR is not exist"
exit 3
fi
}
# 4
function chmod_news() {
chown -R $DATA_CHMOD.$DATA_CHMOD $OLD_DIR
}
# 5
function start_nginx() {
/usr/bin/systemctl start nginx
if [ $? -eq 0 ];then
echo "nginx start ok"
else
echo "ngin is not start,please check..."
fi
}
stop_nginx
backup_data
new_code
chmod_news
start_nginx
10.MySQL 마스터 복사 에 이상 이 있 는 지 확인
#!/bin/bash
user="root"
password="123456"
mycmd="mysql -u$user -p$password -h 192.168.1.88"
function chkdb() {
list=($($mycmd -e "show slave status \G"|egrep "Running|Behind"|awk -F: '{print $2}'))
if [ ${list[0]} = "Yes" -a ${list[1]} = "Yes" -a ${list[2]} -lt 120 ]
then echo "Mysql slave is ok"
else echo "Mysql slave replation is filed"
fi
}
function main() {
while true
do chkdb
sleep 3
done
}
main
11.MySQL 데이터베이스 백업 스 크 립 트(mysqldump)
#!/bin/bash
# 15
source /etc/profile #
source ~/.bash_profile #
set -o nounset #
#set -o errexit # shell
user="root"
password="123456"
host="localhost"
port="3306"
# ,
db=("test")
# ,
#MyISAM --lock-all-tables,
#InnoDB --single-transaction
lock="--single-transaction"
mysql_path="/usr/local/mysql"
backup_path="${mysql_path}/backup"
date=$(date +%Y-%m-%d_%H-%M-%S)
day=15
backup_log="${mysql_path}/backup.log"
#
if [ ! -e $backup_path ];then
mkdir -p $backup_path
fi
#
find $backup_path -type f -mtime +$day -exec rm -rf {} \; > /dev/null 2>&1
echo " :${db[*]}"
#
backup_sql(){
dbname=$1
backup_name="${dbname}_${date}.sql"
#-R , ,
mysqldump -h $host -P $port -u $user -p$password $lock --default-character-set=utf8 --flush-logs -R $dbname > $backup_path/$backup_name
if [[ $? == 0 ]];then
cd $backup_path
tar zcpvf $backup_name.tar.gz $backup_name
size=$(du $backup_name.tar.gz -sh | awk '{print $1}')
rm -rf $backup_name
echo "$date $dbname($size) "
else
cd $backup_path
rm -rf $backup_name
echo "$date $dbname "
fi
}
#
length=${#db[@]}
for (( i = 0; i < $length; i++ )); do
backup_sql ${db[$i]} >> $backup_log 2>&1
done
echo " , $backup_log"
du $backup_path/*$date* -sh | awk '{print " :" $2 ", :" $1}'
작업 중 Shell 유 틸 리 티 스 크 립 트 를 사용 하 는 것 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 Shell 유 틸 리 티 스 크 립 트 내용 은 예전 의 글 을 검색 하거나 아래 의 관련 글 을 계속 찾 아 보 세 요.앞으로 많은 응원 부 탁 드 리 겠 습 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Shell alias 명령에 별칭을 설정하는 방법명령에 별명을 설정하면 명령의'작은 이름'으로 삼을 수 있지만, 이렇게 하는 것이 무슨 의미가 있습니까? 이때 별명이 작용할 수 있다.vim 명령의 별명을vi라고 정의하면 이후에 실행된vi 명령은 실제로vim 명령을...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.