linux shell指令大全整理

时间:2025-03-26 19:13:30

linux shell指令

shell是一种脚本语言, 需要有编译器执行

  1. bash是linux下默认的shell
  2. sh是unix下默认的shell

在ubuntu中bash和sh都可用

执行

#!/bin/bash
#告诉系统用哪个解释器解释
  1. 通过bash执行, 不需要执行权限
bash 
  1. 设置为可执行文件, 直接执行
chmod +x 
./

变量类型

  1. 局部变量

在脚本中定义, 仅在当前shell中有效, 其他shell不能访问

  1. 环境变量

所有程序, 包括shell启动的程序, 都能访问环境变量, 在c中通过system()函数执行的结果可以通过环境变量传递回来

  1. shell变量

特殊变量, 比如传递给shell的参数

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YEeaQ6cj-1648294508220)(C:\Users\87698\Documents\myMarkdown\linux shell指令.assets\)]

$? 可以获取上一个命令的退出状态。所谓退出状态,就是上一个命令执行后的返回结果。退出状态是一个数字,一般情况下,大部分命令执行成功会返回 0,失败返回 1。

局部变量

# 定义变量, 不能有空格, 对于文本有没有双引号好像都可以
country=china
country="china"
# 数字没有双引号就是数字, 有就是文本
number=100

# 使用变量,可以用{}限定界限
echo "i from ${country} i $number old"

命令替换

转义符

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LawTagIw-1648294508223)(C:\Users\87698\Documents\myMarkdown\linux shell指令.assets\)]

命令替换

用反引号``可以将一个命令的输出给另一个变量

directory=`pwd`
echo $directory

shell运算符

原生bash不支持简单的算术运算, 但是可以通过其他命令来实现, 比如awkexpr,expr是一款表达式计算工具

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-NVnTDVFh-1648294508225)(C:\Users\87698\Documents\myMarkdown\linux shell指令.assets\)]

val=`expr 2 + 2`

通过命令替换将计算结果传给val

字符串

单引号的限制:

  1. 单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的;
  2. 单引号字串中不能出现单引号(对单引号使用转义符后也不行)。

双引号的优点:

  1. 双引号里可以有变量
  2. 双引号里可以出现转义字符

shell的文件包含

Shell 也可以包含外部脚本,将外部脚本的内容合并到当前脚本

. filename
#或
source filename

字符串运算符

用来计算两个字符串是否相等, 假定变量a为"abc",变量b为"efg", 要用[]括号

运算符 说明 举例
= 检测两个字符串是否相等,相等返回 true。 [ $a = $b ] 返回 false。
!= 检测两个字符串是否不相等,不相等返回 true。 [ $a != $b ] 返回 true。
-z 检测字符串长度是否为0,为0返回 true。 [ -z $a ] 返回 false。
-n 检测字符串长度是否不为 0,不为 0 返回 true。 [ -n “$a” ] 返回 true。
$ 检测字符串是否为空,不为空返回 true。 [ $a ] 返回 true。

if-else

注意[]要和里面内容用空格分开, 运算符=两边也要用空格分开

if和[]也要分开, then要另起一行

用fi结尾

a="abc"
b="efg"

if [ $a = $b ]
then
	echo "equal"
else
	echo "no"
fi

if else-if else

-gt判断左边的数字是否大于右边的数字, 不是用>

-lt判断左边是不是小于右边的

==判断两数是否相等

echo要用"", 不然会把 1 的 值 写 入 到 1的值写入到 1a名字的文件里

a=100
if [ $1 -gt $a ]
then
        echo "$1 > $a"
elif [ $1 -lt $a ]
then
        echo "$1 < $a"
else
        echo "$1 = $a"
fi

for循环

穷举法, 或者用{x…y}表示从x到y, 或者用*表示所以可用的

#穷举法
for loop in 1 2 3 4
do
  echo "The value is: $loop"
done

#从0开始的10个,没有10
for i in {0..10}
do
  mkdir dir$i
done

#通配符
for i in /etc/*.conf

#用$()效果和``一样,执行脚本读取返回值
for i in $(cat /root/)        --》从列表文件读取文件名
do
    useradd $i
    echo "123456" | passwd --stdin $i --》通过管道指定密码字串
done

while循环

这边用了两个括号后, 就可以<=号进行判断了, 不知道为什么, 而且还是连着的

而且用了let命令,let 命令是 BASH 中用于计算的工具,用于执行一个或多个表达式,变量计算中不需要加上 $ 来表示变量

#!/bin/bash

let a=5+4
let b=9-3 
echo $a $b
int=1
while(( $int<=5 ))
do
  echo $int
  let "int++"
done

无限循环

用了read命令, 从输入得到一个值到input变量中, 判断是不是y,是则用break跳出循环

while :
do
  echo "input a key:"
  read input
  if [ $input = 'y' ]
  then
    echo "you input y  break"
    break
  else
    echo "you input other"
  fi
done

函数

参数和调用脚本一样, 通过空格穿, 返回值只能返回int, 没什么用

funWithParm(){
	echo "第一个参数为 $1 !"
	echo "第二个参数为 $2 !"
}
funWithParm 1 2

重定向

命令 说明
command > file 将输出重定向到 file。
command < file 将输入重定向到 file。
command >> file 将输出以追加的方式重定向到 file。

输出重定向是将输出定向到文件里

输入重定向是从文件读书数据作为输入给程序

>右边不需要空格

深入理解

一般情况下,每个 Unix/Linux 命令运行时都会打开三个文件:

  • 标准输入文件(stdin):stdin的文件描述符为0,Unix程序默认从stdin读取数据。
  • 标准输出文件(stdout):stdout 的文件描述符为1,Unix程序默认向stdout输出数据。
  • 标准错误文件(stderr):stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。

如果希望stderr重定向到file, 可以这样写, 在>前加2

command 2>file

标准错误文件 stdout 和 stderr 合并后重定向到 file

command > file 2>&1
command &> file

ping历程

找到局域网中的主机

  • -c 1 —》只ping一次。
  • -i 0.2–》第一个包和第二个包之间间隔0.2s
  • -w 2 --》只等待2s

tr -s替换重复的字符

cut用来从标准输入或文本文件中剪切列或域

#!/bin/bash
for r in 192.168.1.{1..254}
do
    ping -c1 -w2 "${ip}" &>/dev/null
done
arp -n|grep ether|tr -s ' '|cut -d' ' -f1

通配符

有点类似正则表达式

符号 作用
* 匹配任何字符串,包括空字符串,*代表0个或多个
? 匹配任何一个字符,?代表一个字符
[abcd] 匹配abcd中的任何一个字符
[a-z] 表示范围a-z,中的任何一个字符

管道符

|:把前面命令的结果给后面的命令

arp -n|grep ether|tr -s ' '|cut -d' ' -f1

作业控制

命令 说明
ctrl+c 终止进程
ctrl+z 挂起一个进程
jobs 查看当前有多少在后台运行的命令
fg 将后台中的命令调值前台继续运行
bg 将一个在后台暂停的命令, 在后台中继续执行
命令+& 将命令后台执行