0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

整理一些實(shí)用的Linux Shell腳本案例

jf_yLA7iRus ? 來(lái)源:咸魚愛搞機(jī) ? 作者:咸魚不想禿頭 ? 2022-10-31 09:13 ? 次閱讀

今天給大家整理一些實(shí)用的 Linux Shell 腳本案例

希望可以幫到大家,讓大家更熟悉 shell 編程

1.顯示系統(tǒng)一些基本信息

顯示信息如下:

系統(tǒng)版本

系統(tǒng)內(nèi)核

虛擬平臺(tái)

主機(jī)名

ip地址

開機(jī)信息有沒(méi)有報(bào)錯(cuò),有的話輸出到屏幕

可以將該腳本加入到開機(jī)自啟動(dòng)里面,這樣開機(jī)就會(huì)輸出基本信息

#!/bin/bash
info(){
system=$(hostnamectl|grepSystem|awk'{print$3}')
kernel_release=$(hostnamectl|grepKernel|awk-F:'{print$2}')
Virtualization=$(hostnamectl|grepVirtualization|awk'{print$2}')
server_name=$(hostname)
ipaddr=$(hostname-I)
echo"當(dāng)前系統(tǒng)版本是:${system}"
echo"當(dāng)前系統(tǒng)內(nèi)核是:${kernel_release}"
echo"當(dāng)前虛擬平臺(tái)是:${Virtualization}"
echo"當(dāng)前主機(jī)名是:${server_name}"
echo"當(dāng)前ip地址:${ipaddr}"
}

checkerrror(){
error_info=$(dmesg|greperror)
if[-e${error_info}]
then
echo"無(wú)錯(cuò)誤日志!"
else
ehcho${error_info}
fi
}
info
checkerrror

ac7adc2a-58b2-11ed-a3b6-dac502259ad0.png

2.關(guān)閉系統(tǒng)防火墻和SELinux

檢查防火墻狀態(tài),是否安裝防火墻,如果安裝則關(guān)閉 關(guān)閉SELinux 清空iptables規(guī)則

#!/bin/bash
close_firewalld(){
code=$(systemctlstatusfirewalld)

if[${code}-eq0]
then
systemctlstopfirewalld
fi
}

close_selinux(){
sed-i'/^SELINUX/s/=.*/=disabled/'/etc/selinux/config
setenforce0
}

close_iptables(){
iptables-F
serviceiptablessave
serviceiptablesrestart
}

close_firewalld
close_selinux
close_iptables

3.定時(shí)任務(wù)計(jì)劃:歸檔備份

打包壓縮/var/log/nginx目錄下所有內(nèi)容,存放在/tmp/nginx目錄里

壓縮文件命名規(guī)范:yymmdd_logs.tar.gz,只保存七天內(nèi)的文件,超過(guò)七天的文件會(huì)進(jìn)行清理

#!bin/bash
date="$(date+%Y%m%d)"
dir='/tmp/nginx'
backupfile='yymmdd_logs.tar.gz'

#查看/tmp/nginx是否存在,不存在則創(chuàng)建
checkbak(){
if[!-e${dir}]
then
mkdir${dir}
fi
}

#壓縮文件
backup(){
tar-zcvf${dir}/${backupfile}/var/log/nginx/>/dev/null2>&1
echo"${backupfile}Compressed and packaged successfully !"
}

#清除七天過(guò)期文件
cleanup(){
find${dir}-typef-mtime+7|xagrsrm-rf
if[$?-eq0]
then
echo"Cleaned up successfully!"
else
echo"datacleaningfailederror,pleasepayattentionintime"
fi
}

checkbak
backup
cleanup

4.自動(dòng)批量創(chuàng)建用戶

批量創(chuàng)建user1、user2、user3.....

#!/bin/bash
#檢查用戶是否存在,不存在則創(chuàng)建
checkuser(){
foriin$(seq120)
do
iduser${i}>/dev/null2>&1
if[$?-eq0]
then
echo"user${i}已存在!"
else
useradduser${i}&&echo"user${i}"|passwd--stdinuser${i}>/dev/null2>&1
fi
done
}
checkuser

5.通過(guò)位置參數(shù)創(chuàng)建用戶

$1 是執(zhí)行腳本的第一個(gè)參數(shù)

$2 是執(zhí)行腳本的第二個(gè)參數(shù)

#!/bin/bash
checkuser(){
id${1}>/dev/null2>&1
if[$?-eq0]
then
echo"${1}已存在!"
else
useradd"$1"
echo"$2"|passwd‐‐stdin"$1"
fi
}

6.批量刪除用戶

批量刪除user1...user20

#!/bin/bash
#檢查用戶是否存在,存在則刪除
checkuser(){
foriin$(seq120)
do
iduser${i}>/dev/null2>&1
if[$?-eq0]
then
userdel-ruser${i}
else
echo"user${i}不存在!"
fi
done
}
checkuser

7.更新系統(tǒng)時(shí)間,并寫入硬件時(shí)間里

