分享运维日常实用shell脚本

1、用户权限检查脚本

#!/bin/bash

# 检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不

# 是,则提示您非管理员(使用字串对比版本)

if [ $USER == "root" ]

then

yum ‐y install vsftpd

else

echo "您不是管理员,没有权限安装软件"

fi

-----------------------------------------------

#!/bin/bash

# 检测本机当前用户是否为超级管理员,如果是管理员,则使用 yum 安装 vsftpd,如果不

# 是,则提示您非管理员(使用 UID 数字对比版本)

if [ $UID -eq 0 ];then

yum ‐y install vsftpd

else

echo "您不是管理员,没有权限安装软件"

fi

批量创建用户及密码脚本


#!/bin/bash

# 编写脚本:提示用户输入用户名和密码,脚本自动创建相应的账户及配置密码。如果用户

# 不输入账户名,则提示必须输入账户名并退出脚本;如果用户不输入密码,则统一使用默

# 认的 123456 作为默认密码。


read -p "请输入用户名: " user

#使用‐z 可以判断一个变量是否为空,如果为空,提示用户必须输入账户名,并退出脚本,退出码为 2

#没有输入用户名脚本退出后,使用$?查看的返回码为 2

if [ -z $user ];then

echo "您不需输入账户名"

exit 2

fi

#使用 stty ‐echo 关闭 shell 的回显功能

#使用 stty echo 打开 shell 的回显功能

stty -echo

read -p "请输入密码: " pass

stty echo

pass=${pass:‐123456}

useradd "$user"

echo "$pass" | passwd ‐‐stdin "$user"

KVM虚拟机一键克隆脚本

#!/bin/bash

# 编写脚本快速克隆 KVM 虚拟机


# 本脚本针对 RHEL7.2 或 Centos7.2

# 本脚本需要提前准备一个 qcow2 格式的虚拟机模板,

# 名称为/var/lib/libvirt/images /.rh7_template 的虚拟机模板

# 该脚本使用 qemu‐img 命令快速创建快照虚拟机

# 脚本使用 sed 修改模板虚拟机的配置文件,将虚拟机名称、UUID、磁盘文件名、MAC 地址

# exit code:

# 65 ‐> user input nothing

# 66 ‐> user input is not a number

# 67 ‐> user input out of range

# 68 ‐> vm disk image exists


IMG_DIR=/var/lib/libvirt/images

BASEVM=rh7_template

read -p "Enter VM number: " VMNUM

if [ $VMNUM -le 9 ];then

VMNUM=0$VMNUM

fi


if [ -z "${VMNUM}" ]; then

echo "You must input a number."

exit 65

