linux中BASH如何使用

linux中BASH如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

创新互联建站是一家专业提供西林企业网站建设,专注与网站建设、网站制作、H5网站设计、小程序制作等业务。10年已为西林众多企业、政府机构等服务。创新互联专业网络公司优惠进行中。

Bash shell 的功能

  • 命令编修能力 (history):

    只要在命令行按“上下键”就可以找到前/后一个输入的指令,这么多的指令记录在哪里呢?在你的主文件夹内的 .bash_history 啦。

  • 命令与文件补全功能: ([tab] 按键的好处)

  • 命令别名设置功能: (alias)

    alias lm='ls -al'

  • 程序化脚本: (shell scripts)

查询指令是否为 Bash shell 的内置命令: type

范例一:查询一下 ls 这个指令是否为 bash 内置?

[dmtsai@study ~]$ type ls
Shell 的变量功能

变量的取用与设置:echo, 变量设置规则, unset

echo $PATH

设置变量:

[dmtsai@study ~]$ echo ${myname}
<==这里并没有任何数据~因为这个变量尚未被设置!是空的!
[dmtsai@study ~]$ myname=VBird
[dmtsai@study ~]$ echo ${myname}
VBird <==出现了!因为这个变量已经被设置了
  • 变量与变量内容以一个等号“=”来链接,如下所示: “myname=VBird”

  • 等号两边不能直接接空白字符,如下所示为错误: “myname = VBird”或“myname=VBird Tsai”

  • 变量名称只能是英文字母与数字,但是开头字符不能是数字,如下为错误: “2myname=VBird”

  • 若该变量为扩增变量内容时,则可用 "$变量名称">

  • 若该变量需要在其他子程序执行,则需要以 export 来使变量变成环境变量: “export PATH”

  • 取消变量的方法为使用 unset :“unset 变量名称”例如取消 myname 的设置: “unset myname”

:如何进入到您目前核心的模块目录?

[dmtsai@study ~]$ cd /lib/modules/$(uname -r)/kernel # 以此例较佳!

其实上面的指令可以说是作了两次动作,亦即是:

  1. 先进行反单引号内的动作“uname -r”并得到核心版本为 3.10.0-229.el7.x86_64

  2. 将上述的结果带入原指令,故得指令为:“cd /lib/modules/3.10.0-229.el7.x86_64/kernel/”

环境变量的功能

用 env 观察环境变量与常见环境变量说明

用 set 观察所有变量 (含环境变量与自订变量)

影响显示结果的语系变量 (locale)

变量键盘读取、阵列与宣告: read, array, declare
  • read

范例一:让使用者由键盘输入一内容,将该内容变成名为 atest 的变量
[dmtsai@study ~]$ read atest
This is a test <==此时光标会等待你输入!请输入左侧文字看看
[dmtsai@study ~]$ echo ${atest}
This is a test <==你刚刚输入的数据已经变成一个变量内容!
  • declare / typeset

范例一:让变量 sum 进行 100+300+50 的加总结果

declare 或 typeset 是一样的功能,就是在“宣告变量的类型”。如果使用 declare 后面并没有接任何参数,那么 bash 就会主动的将所有的变量名称与内容通通叫出来,就好像使用 set 一样啦!

[dmtsai@study ~]$ sum=100+300+50
[dmtsai@study ~]$ echo ${sum}
100+300+50 <==咦!怎么没有帮我计算加总?因为这是文字体态的变量属性啊!
[dmtsai@study ~]$ declare -i sum=100+300+50
[dmtsai@study ~]$ echo ${sum}
450
  • 阵列 (array) 变量类型

范例:设置上面提到的 var[1] ~ var[3] 的变量。

[dmtsai@study ~]$ var[1]="small min"
[dmtsai@study ~]$ var[2]="big min"
[dmtsai@study ~]$ var[3]="nice min"
[dmtsai@study ~]$ echo "${var[1]}, ${var[2]}, ${var[3]}"
small min, big min, nice min

与文件系统及程序的限制关系: ulimit

变量内容的删除、取代与替换

范例一:先让小写的 path 自订变量设置的与 PATH 内容相同

[dmtsai@study ~]$ path=${PATH}
[dmtsai@study ~]$ echo ${path}
/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/dmtsai/.local/bin:/home/dmtsai/bin

范例二:假设我不喜欢 local/bin,所以要将前 1 个目录删除掉,如何显示?