查看是否安裝ntpdate工具

創(chuàng)建上海時(shí)區(qū)文件的軟鏈接

更新時(shí)間并寫入到硬件時(shí)間里

#!/bin/bash
package="ntpdate"
info=$(rpm-q${package})
check_pkgs(){
if[!-e${info}]
then
echo"ntpdate already exists!"
else
echo"start installation!"
yumcleanall>/dev/null2>&1
fi
yumupdate-y&&yuminstall-y${package}>/dev/null2>&1
fi
}

modify_time(){
echo"開始修改時(shí)間"
rm-rf/etc/localtime&&ln-s/usr/share/zoneinfo/Asia/Shanghai/etc/localtime
/usr/sbin/ntpdatecn.pool.ntp.org>/dev/null2>&1&&hwclock-w
}

check_pkgs
modify_time

8.檢查服務(wù)運(yùn)行狀態(tài)

檢查某一服務(wù)是否正常運(yùn)行,執(zhí)行腳本的時(shí)候第一個(gè)參數(shù)為服務(wù)名

#!/bin/bash
result=$(pidof$1|wc-l)
echo${result}
if[${result}-eq0]
then
echo"service does not exist !"
else
echo"Service is running normally !"
fi

ac909506-58b2-11ed-a3b6-dac502259ad0.png

9.對(duì)目標(biāo)主機(jī)進(jìn)行心跳檢測(cè)

ping目標(biāo)主機(jī)看是否ping得通,三次ping通表示主機(jī)正常運(yùn)行

將目標(biāo)主機(jī)的ip地址作為第一個(gè)參數(shù)傳進(jìn)去

#!/bin/bash
ipaddr=$1
echo${ipaddr}
ping_status(){
ifping-c1${ipaddr}>/dev/null2>&1
then
echo"ping${ipaddr}issuccessful!"
continue
fi
}

foriin$(seq13)
do
ping_status
echo"ping${ipaddr}isfailure!"
done

aca15756-58b2-11ed-a3b6-dac502259ad0.png

進(jìn)階版:對(duì)ip地址池里的主機(jī)分別進(jìn)行心跳檢測(cè)

ipaddr=(192.168.149.131192.168.149.130192.168.149.132192.168.149.133)
foriin${ipaddr[*]}
do
echo"....begintoping${i}....."
ifping-c3${i}>/dev/null2>&1
then
echo"ping${i}issuccessful!"
else
echo"ping${i}isfailure!"
fi
done

acbc73f6-58b2-11ed-a3b6-dac502259ad0.png

10.系統(tǒng)磁盤內(nèi)存容量告警

根分區(qū)剩余空間小于20%(即使用空間大于80%) 輸出告警信息 內(nèi)存使用空間大于80% 輸出告警信息 配合crond每5分鐘檢查一次

#!/bin/bash
disk_letfspace=$(df-Th|grep-w/|awk'{print$6}'|cut-d%-f1)
mem_used=$(free-m|grepMem|awk'{print$3}')
mem_total=$(free-m|grepMem|awk'{print$2}')
mem_letfspace=$[${mem_used}*100/${mem_total}]
if[${disk_letfspace}-gt80]
then
echo"Diskfreespaceislessthan20%!"
else
echo"${disk_letfspace}%ofdiskspaceleft"
fi
if[${mem_letfspace}-gt80]
then
echo"memoryspaceislessthan20%!"
else
echo"${mem_letfspace}%ofmemoryspaceleft"
fi
crontab-l
*/5****/root/check_space.sh

acc33bbe-58b2-11ed-a3b6-dac502259ad0.png






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11123

    瀏覽量

    207912
  • 磁盤
    +關(guān)注

    關(guān)注

    1

    文章

    355

    瀏覽量

    25093
  • Shell
    +關(guān)注

    關(guān)注

    1

    文章

    359

    瀏覽量

    23192

原文標(biāo)題:【干貨】10個(gè)實(shí)用 Linux Shell 腳本案例

