第一部分shell编程1基础知识


ls etc/init.d/ shell脚本的路径

ls /usr/local/apache2/
ls /usr/local/apache2/bin/apachectl


1. shell特性
命令历史 history !! !$ !n !字符
Tab 键可以补全文件路径或者命令
alias a=“b” unalias a
通配符 *匹配零个或多个字符 ?匹配一个字符
输入输出重定向 >, >>, < 反向重定向, 2>, 2>> 错误重定向
管道符 |
作业控制 ctrl+z, jobs查看后台停止的命令, fg 恢复后台停止的命令, bg n n表示查看后台第几个运行的命令

sleep 100 & 放到后台执行


ls aming >1.log 2>err.log = ls aming >1.log 2>&1

mail -s "adhofdjf" 947370895@qq.com < /etc/passwd
wc -l < /etc/passwd
39

cat 1.log | wc -l


2. 变量

系统变量名都是大写,echo 可以查看变量名
env 可以列出当前用户的所有环境变量以及用户自定义全局变量
set命令可以把所有变量列出来包括系统的和自定义的全局变量以及当前shell自定义变量
linux下设置自定义变量规则: (1)格式为 “a=b”, 其中a为变量名,b为变量的内容,等号两边不能有空格;(2)变量名只能由英、数字以及下划线组成,而且不能以数字开头;(3)当变量内容带有特殊字符(如空格)时,需要加上单引号;(4)如果变量内容中需要用到其他命令运行结果则可以使用反引号;(5)变量内容可以累加其他变量的内容,需要加双引号;

系统所有用户使用变量: export myname=Aming 全局变量,加入/etc/profile并source /etc/profile永久生效
系统某个用户使用变量: export myname=Aming 加入当前用户家目录下的 .bashrc中 source .bashrc
export myname=Aming 全局变量,export 不加任何选项表示,声明所有的环境变量以及用户自定义变量
用户自定义变量,可以使用 unset 变量名 进行解除变量设置

a=1
echo $a

unset a 把a的值抹掉


echo $HOME
echo $LANG

filename=/etc/passwd
echo $filename

com='ls /root'
echo $com

rpm -qf `which vim` 符号代表引用命令里面的结果


[root@localhost /]# a=1
[root@localhost /]# b=$a:123
[root@localhost /]# echo $b
1:123

 


3. 系统和个人环境变量的配置文件
/etc/profile PATH, USER, LOGNAME, MAIL, INPUTRC, HOSTNAME, HISTSIZE, umask等
/etc/bashrc $PS1 umask 以后如果设置umask修改 /etc/profile 不要改这个文件
.bash_profile 用户自己的环境变量
.bashrc 当用户登录时以及每次打开新的shell时, 执行该文件
.bash_history 记录命令历史用的
.bash_logout :当退出shell时,会执行该文件。


[root@localhost ~]# echo $PS1
[u@h W]$
[root@localhost ~]# 输出的就是这里的意思


PS1=“[u@h W ]\$”增加一个时间


全局配置

/etc/profile
/etc/profile.d/*.sh
/etc/bashrc

 

4. shell中的特殊符号
* 匹配符号,零个或多个任意字符
? 匹配符号,1个任意的字符
# 注视说明用的,使后面的内容失去原本的意义
脱义字符,将特殊字符还原为普通字符
|将符号前面命令的结果丢给符号后面的命令,一般针对文档操作的命令比较常用,例如cat, less, head, tail, grep, cut, sort, wc, uniq, tee, tr, split, sed, awk等等

$ 引用变量,还有 !$
; 分号,多条命令写一行时,分隔命令
~ 用户家目录
& 放到命令最后面,让命令在后台运行
>, >>, 2>, 2>> [错误]重定向,追加[错误]重定向
[ ] 中括号,中间为字符组合,代表中间字符中的任意一个 ls 1[23a].txt

 


5. 常用命令:
1)cut
语法: cut -d ‘分隔字符’ [-cf] n 这里的n是正整数
-d 后面指定分隔符,用单引号引起来,-f 指定第几段 cut -d ':' -f 1 /etc/passwd |head -n 5.
cut -d : -f1 /etc/passwd |head -n 5
-c 后面只有一个数字表示截取第几个字符head -n2 /etc/passwd|cut -c2
-c 后面跟一个数字区域,表示截取从几到几head -n2 /etc/passwd|cut -c2-5

[root@localhost ~]# head /etc/passwd |cut -d : -f3
0
1
2
3
4
5
6
7
8
10


[root@localhost ~]# head /etc/passwd|cut -c2
o
i
a
d
p
y
h
a
a
u

 

cut和sort结合使用

2)sort
语法: sort [-t 分隔符] [-kn1,n2] [-nru] (n1<n2)
不加选项,从首字符向后,依次按ASCII码值进行升序排序sort /etc/passwd
-n 从小到大排序,使用纯数字排序
-t 后指定分隔符,-kn1,n2表示在指定的区间中排序,-k后面只跟一个数字表示对第n个字符排序
sort -t: -k3 -n /etc/passwd
-r 表示以降序的形式排序 sort -t: -k3,5 -r /etc/passwd k表示期间
-u 去重 cut -d: -f4 /etc/passwd |sort -n -u

 

[root@localhost ~]# cut -d: -f3 /etc/passwd |sort -n
0
1
2
3
4
5
6
7
8
10
11
12
13
14
69
74
81
89
99
499

sort -n -u 1.txt |xargs

3)wc
用于统计文档的行数、字符数、词数
不加任何选项,会显示行数、词数以及字符数
-l 统计行数
-m 统计字符数
-w 统计词数

4)uniq
uniq 去重复,最常用就一个 -c 用来统计重复的行数,去重前要先排序sort testb.txt |uniq -c

uniq 1.txt |wc -l

sort -n 1.txt |uniq 现有排序

sort -n 1.txt |uniq -c |sort -n 多个管道,c代表显示重复的次数


5)tee
后跟文件名,类似于>,比重定向多了一个功能,在把文件写入后面所跟的文件中的同时,还显示在屏幕上
|tee ==> + screen

tcpdump -nn 抓包的
tcpdump -nn > 2.log

wc -l 2.log

tcpdump -nn |tee 2.log 不但在屏幕上显示,还定向到2.log里面了,动态的

 

6)tr 用来替换字符
最常用的就是大小写转换: head -2 /etc/passwd |tr '[a-z]' '[A-Z]'
tr 替换一个字符也是可以的 grep 'root' /etc/passwd |tr 'r' 'R'

7)split 切割大文件用的
-b : 按大小来分割单位为byte split -b50 1.txt
默认会以xaa, xab, …这样的形式定义分隔后的文件名,也可以指定文件名 split -b50 1.txt 123
-l : 按行数分隔,split -l10 file

[root@localhost ~]#split -b5 1.txt
[root@localhost ~]# ls
1.txt install.log xaa xac xae
anaconda-ks.cfg install.log.syslog xab xad xaf
[root@localhost ~]# du -sb x*
5 xaa
5 xab
5 xac
5 xad
5 xae
3 xaf

rm -rf x*

 

6. && 和 ||
command1 ; command2 前面命令是否执行完成都会执行后面命令
command1 && command2 只有前面命令执行成功才会执行后面命令
command1 || command2 只有前面命令不成功再去执行后面命令

原文地址:https://www.cnblogs.com/chenshoubiao/p/4854990.html