[dmtsai@study ~]$ echo ${path#/*local/bin:}
/usr/bin:/usr/local/sbin:/usr/sbin:/home/dmtsai/.local/bin:/home/dmtsai/bin

范例六:将 path 的变量内容内的 sbin 取代成大写 SBIN:

[dmtsai@study ~]$ echo ${path/sbin/SBIN}
/usr/local/bin:/usr/bin:/usr/local/SBIN:/usr/sbin:/home/dmtsai/.local/bin:/home/dmtsai/bin

#这个部分就容易理解的多了!关键字在于那两个斜线,两斜线中间的是旧字串 #后面的是新字串,所以结果就会出现如上述的特殊字体部分啰!

[dmtsai@study ~]$ echo ${path//sbin/SBIN}
/usr/local/bin:/usr/bin:/usr/local/SBIN:/usr/SBIN:/home/dmtsai/.local/bin:/home/dmtsai/bin

#如果是两条斜线,那么就变成所有符合的内容都会被取代喔!

我们将这部份作个总结说明一下:

变量设置方式说明
${变量#关键 字} 
${变量##关键字}若变量内容从头开始的数据符合“关键字”,则将符合的最短数据删除若变量内容从头开始的数据符合“关键字”,则将符合的最长数据删除
${变量%关键 字} 
${变量%%关键字}若变量内容从尾向前的数据符合“关键字”,则将符合的最短数据删除 若变量内容从尾向前的数据符合“关键字”,则将符合的最长数据删除
${变量/旧字串/新字串} 
${变量//旧字串/新字串}若变量内容符合“旧字串”则“第一个旧字串会被新字串取代” 若变量内容符合“旧字串”则“全部的旧字串会被新字串取代”
Bash Shell 的操作环境:

bash 的环境配置文件

linux中BASH如何使用

source :读入环境配置文件的指令

万用字符与特殊符号

符号意义
*代表“ 0 个到无穷多个”任意字符
?代表“一定有一个”任意字符
[ ]同样代表“一定有一个在括号内”的字符(非任意字符)。例如 [abcd] 代表“一定有一个字符, 可能是 a, b, c, d 这四个任何一个
[ -]若有减号在中括号内时,代表“在编码顺序内的所有字符”。例如 [0-9] 代表 0 到 9 之间的所有数字,因为数字的语系编码是连续的!
[^]若中括号内的第一个字符为指数符号 (^) ,那表示“反向选择”,例如 [^abc] 代表一定有一个字符,只要是非 a, b, c 的其他字符就接受的意思。

除了万用字符之外,bash 环境中的特殊符号有哪些呢?下面我们先汇整一下:

Snipaste_2019-04-24_13-00-38

数据流重导向
  1. 标准输入  (stdin) :代码为 0 ,使用 < 或 << ;

  2. 标准输出  (stdout):代码为 1 ,使用 > 或 >> ;

  3. 标准错误输出(stderr):代码为 2 ,使用 2> 或 2>> ; 为了理解 stdout 与 stderr ,我们先来进行一个范例的练习: 范例一:观察你的系统根目录 (/) 下各目录的文件名、权限与属性,并记录下来

[dmtsai@study ~]$ ll / ==此时屏幕会显示出文件名信息
[dmtsai@study ~]$ ll / > ~/rootfile ==屏幕并无任何信息
[dmtsai@study ~]$ ll ~/rootfile ==有个新文件被创建了!
-rw-rw-r--. 1 dmtsai dmtsai 1078 Jul 9 18:51 /home/dmtsai/rootfile

1> :以覆盖的方法将“正确的数据”输出到指定的文件或设备上; 1>>:以累加的方法将“正确的数据”输出到指定的文件或设备上; 2> :以覆盖的方法将“错误的数据”输出到指定的文件或设备上; 2>>:以累加的方法将“错误的数据”输出到指定的文件或设备上;

范例五:将指令的数据全部写入名为 list 的文件中

[dmtsai@study ~]$ find /home -name .bashrc > list 2> list  ==错误
[dmtsai@study ~]$ find /home -name .bashrc > list 2>&1  ==正确
[dmtsai@study ~]$ find /home -name .bashrc &> list  ==正确

standard input : < 与 << 了解了 stderr 与 stdout 后,那么那个 < 又是什么呀?呵呵!以最简单的说法来说, 那就 是“将原本需要由键盘输入的数据,改由文件内容来取代”的意思。 我们先由下面的 cat 指令操 作来了解一下什么叫做“键盘输入”吧!

范例六:利用 cat 指令来创建一个文件的简单流程

[dmtsai@study ~]$ cat < catfile
testing
cat file test
< ==这里按下 [ctrl]+d 来离开
[dmtsai@study ~]$ cat catfile
testing
cat file test

命令执行的判断依据: ; , &&, ||

  • cmd ; cmd (不考虑指令相关性的连续指令下达)

在某些时候,我们希望可以一次执行多个指令,例如在关机的时候我希望可以先执行两次sync 同步化写入磁盘后才 shutdown 计算机,那么可以怎么作呢?这样做呀:

[root@study ~]# sync; sync; shutdown -h now

在某些时候,我们希望可以一次执行多个指令,例如在关机的时候我希望可以先执行两次 sync 同步化写入磁盘后才 shutdown 计算机,那么可以怎么作呢?这样做呀: [root@study ~]# sync; sync; shutdown -h now

$? (指令回传值) 与 && 或 ||

cmd1&&cmd2

若 cmd1 执行完毕且正确执行($?=0),则开始执行 cmd2。 2. 若 cmd1 执行完毕且为错误 ($?≠0),则 cmd2 不执行。

cmd1 ||cmd2

若 cmd1 执行完毕且正确执行($?=0),则 cmd2 不执行。 2. 若 cmd1 执 行完毕且为错误 ($?≠0),则开始执行 cmd2。

范例一:使用 ls 查阅目录 /tmp/abc 是否存在,若存在则用 touch 创建 /tmp/abc/hehe

[dmtsai@study ~]$ ls /tmp/abc && touch /tmp/abc/hehe
ls: cannot access /tmp/abc: No such file or directory

#ls 很干脆的说明找不到该目录,但并没有 touch 的错误,表示 touch 并没有执行

管线命令 (pipe)

撷取命令: cut, grep

范例一:将 PATH 变量取出,我要找出第五个路径。

[dmtsai@study ~]$ echo ${PATH}
/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/dmtsai/.local/bin:/home/dmtsai/bin
[dmtsai@study ~]$ echo ${PATH} | cut -d ':' -f 5
#如同上面的数字显示,我们是以“ : ”作为分隔,因此会出现 /home/dmtsai/.local/bin
#那么如果想要列出第 3 与第 5 呢?,就是这样:
[dmtsai@study ~]$ echo ${PATH} | cut -d ':' -f 3,5
范例一:将 last 当中,有出现 root 的那一行就取出来;
[dmtsai@study ~]$ last|grep 'root'
范例二:与范例一相反,只要没有 root 的就取出!
[dmtsai@study ~]$ last | grep -v 'root'

排序命令: sort, wc, uniq

范例一:个人帐号都记录在 /etc/passwd 下,请将帐号进行排序。
[dmtsai@study ~]$ cat /etc/passwd | sort

范例一:使用 last 将帐号列出,仅取出帐号栏,进行排序后仅取出一位;
[dmtsai@study ~]$ last | cut -d ' ' -f1 | sort| uniq

范例一:那个 /etc/man_db.conf 里面到底有多少相关字、行、字符数?
[dmtsai@study ~]$ cat /etc/man_db.conf | wc
131 723 5171

#输出的三个数字中,分别代表: “行、字数、字符数”

双向重导向: tee

[dmtsai@study ~]$ last | tee last.list | cut -d " " -f1

#这个范例可以让我们将 last 的输出存一份到 last.list 文件中;

字符转换命令: tr, col, join, paste, expand

tr 可以用来删除一段讯息当中的文字,或者是进行文字讯息的替换!

范例一:将 last 输出的讯息中,所有的小写变成大写字符:

[dmtsai@study ~]$ last | tr '[a-z]' '[A-Z]'

#事实上,没有加上单引号也是可以执行的,如:“ last | tr [a-z] [A-Z] ”

join 看字面上的意义 (加入/参加) 就可以知道,他是在处理两个文件之间的数据, 而且, 主要是在处理“两个文件当中,有 "相同数据" 的那一行,才将他加在一起”的意思。

这个 paste 就要比 join 简单多了!相对于 join 必须要比对两个文件的数据相关性, paste 就 直接“将两行贴在一起,且中间以 [tab] 键隔开”

expand 这玩意儿就是在将 [tab] 按键转成空白键啦。

分区命令: split

范例一:我的 /etc/services 有六百多K,若想要分成 300K 一个文件时?

[dmtsai@study ~]$ cd / | split -b 300k /etc/services services
[dmtsai@study tmp]$ ll -k services*
-rw-rw-r--. 1 dmtsai dmtsai 307200 Jul 9 22:52 servicesaa
-rw-rw-r--. 1 dmtsai dmtsai 307200 Jul 9 22:52 servicesab
-rw-rw-r--. 1 dmtsai dmtsai 55893 Jul 9 22:52 servicesac

参数代换: xargs

关于减号 - 的用途

管线命令在 bash 的连续的处理程序中是相当重要的!另外,在 log file 的分析当中也是相当 重要的一环, 所以请特别留意!另外,在管线命令当中,常常会使用到前一个指令的 stdout 作为这次的 stdin , 某些指令需要用到文件名称 (例如 tar) 来进行处理时,该 stdin 与 stdout 可以利用减号 "-" 来替代, 举例来说:

[root@study ~]# mkdir /tmp/homeback
[root@study ~]# tar -cvf - /home | tar -xvf - -C /tmp/homeback

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


当前题目:linux中BASH如何使用
转载注明:http://myzitong.com/article/jhppdh.html