文章出處:【微信號(hào):釋然IT雜談,微信公眾號(hào):釋然IT雜談】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何使用Shell腳本Linux 服務(wù)器尋找攻擊證據(jù)

    使用 Shell 腳本Linux 服務(wù)器上能夠控制、毀壞或者獲取任何東西,通過(guò)一些巧妙的攻擊方法黑客可能會(huì)獲取巨大的價(jià)值,但大多數(shù)攻擊也留下蹤跡。當(dāng)然,這些蹤跡也可通過(guò)
    的頭像 發(fā)表于 10-09 14:24 ?889次閱讀

    步了解并搞懂shell腳本

    Shell腳本并不能作為正式的編程語(yǔ)言,因?yàn)樗窃?b class='flag-5'>Linux的shell中運(yùn)行的,所以稱為shell腳本
    發(fā)表于 12-06 09:03 ?458次閱讀

    Linux Shell腳本入門到實(shí)戰(zhàn)詳解

    Linux Shell腳本入門到實(shí)戰(zhàn)詳解
    發(fā)表于 02-17 15:03 ?576次閱讀

    Linux shell腳本分享

    今天浩道跟大家分享幾個(gè)Linux運(yùn)維中常用到的shell腳本!
    發(fā)表于 07-18 09:53 ?521次閱讀
    <b class='flag-5'>Linux</b> <b class='flag-5'>shell</b><b class='flag-5'>腳本</b>分享

    Linux中常用的Shell腳本示例

    當(dāng)談?wù)?b class='flag-5'>一線運(yùn)維工作中的常用 Shell 腳本時(shí),以下是一些實(shí)用的例子。
    發(fā)表于 09-08 09:42 ?572次閱讀

    如何利用Shell腳本掩藏Linux服務(wù)器使用痕跡

    使用 Shell 腳本Linux 服務(wù)器上能夠控制、毀壞或者獲取任何東西,通過(guò)一些巧妙的攻擊方法黑客可能會(huì)獲取巨大的價(jià)值,但大多數(shù)攻擊也留下蹤跡。當(dāng)然,這些蹤跡也可通過(guò)
    的頭像 發(fā)表于 02-13 13:21 ?3233次閱讀

    如何創(chuàng)建和執(zhí)行個(gè)簡(jiǎn)單的Linux shell腳本

     如果您愿意要嘗試更長(zhǎng)的shell腳本,請(qǐng)將下面的shell腳本(并附加為PDF和ODT文件)復(fù)制到文本編輯器中,保存,使其可執(zhí)行并運(yùn)行。當(dāng)您了解更多
    的頭像 發(fā)表于 11-06 17:28 ?1.3w次閱讀

    Linux shell腳本經(jīng)驗(yàn)分享

    作為Linux嵌入式程序猿,寫shell腳本也是經(jīng)常碰到的工作,在這個(gè)過(guò)程中或多或少踩過(guò)一些坑,也積累了
    的頭像 發(fā)表于 04-04 17:28 ?1716次閱讀
    <b class='flag-5'>Linux</b> <b class='flag-5'>shell</b><b class='flag-5'>腳本</b>經(jīng)驗(yàn)分享

    Linux系統(tǒng)命令及shell腳本實(shí)踐指南

    Linux系統(tǒng)命令及shell腳本實(shí)踐指南資料下載。
    發(fā)表于 06-01 14:47 ?28次下載

    文剖析隱藏shell腳本內(nèi)容的工具shc

    從事 Linux 開發(fā)的同學(xué),經(jīng)常需要編寫 shell 腳本,有時(shí)腳本中會(huì)涉及到一些敏感內(nèi)容,比如一些
    的頭像 發(fā)表于 08-14 10:44 ?2025次閱讀
    <b class='flag-5'>一</b>文剖析隱藏<b class='flag-5'>shell</b><b class='flag-5'>腳本</b>內(nèi)容的工具shc

    34個(gè)Linux Shell腳本匯總

    作為Linux 工程師,會(huì)寫好的腳本不僅能提高工作效率,還能有更多的時(shí)間做自己的事。最近在網(wǎng)上沖浪的時(shí)候,也注意收集一些大佬寫過(guò)的腳本
    的頭像 發(fā)表于 01-06 10:25 ?1336次閱讀

    Linux命令行與shell腳本編寫

    Linux命令行與shell腳本編寫
    發(fā)表于 01-11 16:50 ?4次下載

    通過(guò)Shell腳本掩蓋Linux系統(tǒng)上的操作痕跡

    使用 Shell 腳本Linux 服務(wù)器上能夠控制、毀壞或者獲取任何東西,通過(guò)一些巧妙的攻擊方法黑客可能會(huì)獲取巨大的價(jià)值,但大多數(shù)攻擊也留下蹤跡。
    的頭像 發(fā)表于 04-03 10:43 ?466次閱讀

    使用Shell腳本掩蓋Linux上的操作痕跡

    使用 Shell 腳本Linux 服務(wù)器上能夠控制、毀壞或者獲取任何東西,通過(guò)一些巧妙的攻擊方法黑客可能會(huì)獲取巨大的價(jià)值,但大多數(shù)攻擊也留下蹤跡。
    的頭像 發(fā)表于 05-23 09:15 ?544次閱讀
    使用<b class='flag-5'>Shell</b><b class='flag-5'>腳本</b>掩蓋<b class='flag-5'>Linux</b>上的操作痕跡

    Linux Shell腳本經(jīng)典案例分享

    ? 作為Linux 運(yùn)維工程師,會(huì)寫好的腳本不僅能提高工作效率,還能有更多的時(shí)間做自己的事。最近在網(wǎng)上沖浪的時(shí)候,發(fā)現(xiàn)大家對(duì)Shell腳本
    發(fā)表于 06-16 14:03 ?588次閱讀
    <b class='flag-5'>Linux</b> <b class='flag-5'>Shell</b><b class='flag-5'>腳本</b>經(jīng)典案例分享