shell知识

简介:
脚本的执行方法:5种
绝对路径:#/home/shell/shell.sh
相对路径:#../shell.sh
$PATH中:#shell.sh
bash命令:#bash shell.sh
source命令(简写"."):#. shell.sh
脚本的书写:
第一行:#!/bin/bash   #!叫shabang header
文件头:
    脚本名、作者、联系方式、日期、changelog
定义变量:
    PATH、LANG、自定义变量
定义函数:
主程序:
    返回值
返回值:
代表程序(指令、语句)的执行情况。
父进程负责收集子进程的返回值。
0    成功
非0  失败
    2   用法错误
    126 没权限
    127 命令没找到
定义方法:
exit N
return N
查看方法:只能常上一个程序。
#echo $?
变量:
保存数据的一种形式,在内存中分配的位置。
变量名:
字母或下划线开头,后面更随字母数字或下划线。
#echo $PATH
 显示   变量名
变量的定义(赋值):
变量名=值     =两边不能空格、不要用$
#A=123
#echo $A
#unset A   退出终端也行
#A=/etc/*.conf
#echo $A
间接引用:
#A=B
#B=helloworld
#echo ${!A}   #eval echo \$$A
全局变量:
#A=helloword
#export A
#export
#bash
#echo $A
helloword
#exit
#export -n A
#export | head -n 5
想永久生效的话,写配置文件/etc/[bashrc|profile]。
内部变量:
PPID  父进程的PID
UID   当前用户UID
EUID  有效用户UID
BASH  bash二进制文件的路径
BASH_VERSION  bash版本信息
SHELL  登录shell的绝对路径
SHELLOPTS  当前shell启用的选项
EDITOR  默认编辑器
USER/LOGNAME   用户名/登录名
HOME  用户主目录
PWD   当前目录
HOSTNAME  主机名
MACHTYPE/OSTYPE  机器类型/系统类型
PATH  可执行文件的搜索路径
#PATH=$PATH:/root/bin
#export PATH
REPLY    输入数据的默认存储变量
SECONDS  脚本运行时间
RANDOM   随机数0-32767   #echo $(($RANDOM%100))  1-100之间的随机数
PS1  第一提示符
PS2  第二提示符
$?  上一个命令的返回值
$$  当前进程的PID
$!  最近一个后台进程的PID
$0  脚本名字
$1...$N  脚本的第1个参数
$#  参数的个数
$@  所有参数,一个一个的。"A" "B"
"$@"  所有参数,一个一个的。
$*  所有参数,一个一个的。
"$*"  所有参数,一个字符串。"A B"
#!bin/bash
echo "input something..."
read
echo $REPLY
echo '$0='$0
echo '$1='$1
echo '$10='${10}    位置变量大于10、数组、间接引用
echo '$#='$#
echo  " $*=""$*"
bash的操作环境:
env  环境变量
set
-f 关闭路径替换
-n 读取脚本但是不执行
-e 遇到错误立刻停止
-x 打印命令替换(debug)   #!/bin/bash -x
-v 打印读取的命令
stty
declare声明变量
-i 整型
-x 环境变量
-a 数组
-r 只读变量
bash中的数组:
两个相关联的变量组成数组
array[index/key]=value
数组名   下标       元素
数组的赋值:
#array[0]=hello ; array[1]=world ; array[3]=again
#arry=(hello [4]=world [6]=again again)
数组的取值:
#echo ${array[0]}
#array=(one two there four five)
#echo ${array[0]}   第一个元素的值
#echo ${array[0]:1}  第一个元素的值,从第二个字母开始显示。
#echo ${array[@]}  全部元素的值
#echo ${array[*]}  全部元素的值
#echo ${#array[0]}  第一个元素的值的长度
#echo ${#array[@]}  数组中所有元素的个数
#echo ${array[@]#f*r}  从左向右最短匹配,删除
#echo ${array[@]##t*e}  从左向右最长匹配,删除
#echo ${array[@]%h*e}  从右向左最短匹配,删除
#echo ${array[@]%%t*e}  从右向左最长匹配,删除
变量的各种操纵方法:
参数替换:
${变量名-值}
${var-default}  #如果变量var没有被声明,那么default就是变量var的值。
${var:-default}  #如果变量var没有被赋值,那么default就是变量var的值。
#!/bin/bash
#var=
echo "${var-notdefine}"
echo "${var:-isnull}"
${var=default}
${var:=default}
${var+default}
${var:+default}
${var?default}
${var:?default}
变量替换:
${#var}  变量内容的长度
${var#string}  从左向右最短匹配,删除
${var##string}  从左向右最长匹配,删除
${var%string}  从右向左最短匹配,删除
${var%%string}  从右向左最长匹配,删除
#!/bin/bash
stringX=abcABC123ABCabc
echo $stringX
echo ${stringX#a*C}
echo ${stringX##a*C}
echo ${stringX%b*c}
echo ${stringX%%b*c}
#!/bin/bash
echo $0
echo ${0##*/}  保留脚本名
echo $(basename /home/shell/shell.sh)  保留脚本名
echo $MAIL
echo ${MAIL##/*/}  只保留用户名
echo ${MAIL%$USER}  只保留路径
大括号替换:
#touch file{4,9}
#touch file{0..9}
#cp /etc/fstab{,.bak}
算术替换:
#echo $((1+ 6 ))
#echo $[1+6]
+ - * / % ()
#SUM=`bc <<<"1+7"`
#echo $SUM
命令替换:
`command`
$(command)
#rpm -qf `which httpd`  httpd命令是哪个软件包安装的?
各种比较:
test(简写"[","]")命令
文件类型:#test -e filename   #[ -e filename ]
-e 是否存在
-f 是否为文件
-d 是否为目录
-b 是否为块设备
-c 是否为字符设备
-S 是否为socket文件
-p 是否为管道
-L 是否为连接
文件权限:
-r
-w
-x
-u 是否有SUID
-g 是否有SGID
-k 是否有Sticky bit
-s 是否非空
两个文件之间:#test file1 -nt file2
-nt file1是否比file2新
-ot file1是否比file2旧
-ef 两个文件是否相同
整数之间:
-eq 相等
-ne 不等
-gt 大于
-lt 小于
-ge 大于等于
-le 小于等于
字符、字符串之间:
-z 是否空
-n 是否非空
== 相同
!= 不同
其他:#test -r file1 -a -x file1   #test ! -e file1
-a 逻辑于
-o 逻辑或
!   非(取反)
例:
test.sh

各种杂项:
echo:
#echo -ne "hello\tworld\n"
read:
-p   显示提示信息   #read -p "Input filename:" FN
-t   超时时间
-n 1 按任意键继续
sleep/wait:   #sleep 5
exit/return:
:
bc:  #bc <<<"1+7"
seq: #seq 6   #seq 2 6  #seq 1 2 9

各种语句:
if:
if CONDITION
then
  COMMAND
fi
if CONDITION
then
  COMMAND1
else
  COMMAND2
fi
if CONDITION1
then
  COMMAND1
elif CONDITION2
  then
  COMMAND2
else
  COMMAND3
fi
例:
#!/bin/bash
if [ -d $1 ] ; then
  echo "$1 is directory."
elif [ -x $1 ] ; then
  echo "$1 is a scripts."
elif [ -f $1 ] ; then
  echo "$1 is a file."
else
  echo "Unknown."
fi
例子:
有木有.sh
例子:
计算闰年
leapyear.sh
for:
for VAR in LIST
do
  COMMANDS
done
LIST的写法:
直接写:  for i in 1 2 3
大括号扩展:for i in {0..99}
通配符:for i in /etc/*.conf
命令的结果:for i in `find /etc/ -name "*.conf"`
C风格:for ((i=0;i<10;i=i+1))
练:
#!/bin/bash
for A in $@ ; do
  echo '$@='$A
done
for B in "$@" ; do
  echo '" $@"='$B
done
for C in $* ; do
  echo '$*='$C
done
for D in "$*" ; do
  echo '"$*"='$D
done
for i in ${array[@]} ; do
  echo $i
done
例:
9*9.sh
#!/bin/bash
for i in {1..9} ; do
  for n in `seq 1 $i` ; do
    echo -ne "$i*$n=$(($i*$n))"
  done
  echo
done
ping.sh
方法一:
#!/bin/bash
for i in {252..254} ; do
  ping -c1 192.168.18.$i &> /dev/null
  if [ "$?" == "0" ] ; then
    echo "192.168.18.$i online."
  else
    echo "192.168.18.$i offline."
  fi
done
方法二:
for i in {252..254} ; do
  if ping -c1 192.168.18.$i &> /dev/null ; then
    echo "192.168.18.$i online."
  else
    echo "192.168.18.$i offline."
  fi
done
方法三:
for i in {252..254} ; do
  result=`ping -c1 192.168.18.$i | grep ttl | cut -d "=" -f 2 | cut -d " " -f 2`
  if [ "$result" == "ttl" ] ; then
    echo "192.168.18.$i online."
  else
    echo "192.168.18.$i offline."
  fi
done
mssh.sh
#!/bin/bash
#mssh.sh "IP1 IP2"  "service iptables stop"
for i in $1 ; do
  ssh $i $2
done
监控磁盘
#!/bin/bash
for space in `LANG=C df -h | grep -v Use | awk '{print $5}' | cut -d "%" -f 1`
do
  if [ $space -get 80 ] ; then
    echo "Over 80%" | mail -s "report"  root@localhost
  else
    echo "Disk space normail" | mail -s "report"  root@localhost
  fi
done
while:#true #false
while CONTROL-COMMAND
do
  CONSEQUENT-COMMANDS
done
例:
#!/bin/bash
i=0
while [ $i -lt 4 ] ; do
  echo $i
  i=$[$i+1]
done
until:
until CONTROL-COMMAND
do
  CONSEQUENT-COMMANDS
done
例:
#!/bin/bash
num=1
until [ ! "$num" -le 5 ] ; then
do
  echo "$num"
  num=$(($num+1))
done
练:
监控httpd是否运行,没运行的话尝试重启并发邮件报警。
#!/bin/bash
process=httpd
while true ; do
  #result=`pstree | grep $process`
  pstree | grep $process &> /dev/null
  if [ $? -eq 0 ] ; then
    echo "$process is running." | mail -s "report"  root@localhost
  else
    echo "$process NOT running." | mail -s "report"  root@localhost
  fi
  sleep 600
done
case

break continue
shift

函数
autoinstall.sh
 

本文转自zhaoyun00 51CTO博客,原文链接:http://blog.51cto.com/zhaoyun/747166

相关文章
|
Shell Windows 分布式数据库
|
2月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
110 1
|
1月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
63 2
6种方法打造出色的Shell脚本
|
1月前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
59 1
|
1月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
49 2
|
2月前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
57 6
|
1月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
82 12
|
2月前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
72 2