1.shell简介html
2. shell分类前端
3. 查看shellpython
4. 第一个shell脚本正则表达式
5. shell编程经常使用命令shell
5.1 grep数据库
5.2 cut编程
5.3 sortvim
5.4 uniq后端
5.5 seqcentos
5.6 tr
6. 课后做业
什么是脚本?
脚本简单地说就是一条条的文字命令(一些指令的堆积),这些文字命令是能够看到的(如能够用记事本打开查看、编辑)。
常见的脚本: JavaScript(JS,前端),VBScript, ASP,JSP,PHP(后端),SQL(数据库操做语言),Perl,Shell,python,Ruby,JavaFX, Lua等。
为何要学习和使用shell?
Shell属于内置的脚本
程序开发的效率很是高,依赖于功能强大的命令能够迅速地完成开发任务(批处理)
语法简单,代码写起来比较轻松,简单易学
Shell 是一个 C 语言编写的脚本语言,它是用户与 Linux 的桥梁,用户输入命令交给 Shell 处理, Shell 将相应的操做传递给内核(Kernel),内核把处理的结果输出给用户。
下面是流程示意图:
Shell 既然是工做在 Linux 内核之上,那咱们也有必要了解下 Linux 相关知识。 Linux 是一套免费试用和自由传播的类 Unix 操做系统,是一个基于 POSIX 和 UNIX 的多用户、多任 务、支持多线程和多 CPU 的操做系统。
1983 年 9 月 27 日,Richard Stallman(理查德-马修-斯托曼)发起 GNU 计划,它的目标是建立一 套彻底自由的操做系统。为保证 GNU 软件能够自由的使用、复制、修改和发布,全部的 GNU 软件都 有一份在禁止其余人添加任何限制的状况下受权全部权利给任何人的协议条款,GNU 通用公共许可 证(GNU General Plubic License,GPL),说白了就是不能作商业用途。
GNU 是"GNU is Not Unix"的递归缩写。UNIX 是一种普遍使用的商业操做系统的名称。
1985 年,Richard Stallman 又创立了自由软件基金会(Free Software Foundation,FSF)来为 GNU 计划提供技术、法律以及财政支持。
1990 年,GNU 计划开发主要项目有 Emacs(文本编辑器)、GCC(GNU Compiler Collection,GNU 编 译器集合)、Bash 等,GCC 是一套 GNU 开发的编程语言编译器。还有开发一些 UNIX 系统的程序库和 工具。
1991 年,Linuxs Torvalds(林纳斯- 托瓦兹)开发出了与 UNIX 兼容的 Linux 操做系统内核并在 GPL 条款下发布。
1992 年,Linux 与其余 GUN 软件结合,彻底自由的 GUN/Linux 操做系统正式诞生,简称 Linux。
1995 年 1 月,Bob Young 创办 ACC 公司,以 GNU/Linux 为核心,开发出了 RedHat Linux 商业版。
Linux 基本思想有两点:第一,一切都是文件;第二,每一个软件都有肯定的用途。
与 Unix 思想十分 相近。 Kernel Shell 命令 用户 解析命令 并传递给内核 执行动做
GUI 为 Unix 或者类 Unix 操做系统构造一个功能完善、操做简单以及界面友好的桌面环境。主流桌 面环境有 KDE,Gnome 等。
CLI 是在用户提示符下键入可执行指令的界面,用户经过键盘输入指令,完成一系列操做。 在 Linux 系统上主流的 CLI 实现是 Bash,是许多 Linux 发行版默认的 Shell。还有许多 Unix 上 Shell,例如 tcsh、csh、ash、bsh、ksh 等。
Shell 是一个程序,通常都是放在/bin或者/user/bin目录下,当前 Linux 系统可用的 Shell 都记录在/etc/shells文件中。/etc/shells是一个纯文本文件,你能够在图形界面下打开它,也可使用 cat 命令查看它。
经过 cat 命令来查看当前 Linux 系统的可用 Shell:
$ cat /etc/shells /bin/sh /bin/bash /sbin/nologin /usr/bin/sh /usr/bin/bash /usr/sbin/nologin /bin/tcsh /bin/csh
在现代的 Linux 上,sh 已经被 bash 代替,/bin/sh每每是指向/bin/bash的符号连接。
若是你但愿查看当前 Linux 的默认 Shell,那么能够输出 SHELL 环境变量:
$ echo $SHELL /bin/bash
输出结果代表默认的 Shell 是 bash。
SHELL是 Linux 系统中的环境变量,它指明了当前使用的 Shell 程序的位置,也就是使用的哪一个 Shell。
主要讲解在大多 Linux 发行版下默认 Bash Shell。Linux 系统是 RedHat 下的 CentOS 操做系 统,彻底免费。与其商业版 RHEL(Red Hat Enterprise Linux)出自一样的源代码,不一样的是 CentOS 并不包含封闭源代码软件和售后支持。
用 vim 打开 test.sh,编写:
# vim test.sh #!/bin/bash echo "Hello world!"
第一行指定解释器,第二行打印 Hello world!
写好后,开始执行,执行 Shell 脚本有三种方法:
# bash test.sh
Hello world!
当前终端会新生成一个子 bash 去执行脚本。
# ll test.sh -rw-r--r--. 1 root root 32 Aug 18 01:07 test.sh # chmod +x test.sh # ./test.sh -bash: ./test.sh: Permission denied # chmod +x test.sh # ./test.sh Hello world!
这种方式默认根据脚本第一行指定的解释器处理,若是没写以当前默认 Shell 解释器执行。
注意,这里在运行时必定要写成 ./test.sh(绝对路径亦可),而不是 test.sh,运行其它二进制的程序也同样,直接写 test.sh,Linux 系统会去 PATH(环境变量) 里寻找有没有叫 test.sh 的,而只有 /bin, /sbin, /usr/bin,/usr/sbin 等在 PATH 里,你的当前目录一般不在 PATH 里,因此写成 test.sh 是会找不到命令的,要用 ./test.sh 告诉系统说,就在当前目录找。
# source test.sh
Hello world!
最后一句话什么意思那?
子shell新建变量,在父shell中不会生效:
咱们可使用命令pstree查看咱们当前所处的位置
须要下载
[root@ken ~]# yum search pstree Loaded plugins: fastestmirror Loading mirror speeds from cached hostfile ==================================================== Matched: pstree ==================================================== psmisc.x86_64 : Utilities for managing processes on your system texlive-pst-tree.noarch : Trees, using pstricks [root@ken ~]# yum install psmisc -y
使用pstree
咱们再次执行bash,就会进入到另一个子shell中
这个时候咱们在这个子shell中定义一个变量,发现能够正确打印出来
[root@ken ~]# age=25 [root@ken ~]# echo $age 25
如今咱们退出当前的shell,即进入了当前子shell中的父shell中,再次打印咱们刚才定义的变量
能够发现如今已经没法获取到咱们刚才定义的变量值了。
子shell继承父shell的环境变量:
咱们把环境变量定义到profile的一个子文件中,并使用source执行该文件并生效
打开一个子shell,定义在父shell中的环境变量依然有效
反之,这种操做在子shell中操做,父shell也不能继承
[root@ken ~]# cat /etc/profile.d/ken.sh export name=ken [root@ken ~]# source /etc/profile.d/ken.sh [root@ken ~]# echo $name ken [root@ken ~]# bash [root@ken ~]# echo $name ken
练习1:使用root用户账号建立并执行test2.sh,实现建立一个shelltest用户,并在其家目录中新建文件try.html。
练习2:统计当前系统总共有多少用户
练习3:统计当前已经安装的软件数量
过滤来自一个文件或标准输入匹配模式内容。
除了 grep 外,还有 egrep。egrep 是 grep 的扩展,至关于 grep -E。
Usage: grep [OPTION]... PATTERN [FILE]...
选项 | 描述 |
-E,--extended-regexp |
模式是扩展正则表达式(ERE) |
-i,--ignore-case | 忽略大小写 |
-n,--line-number | 打印行号 |
-o,--only-matching | 只打印匹配的内容 |
-c,--count | 只打印每一个文件匹配的行数 |
-B,--before-context=NUM | 打印匹配的前几行 |
-A,--after-context=NUM | 打印匹配的后几行 |
-C,--context=NUM |
打印匹配的先后几行 |
--color[=WHEN], |
匹配的字体颜色 |
-v,--invert-match |
打印不匹配的行 |
1. -i, 忽略大小写
[root@ken ~]# echo "this is ken THIS IS KEN" | grep -i 'ken' this is ken THIS IS KEN [root@ken ~]# echo "this is ken THIS IS KEN" | grep 'ken' this is ken THIS IS KEN
2. -n,打印行号
[root@ken ~]# grep -n 'root' /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 10:operator:x:11:0:operator:/root:/sbin/nologin
3. -o,只打印匹配的内容
[root@ken ~]# echo "this is ken THIS IS KEN" | grep -o 'ken' ken [root@ken ~]# echo "this is ken THIS IS KEN" | grep 'ken' this is ken THIS IS KEN
4. -c,打印文件匹配的行数
[root@ken ~]# grep -c 'root' /etc/passwd 2 [root@ken ~]# grep 'root' /etc/passwd root:x:0:0:root:/root:/bin/bash operator:x:11:0:operator:/root:/sbin/nologin
5. -B,打印匹配的前几行
[root@ken ~]# grep -B 3 'root' /etc/passwd root:x:0:0:root:/root:/bin/bash -- shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt mail:x:8:12:mail:/var/spool/mail:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin
6.-A,打印匹配的后几行
[root@ken ~]# grep -A 3 'root' /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin -- operator:x:11:0:operator:/root:/sbin/nologin games:x:12:100:games:/usr/games:/sbin/nologin ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin nobody:x:99:99:Nobody:/:/sbin/nologin
7.-C,打印匹配的先后几行
[root@ken ~]# grep -C 3 'root' /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin -- shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt mail:x:8:12:mail:/var/spool/mail:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin games:x:12:100:games:/usr/games:/sbin/nologin ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin nobody:x:99:99:Nobody:/:/sbin/nologin
8. --color,在centos7中已经默认为 grep --color,在centos6中须要加上--color才会显示颜色
[root@ken ~]# alias grep alias grep='grep --color=auto'
9. -v, 打印不匹配的行
[root@ken ~]# echo -e "hi\nthis is ken\nncie to meet you\nbye " | grep -v 'ken' hi ncie to meet you bye
cut [-bn] [file] cut [-c] [file] cut [-df] [file]
使用说明:
cut 命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段写至标准输出。
若是不指定 File 参数,cut 命令将读取标准输入。必须指定 -b、-c 或 -f 标志之一。
经常使用参数:
-c :以字符为单位进行分割。
-d :自定义分隔符。
-f :与-d一块儿使用,指定显示哪一个区域。
经常使用实例演示1: -c:以字符为单位进行分隔
[root@ken ~]# echo "this is ken" | cut -c 4 s [root@ken ~]# echo "this is ken" | cut -c 5 [root@ken ~]# echo "this is ken" | cut -c 2 h
[root@ken ~]# echo "this is ken" | cut -c 1-5
this
经常使用实例演示2:-d,-f:自定义分隔符并进行指定显示
1.从标准输入读取
[root@ken ~]# echo 'this is ken' | cut -d' ' -f3 ken
[root@ken ~]# echo "name:ken age:25 gender:male" | cut -d ' ' -f2
age:25
2.从文件中读取
[root@ken ~]# echo "this is ken">test [root@ken ~]# cut -d' ' -f3 test ken
Linux sort命令用于将文本文件内容加以排序。
sort可针对文本文件的内容,以行为单位来排序。
sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符>][+<起始栏位>-<结束栏位>][--help][--verison][文件]
在使用sort命令以默认的式对文件的行进行排序,使用的命令以下:
[root@ken ~]# cat test 6 this is ken 2 this is ken 5 this is ken 6 this is ken 1 this is ken 8 this is ken [root@ken ~]# sort test 1 this is ken 2 this is ken 5 this is ken 6 this is ken 6 this is ken 8 this is ken
sort 命令将以默认的方式将文本文件的第一列以ASCII 码的次序排列,并将结果输出到标准输出。
[root@ken ~]# sort -r test | head -3 8 this is ken 6 this is ken 6 this is ken
[root@ken ~]# sort -t 'e' -k 2 test 6 this:is:ke1 5 this:is:ke2 6 this:is:ke3 2 this:is:ke4 1 this:is:ke6 8 this:is:ke7 [root@ken ~]# sort -t 'e' -k 2 -r test 8 this:is:ke7 1 this:is:ke6 2 this:is:ke4 6 this:is:ke3 5 this:is:ke2 6 this:is:ke1
[root@ken ~]# sort test 1 this:is:ke6 2 this:is:ke4 2 this:is:ke4 2 this:is:ke4 2 this:is:ke4 5 this:is:ke2 6 this:is:ke1 6 this:is:ke3 8 this:is:ke7 [root@ken ~]# sort -u test 1 this:is:ke6 2 this:is:ke4 5 this:is:ke2 6 this:is:ke1 6 this:is:ke3 8 this:is:ke7
去除重复的行(相邻且相同,认定为重复)
-c:在行首用数字表示该行出现了多少次
-u:仅仅显示那些没有出现重复过的行
[root@ken ~]# uniq -c test 1 6 this:is:ke3 4 2 this:is:ke4 1 5 this:is:ke2 1 6 this:is:ke1 1 1 this:is:ke6 1 8 this:is:ke7
[root@ken ~]# sort test | uniq 1 this:is:ke6 2 this:is:ke4 5 this:is:ke2 6 this:is:ke1 6 this:is:ke3 8 this:is:ke7
生成一个数组序列
seq [start [step]] stop
[root@ken ~]# seq 5 #终止位5 1 2 3 4 5 [root@ken ~]# seq 2 5 #起始位2,终止位5 2 3 4 5 [root@ken ~]# seq 2 2 10 #起始位2,步长为2,终止位10 2 4 6 8 10
Linux tr 命令用于转换或删除文件中的字符。
tr 指令从标准输入设备读取数据,通过字符串转译后,将结果输出到标准输出设备。
a-z 任意小写
A-Z 任意大写
0-9 任意数字
[root@ken ~]# echo "this is ken" | tr a-z A-Z THIS IS KEN [root@ken ~]# echo "THIS IS KEN" | tr A-Z a-z this is ken
s这个字符串都会被删掉
[root@ken ~]# cat test 6 this:is:ke3 2 this:is:ke4 2 this:is:ke4 2 this:is:ke4 2 this:is:ke4 5 this:is:ke2 6 this:is:ke1 1 this:is:ke6 8 this:is:ke7 [root@ken ~]# cat test | tr -d 's' 6 thi:i:ke3 2 thi:i:ke4 2 thi:i:ke4 2 thi:i:ke4 2 thi:i:ke4 5 thi:i:ke2 6 thi:i:ke1 1 thi:i:ke6 8 thi:i:ke7
做业1. 获取主机IP地址,获取结果仅显示IP,例如:172.20.10.2(使用尽量多的方法)
做业2. 有以下一个文件,文件内容以下。
请把下方的内容复制到你的一个文件中,并完成以下需求
需求1. 统计出各个网址出现的次数
需求2. 按照出现次数排序(升序)
需求3. 取出出现次数排名前两名的网址
[root@ken ~]# cat ken.sh http://www.baidu.com http://www.baidu.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.sina.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.qq.com http://www.qq.com http://www.qq.com http://www.qq.com http://www.qq.com http://www.qq.com http://www.qq.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.taobao.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com http://www.baidu.com
做业1:
第一种方法:
[root@ken ~]# ip a | grep global | cut -d " " -f 6 | cut -d "/" -f1 172.20.10.6
第二种方法:
[root@ken ~]# ip a | grep global | cut -d "b" -f 1 | tr -d [a-z] | cut -d "/" -f 1 | tr -d " "
172.20.10.6
第三种方法:
[root@ken ~]# ip a | grep global | tr -d [a-z] | tr -d " " | cut -d "/" -f1 172.20.10.6
方法有不少,你们尽量的本身多思考哦!
做业2:
1. 统计出各个网址出现的次数
[root@ken ~]# cat ken.sh | cut -d '/' -f3 | sort | uniq -c 19 www.baidu.com 7 www.qq.com 12 www.sina.com 10 www.taobao.com
2. 按照出现次数排序(升序)
[root@ken ~]# cat ken.sh | cut -d '/' -f3 | sort | uniq -c | sort -n 7 www.qq.com 10 www.taobao.com 12 www.sina.com 19 www.baidu.com
3. 取出出现次数排名前两名的网址
[root@ken ~]# cat ken.sh | cut -d '/' -f3 | sort | uniq -c | sort -n -r | head -2 19 www.baidu.com 12 www.sina.com
思考:还有更多的办法吗?