elif [[ ${VMNUM} =~ [a‐z] ]; then

echo "You must input a number."

exit 66

elif [ ${VMNUM} -lt 1 -o ${VMNUM} -gt 99 ]; then

echo "Input out of range"

exit 67

fi


NEWVM=rh7_node${VMNUM}


if [ -e $IMG_DIR/${NEWVM}.img ]; then

echo "File exists."

exit 68

fi


echo -en "Creating Virtual Machine disk image......\t"

qemu‐img create -f qcow2 ‐b $IMG_DIR/.${BASEVM}.img $IMG_DIR/${NEWVM}.img &> /dev/null


echo -e "\e[32;1m[OK]\e[0m"


#virsh dumpxml ${BASEVM} > /tmp/myvm.xml

cat /var/lib/libvirt/images/.rhel7.xml > /tmp/myvm.xml

sed -i "/<name>${BASEVM}/s/${BASEVM}/${NEWVM}/" /tmp/myvm.xml

sed -i "/uuid/s/<uuid>.*<\/uuid>/<uuid>$(uuidgen)<\/uuid>/" /tmp/myvm.xml

sed -i "/${BASEVM}\.img/s/${BASEVM}/${NEWVM}/" /tmp/myvm.xml


# 修改 MAC 地址,本例使用的是常量,每位使用该脚本的用户需要根据实际情况修改这些值

# 最好这里可以使用便利,这样更适合于批量操作,可以克隆更多虚拟机

sed -i "/mac /s/a1/0c/" /tmp/myvm.xml


echo -en "Defining new virtual machine......\t\t"

virsh define /tmp/myvm.xml &> /dev/null

echo -e "\e[32;1m[OK]\e[0m"

shell排序训练


#!/bin/bash

# 依次提示用户输入 3 个整数,脚本根据数字大小依次排序输出 3 个数字

read -p "请输入一个整数:" num1

read -p "请输入一个整数:" num2

read -p "请输入一个整数:" num3

# 不管谁大谁小,最后都打印 echo "$num1,$num2,$num3"

# num1 中永远存最小的值,num2 中永远存中间值,num3 永远存最大值

# 如果输入的不是这样的顺序,则改变数的存储顺序,如:可以将 num1 和 num2 的值对调

tmp=0

# 如果 num1 大于 num2,就把 num1 和和 num2 的值对调,确保 num1 变量中存的是最小值

if [ $num1 -gt $num2 ];then

tmp=$num1

num1=$num2

num2=$tmp

fi

# 如果 num1 大于 num3,就把 num1 和 num3 对调,确保 num1 变量中存的是最小值

if [ $num1 -gt $num3 ];then

tmp=$num1

num1=$num3

num3=$tmp

fi

# 如果 num2 大于 num3,就把 num2 和 num3 对标,确保 num2 变量中存的是小一点的值

if [ $num2 -gt $num3 ];then

tmp=$num2

num2=$num3

num3=$tmp

fi

echo "排序后数据(从小到大)为:$num1,$num2,$num3"

测试服务器网络


#!/bin/bash

# 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机

# 状态(for 版本)

for i in {1..254}

do

# 每隔0.3秒ping一次,一共ping2次,并以1毫秒为单位设置ping的超时时间

ping ‐c 2 ‐i 0.3 ‐W 1 192.168.4.$i &>/dev/null

if [ $? -eq 0 ];then

echo "192.168.4.$i is up"

else

echo "192.168.4.$i is down"

fi

done

===========================================

#!/bin/bash

# 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机

# 状态(while 版本)

i=1

while [ $i -le 254 ]

do

ping ‐c 2 ‐i 0.3 ‐W 1 192.168.4.$i &>/dev/null

if [ $? -eq 0 ];then

echo "192.168.4.$i is up"

else

echo "192.168.4.$i is down"

fi

let i++

done

===============================================

#!/bin/bash

# 编写脚本测试 192.168.4.0/24 整个网段中哪些主机处于开机状态,哪些主机处于关机

# 状态(多进程版)


#定义一个函数,ping 某一台主机,并检测主机的存活状态

myping(){

ping ‐c 2 ‐i 0.3 ‐W 1 $1 &>/dev/null

if [ $? -eq 0 ];then

echo "$1 is up"

else

echo "$1 is down"

fi

}

for i in {1..254}

do

myping 192.168.4.$i &

done

# 使用&符号,将执行的函数放入后台执行

# 这样做的好处是不需要等待ping第一台主机的回应,就可以继续并发ping第二台主机,依次类推。

执行任务进度条显示

#!/bin/bash

# 编写脚本,显示进度条

jindu(){

while :

do

echo -n '#'

sleep 0.2

done

}

jindu &

cp -a $1 $2

killall $0

echo "拷贝完成"

==================================================

#!/bin/bash

# 进度条,动态时针版本

# 定义一个显示进度的函数,屏幕快速显示| / ‐ \

rotate_line(){

INTERVAL=0.5 #设置间隔时间

COUNT="0" #设置4个形状的编号,默认编号为 0(不代表任何图像)

while :

do

COUNT=`expr $COUNT + 1` #执行循环,COUNT 每次循环加 1,(分别代表4种不同的形状)

case $COUNT in #判断 COUNT 的值,值不一样显示的形状就不一样

"1") #值为 1 显示‐

echo -e '‐'"\b\c"

sleep $INTERVAL

;;

"2") #值为 2 显示\\,第一个\是转义

echo -e '\\'"\b\c"

sleep $INTERVAL

;;

"3") #值为 3 显示|

echo -e "|\b\c"

sleep $INTERVAL

;;

"4") #值为 4 显示/

echo -e "/\b\c"

sleep $INTERVAL

;;

*) #值为其他时,将 COUNT 重置为 0

COUNT="0";;

esac

done

}

rotate_line

批量修改文件名称或后缀名脚本


#!/bin/bash

# 编写批量修改扩展名脚本,如批量将 txt 文件修改为 doc 文件

# 执行脚本时,需要给脚本添加位置参数

# 脚本名 txt doc(可以将 txt 的扩展名修改为 doc)

# 脚本名 doc jpg(可以将 doc 的扩展名修改为 jpg)


for i in `ls *.$1`

do

mv $i ${i%.*}.$2

done

使用 expect 工具自动交互密码远程其他主机安装 httpd 软件


#!/bin/bash

# 使用 expect 工具自动交互密码远程其他主机安装 httpd 软件


# 删除~/.ssh/known_hosts 后,ssh 远程任何主机都会询问是否确认要连接该主机

rm ‐rf ~/.ssh/known_hosts

