Shell腳本實(shí)現(xiàn)自動(dòng)修改IP、主機(jī)名等功能分享
作為一名Linux SA,日常運(yùn)維中很多地方都會(huì)用到腳本,而服務(wù)器的ip一般采用靜態(tài)ip或者M(jìn)AC綁定,當(dāng)然后者比較操作起來(lái)相對(duì)繁瑣,而前者我們可以設(shè)置主機(jī)名、ip信息、網(wǎng)關(guān)等配置。修改成特定的主機(jī)名在維護(hù)和管理方面也比較方便。如下腳本用途為:修改ip和主機(jī)名等相關(guān)信息,可以根據(jù)實(shí)際需求修改,舉一反三!
#!/bin/sh
#auto Change ip netmask gateway scripts
#wugk 2012-12-17
cat <<EOF
++++++++自動(dòng)修改ip和主機(jī)名等相關(guān)信息+++++++++
ETHCONF=/etc/sysconfig/network-scripts/ifcfg-eth0
HOSTS=/etc/hosts
NETWORK=/etc/sysconfig/network
DIR=/data/backup/`date +%Y%m%d`
NETMASK=255.255.255.0
+++++++++-------------------------+++++++++++
EOF
#Define Path 定義變量,可以根據(jù)實(shí)際情況修改
ETHCONF=/etc/sysconfig/network-scripts/ifcfg-eth0
HOSTS=/etc/hosts
NETWORK=/etc/sysconfig/network
DIR=/data/backup/`date +%Y%m%d`
NETMASK=255.255.255.0
echo "================================================"
echo
#定義change_ip函數(shù)
function Change_ip ()
{
#判斷備份目錄是否存在,中括號(hào)前后都有空格,!嘆號(hào)在shell表示相反的意思#
if
[ ! -d $DIR ];then
mkdir -p $DIR
fi
echo "Now Change ip address ,Doing Backup Interface eth0"
cp $ETHCONF $DIR
grep "dhcp" $ETHCONF
#如下$?用來(lái)判斷上一次操作的狀態(tài),為0,表示上一次操作狀態(tài)正確或者成功#
if
[ $? -eq 0 ];then
#read -p 交互輸入變量IPADDR,注冒號(hào)后有空格,sed -i 修改配置文件#
read -p "Please insert ip Address:" IPADDR
sed -i 's/dhcp/static/g' $ETHCONF
#awk -F. 意思是以.號(hào)為分隔域,打印前三列#
echo -e "IPADDR=$IPADDR\nNETMASK=$NETMASK\nGATEWAY=`echo $IPADDR|awk -F. '{print $1"."$2"."$3}'`.254" >>$ETHCONF
echo "This IP address Change success !"
else
echo -n "This $ETHCONF is static exist ,please ensure Change Yes or NO":
read i
fi
if
[ "$i" == "y" -o "$i" == "yes" ];then
read -p "Please insert ip Address:" IPADDR
count=(`echo $IPADDR|awk -F. '{print $1,$2,$3,$4}'`)
#定義數(shù)組, ${#count[@]}代表獲取變量值總個(gè)數(shù)#
A=${#count[@]}
#while條件語(yǔ)句判斷,個(gè)數(shù)是否正確,不正確循環(huán)提示輸入,也可以用[0-9]來(lái)判斷ip#
while
[ "$A" -ne "4" ]
do
read -p "Please re Inster ip Address,example 192.168.0.11 ip": IPADDR
count=(`echo $IPADDR|awk -F. '{print $1,$2,$3,$4}'`)
A=${#count[@]}
done
#sed -e 可以連續(xù)修改多個(gè)參數(shù)#
sed -i -e 's/^IPADDR/#IPADDR/g' -e 's/^NETMASK/#NETMASK/g' -e 's/^GATEWAY/#GATEWAY/g' $ETHCONF
#echo -e \n為連續(xù)追加內(nèi)容,并自動(dòng)換行#
echo -e "IPADDR=$IPADDR\nNETMASK=$NETMASK\nGATEWAY=`echo $IPADDR|awk -F. '{print $1"."$2"."$3}'`.254" >>$ETHCONF
echo "This IP address Change success !"
else
echo "This $ETHCONF static exist,please exit"
exit $?
fi
}
#定義hosts函數(shù)
############function hosts##############
function Change_hosts ()
{
if
[ ! -d $DIR ];then
mkdir -p $DIR
fi
cp $HOSTS $DIR
read -p "Please insert ip address": IPADDR
host=`echo $IPADDR|sed 's/\./-/g'`
cat $HOSTS |grep 127.0.0.1 |grep "$host"
if
[ $? -ne 0 ];then
sed -i "s/127.0.0.1/127.0.0.1 $host/g" $HOSTS
echo "This hosts change success "
else
echo "This $host IS Exist .........."
fi
}
###########fuction network###############
#定義network函數(shù)
function Change_network ()
{
if
[ ! -d $DIR ];then
mkdir -p $DIR
fi
cp $NETWORK $DIR
read -p "Please insert ip address": IPADDR
host=`echo $IPADDR|sed 's/\./-/g'`
grep "$host" $NETWORK
if
[ $? -ne 0 ];then
sed -i "s/^HOSTNAME/#HOSTNAME/g" $NETWORK
echo "NETWORK=$host" >>$NETWORK
else
echo "This $host IS Exist .........."
fi
}
#PS3一般為菜單提示信息#
PS3="Please Select ip or hosts Menu":
#select為菜單選擇命令,格式為select $var in ..command.. do .... done
select i in "Change_ip" "Change_hosts" "Change_network"
do
#case 方式,一般用于多種條件下的判斷
case $i in
Change_ip )
Change_ip
;;
Change_hosts )
Change_hosts
;;
Change_network )
Change_network
;;
*)
echo
echo "Please Insert $0: Change_ip(1)|Change_hosts(2)|Change_network(3)"
echo
;;
esac
done
- 阿里云主機(jī)一鍵安裝lamp、lnmp環(huán)境的shell腳本分享
- NTFS權(quán)限設(shè)置以避免通過(guò)webshell遍歷主機(jī)目錄
- nginx虛擬主機(jī)防webshell完美版
- shell腳本實(shí)現(xiàn)批量測(cè)試局域網(wǎng)主機(jī)是否在線
- 虛擬主機(jī)封殺webshell提權(quán)!!!!!!!!!!
- 使用PowerShell獲取當(dāng)前主機(jī)內(nèi)存使用量和總量的方法
- PowerShell腳本實(shí)現(xiàn)檢測(cè)網(wǎng)絡(luò)內(nèi)主機(jī)類型
- php管理nginx虛擬主機(jī)shell腳本實(shí)例
- Shell交互批量更改主機(jī)名的方法
相關(guān)文章
linux環(huán)境下編寫shell腳本實(shí)現(xiàn)啟動(dòng)停止tomcat服務(wù)的方法
這篇文章主要介紹了linux環(huán)境下編寫shell腳本實(shí)現(xiàn)啟動(dòng)停止tomcat服務(wù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06Linux使用iptables實(shí)現(xiàn)屏蔽ip地址的示例詳解
netfilter/iptables(簡(jiǎn)稱為iptables)組成Linux平臺(tái)下的包過(guò)濾防火墻,與大多數(shù)的Linux軟件一樣,這個(gè)包過(guò)濾防火墻是免費(fèi)的。本文就來(lái)利用iptables實(shí)現(xiàn)屏蔽ip地址,需要的可以參考一下2022-10-10使用Bash Shell對(duì)目錄中的文件實(shí)現(xiàn)遞歸式拷貝
這篇文章主要介紹了使用Bash Shell對(duì)目錄中的文件實(shí)現(xiàn)遞歸式拷貝,適用于Ubuntu等Debian系的Linux系統(tǒng),需要的朋友可以參考下2015-07-07一個(gè)強(qiáng)大的網(wǎng)絡(luò)分析shell腳本分享(實(shí)時(shí)流量、連接統(tǒng)計(jì))
這篇文章主要介紹了一個(gè)強(qiáng)大的網(wǎng)絡(luò)分析shell腳本分享,此腳本包含實(shí)時(shí)流量統(tǒng)計(jì)、連接統(tǒng)計(jì)強(qiáng)大功能,需要的朋友可以參考下2014-12-12詳解Linux中atime,mtime,ctime的使用場(chǎng)景
這篇文章主要介紹了Linux的三個(gè)時(shí)間atime,mtime,ctime詳細(xì)說(shuō)明與使用場(chǎng)景,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以跟隨小編一起了解一下2022-10-10linux下解決?git?clone每次都要輸入用戶名密碼問(wèn)題(推薦)
這篇文章主要介紹了linux下解決?git?clone每次都要輸入用戶名密碼問(wèn)題,先用git?config?--global?user.name?'username’和git?config?--global?user.email?'xxx@xxx.com’配置一下用戶名和郵箱,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10Shell之function函數(shù)的定義及調(diào)用示例
本文主要介紹了Shell之function函數(shù)的定義及調(diào)用示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08