shell是一個命令行解釋器,它爲用戶提供了一個向 Linux 內核發送請求以便運行程序的系統級程序mysql
#!/bin/bash echo 'hello world'
代碼解釋:sql
1.#!/bin/bash:shell
告訴計算機,使用bash解釋器來執行代碼數據庫
2.echo:編程
控制檯輸出bash
給腳本可執行權限函數
chmod 744 myshell.sh
而後直接運行腳本命令行
./myshell.sh
直接調用shell解釋器執行設計
sh myshell.sh
#內容
:<<! 內容 !
1.Linux中變量的分類:系統變量 自定義變量 2.系統變量: $PATH $HOME $PWD $SHELL $USER 3.顯示當前shell中全部的變量:set
1.定義變量:變量名=變量值 2.撤銷變量:unset 變量名 3.聲明靜態變量:readonly 變量名. 靜態變量不能unset
1.定義變量a 2.撤銷變量a 3.聲明靜態變量b=2,嘗試unset撤銷
1.變量名稱能夠由字母、數字和下劃線組成,可是不能以數字開頭 2.等號兩側不能有空格 3.變量名稱通常習慣爲大寫
1.A=`ls -la` 反引號,運行裏面的命令,並把結果返回給變量 A 2.A=$(ls -la) 等價於反引號
1.export 變量名=變量值 將shell變量輸出給環境變量 2.source 配置文件 讓修改後的配置信息當即生效 3.echo $變量值 查看環境變量的值
1.在/etc/profile文件中定義MY_NAME環境變量 2.查看環境變量MY_NAME的值 強調:在使用MY_NAME前,須要讓其生效 3.source /etc/profile 4,在另一個shell程序中使用MY_NAME
當咱們執行一個 shell
腳本時,若是但願獲取到命令行的參數信息,就能夠使用到位置參數變量code
1. $n (功能描述:n 爲數字,$0 表明命令自己,$1-$9 表明第一到第九個參數,十以上的參數,十以上的參數須要用大 ${10} 括號包含,如${10}) 2. $* (功能描述:這個變量表明命令行中全部的參數,$*把全部的參數當作一個總體) 至關於字符串 3. $@ (功能描述:這個變量也表明命令行中全部的參數,不過$@把每一個參數區分對待) 至關於列表 4. $#(功能描述:這個變量表明命令行中全部參數的個數)
編寫一個shell腳本,pasition.sh,在腳本中獲取到命令行的各個參數信息 age=$1 age1=$2 echo "$age" echo "$age1" 執行命令: bash pasition.sh 1 2 # 1和2爲第一個和第二個參數
就是 shell 設計者事先已經定義好的變量,能夠直接在
shell 腳本中使用
$$ (功能描述:當前進程的進程號(PID)) $! (功能描述:後臺運行的最後一個進程的進程號(PID)) $? (功能描述:最後一次執行的命令的返回狀態。若是這個變量的值爲 0,證實上一個命令正確執行;若是這個變量的值爲非 0(具體是哪一個數,由命令本身來決定(return)),則證實上一個命令執行失敗)
在一個shell腳本pre.sh中簡單實用一下預約義變量(提示, ./myshell.sh & 後臺運行myshell.sh). echo "$$" echo "$!" echo "$?"
1.$((運算式)) 2.$[運算式] 3.`expr m + n` 特色:運算符之間要有空格 + - / % \* \( \)
寫一個demo.sh完成: 1.3種方式計算(2+3)*4的值 2.方式2求出命令行兩個參數的和
#!/bin/bash res=$(((2*3)*4)) echo "$res" res2=$[(2*3)*4] echo "$res2" res3=`expr \( 2 \* 3 \) \* 4` echo "$res3"
res4=$[$1+$2] echo "$res4" 執行命令 bash demo.sh 123 456
[ 條件 ] 注意:條件先後要有空格 特別的: [ 非空 ] 爲true [ ] 爲false [ haha ] && echo true || echo false
= 判等 != 判不相等
-lt 小於 [ 123 -lt 56 ] && echo true || echo false -le 小於等於 -gt 大於 -ge 大於等於 -eg 等於 -ne 不等於
-r 有讀的權限 [ -r 文件 ] -w 有寫的權限 -x 有執行權限
-f 存在而且是通常文件 [-f 文件] -e 文件存在 -d 存在而且是一個目錄
1.'ok'是否等於'ok' 2.'ok100' 是否等於 'ok'
3.23 是否大於 23 4.23 是否大於等於 23
5./root是否存在 6./root是不是通常文件
if [ 條件 ] then 代碼 fi
if [ 條件 ] then 代碼 else 代碼 fi
if [ 條件 ] then 代碼 elif [ 條件 ] then 代碼 else 代碼 fi
編寫shell腳本,if.sh: 若是輸入參數,大於等於90,優秀,大於等於60,則輸出'及格了',若是小於60,則輸出'不及格' #!/bin/bash if [ $1 -ge 90 ] then echo "優秀" elif [ $1 -ge 60 ] then echo "及格" else echo "不及格" fi
case $變量名 in '值1') 代碼 ;; '值2') 代碼 ;; *) 代碼 都沒命中執行 ;; esac
編寫shell腳本,case.sh: 當命令行參數是1時,輸出'週一';是2時,輸出'週二',其它狀況,輸出'其它' #!/bin/bash case $1 in "1") echo "星期一" ;; "2") echo "星期二" ;; *) echo "其餘" ;; esac
for 變量 in 值1 值2 值3 do 代碼 done
編寫foreach.sh: 打印命令行輸入的參數[這裏能夠看出$* 和$@的區別] $* 打印一次 $@ 遍歷全部 #!/bin/bash for i in "$@" do echo "$i" done
for ((初始值;循環條件;結束語句)) do 代碼 done
編寫for.sh: 從1加到100,並輸出結果 #!/bin/bash for ((i=1;i<=100;i++)) do res=$[$res+$i] done echo "$res"
while [ 條件 ] do 代碼 done
編寫while.sh: 從命令行中輸入一個數n,統計1+...+n的值是多少 #!/bin.bash i=1 res=0 while [ $i -le $1 ] do res=$[$res+$i] i=$[$i+1] done echo "$res"
read 選項 變量 選項: -p:提示信息 -t:等待輸入的時間
編寫input.sh: 1.讀取控制帶輸入的值 read -p "請輸入名字:" name echo "$name" 2.讀取控制檯輸入的值,等待6秒 read -p "請輸入名字:" -t 6 name echo "$name"
basename [pathname] [suffix] 得到路徑最後一部分 若是指定的suffix,那麼會去掉結果中suffix的部分
1.返回/home/aaa/test.txt中'test.txt'的部分 2.返回/home/aaa/test.txt中'test'的部分
dirname [pathname] 得到基礎路徑
1.返回/home/aaa/test.txt中'/home/aaa'的部分
function 函數名(){ #沒有形參 代碼; #參數使用:$1,$2,...,${10}... return xxx; } 調用: 函數名 值1 值2
編寫func.sh: 用函數的形式,計算兩個參數的和 #!/bin/bash function test(){ res=$[$1+$2] echo "$res" } test 130 120
在/root下編寫mysql_db_backup.sh 需求: 1.天天凌晨2點10分,備份數據庫mydb 到/data/backup/db 2.備份開始和備份結束時可以給出提示信息 3.備份後的文件要求以備份時間爲文件名,並打包成.tar.gz的形式,如2019-09-28-044403.tar.gz 4.在備份的同時,檢查是否有10天前的備份文件,若是有就刪除 mysqldump -uroot -p123 --host=localhost 要備份的數據庫名字
#!/bin/bash #備份的路徑 BACKUP=/data/backup/db #當前的時間做爲文件名 DATETIME=$(date +%Y_%m_%d_%H%M%S) echo "=======開始備份======" echo "=====備份的路徑是 $BACKUP/$DATETIME.tar.gz" #主機 HOST=localhost #用戶名 DB_USER=root #密碼 DB_PWD=997997 #備份的數據庫 DATABASE=mydb 若是備份路徑不存在,就建立 [ ! -d "$BACKUP/DATETIME" ] && mkdir -p "$BACKUP/$DATETIME" #執行mysql的備份指令 mysqldump -u$DB_USER -p$DB_PWD --host=$HOST $DATABASE | gzip > $BACKUO/$DATETIME/$DATETIME.sql.gz #打包備份文件 cd $BACKUP tar -zcvf $DATETIME.tar.gz $DATETIME #刪除臨時目錄 rm -rf $BACKUP/$DATETIME #刪除10天前的文件 find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm -rf {} \; echo "=====備份成功+++++"