expect <<EOF

spawn ssh 192.168.4.254

expect "yes/no" {send "yes\r"}

# 根据自己的实际情况将密码修改为真实的密码字串

expect "password" {send "密码\r"}

expect "#" {send "yum ‐y install httpd\r"}

expect "#" {send "exit\r"}

EOF

一键源码安装LNMP


#!/bin/bash

# 一键部署 LNMP(源码安装版本)

menu()

{
clear

echo " ##############‐‐‐‐Menu‐‐‐‐##############"

echo "# 1. Install Nginx"

echo "# 2. Install MySQL"

echo "# 3. Install PHP"

echo "# 4. Exit Program"

echo " ########################################"

}


choice()

{

read -p "Please choice a menu[1‐9]:" select

}


install_nginx()

{

id nginx &>/dev/null

if [ $? -ne 0 ];then

useradd -s /sbin/nologin nginx

fi

if [ -f nginx‐1.8.0.tar.gz ];then

tar -xf nginx‐1.8.0.tar.gz

cd nginx‐1.8.0

yum -y install gcc pcre‐devel openssl‐devel zlib‐devel make

./configure ‐‐prefix=/usr/local/nginx ‐‐with‐http_ssl_module

make

make install

ln -s /usr/local/nginx/sbin/nginx /usr/sbin/

cd ..

else

echo "没有 Nginx 源码包"

fi

}


install_mysql()

{

yum -y install gcc gcc‐c++ cmake ncurses‐devel perl

id mysql &>/dev/null

if [ $? -ne 0 ];then

useradd -s /sbin/nologin mysql

fi

if [ -f mysql‐5.6.25.tar.gz ];then

tar -xf mysql‐5.6.25.tar.gz

cd mysql‐5.6.25

cmake .

make

make install

/usr/local/mysql/scripts/mysql_install_db ‐‐user=mysql ‐‐datadir=/usr/local/mysql/data/

‐‐basedir=/usr/local/mysql/

chown -R root.mysql /usr/local/mysql

chown -R mysql /usr/local/mysql/data

/bin/cp -f /usr/local/mysql/support‐files/mysql.server /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

/bin/cp -f /usr/local/mysql/support‐files/my‐default.cnf /etc/my.cnf

echo "/usr/local/mysql/lib/" >> /etc/ld.so.conf

ldconfig

echo 'PATH=\$PATH:/usr/local/mysql/bin/' >> /etc/profile

export PATH

else

echo "没有 mysql 源码包"

exit

fi

}


install_php()

{

#安装 php 时没有指定启动哪些模块功能,如果的用户可以根据实际情况自行添加额外功能如‐‐with‐gd 等

yum -y install gcc libxml2‐devel

if [ -f mhash‐0.9.9.9.tar.gz ];then

tar -xf mhash‐0.9.9.9.tar.gz

cd mhash‐0.9.9.9

./configure

make

make install

cd ..

if [ ! ‐f /usr/lib/libmhash.so ];then

ln -s /usr/local/lib/libmhash.so /usr/lib/

fi

ldconfig

else

echo "没有 mhash 源码包文件"

exit

fi

if [ -f libmcrypt‐2.5.8.tar.gz ];then

tar -xf libmcrypt‐2.5.8.tar.gz

cd libmcrypt‐2.5.8

./configure

make

make install

cd ..

if [ ! -f /usr/lib/libmcrypt.so ];then

ln -s /usr/local/lib/libmcrypt.so /usr/lib/

fi

ldconfig

else

echo "没有 libmcrypt 源码包文件"

exit

fi

if [ -f php‐5.4.24.tar.gz ];then

tar -xf php‐5.4.24.tar.gz

cd php‐5.4.24

./configure ‐‐prefix=/usr/local/php5 ‐‐with‐mysql=/usr/local/mysql ‐‐enable‐fpm ‐‐

enable‐mbstring ‐‐with‐mcrypt ‐‐with‐mhash ‐‐with‐config‐file‐path=/usr/local/php5/etc ‐‐with‐

mysqli=/usr/local/mysql/bin/mysql_config

make && make install

/bin/cp -f php.ini‐production /usr/local/php5/etc/php.ini

/bin/cp -f /usr/local/php5/etc/php‐fpm.conf.default /usr/local/php5/etc/php‐fpm.conf

cd ..

else

echo "没有 php 源码包文件"

exit

fi

}


while :

do

menu

choice

case $select in

1)

install_nginx

;;

2)

install_mysql

;;

3)

install_php

;;

4)

exit

;;

*)

echo Sorry!

esac

done

发表评论

滚动至顶部