history |tail -1 | cut -d‘‘ -f2
计算命令:1)let 例;let C=$A+$B
2)C=$[$A+$B]
3)C=$(($A+$B))
4)expr命令 例:C=` expr $A + $B `
退出脚本;exit 例;exit 0
条件测试:
1)[空格 表达式 空格]
2)test 表达式
3)[[ 空格 表达式 空格]]
if grep ‘bash‘ /etc/shadow
if后面为非零值为假
文件测试
-e file 测试文件是否存在
-f file 是否为普通文件
-d file 是否为目录
-r file 当前用户是否有读权限
$0表示当前命令
多分支if
if 判断1 ;then
语句1
elif 判断2; then
语句2
elif 判断3; then
语句3
else
语句4
fi
测试脚本有无语法错误
bash -n 脚本名称
单步执行脚本
bash -x 脚本名称
位置变量
shift 轮换参数内容
特殊变量:
$#:表示参数的个数
$?
$*:表示参数列表
[email protected]:表示参数列表
sed数据流编辑器
sed对文件本身不处理
sed [选项] ‘addresscommand‘file...
address
1)1,100
2)/regularexpression/
例:/^root/
3)/pattern1/,/pattern2/
第一次被模式一匹配到的行开始到
第一次被模式二匹配到的行结束的
中间的所以行
4)linenumber
指定的行
$表示最后一行
5)startline,+n
从起始行开始的n行(一共n+1行)
command:
d:删除符合条件的行(只是不打印而已)
p:显示符合条件的行(符合的显示两次,不符合的显示一次)
a \string:在指定的行后面追加新行,内容为string
\n:可以用来换行
i \string:在指定的行前面追加新行,内容为string
r file:将指定的文件的内容添加到符合条件的行处
w file:将指定范围内的内容另存到指定文件中(追加的方式)
s/要查找的内容/要替换成的内容/ 查找并替换(默认只替换每行中第一次匹配要被替换的内容)
g:全局替换
i:查找时忽略大小写
&:引用匹配到模式的整个串
后向引用:
例:
sed ‘s#\(l..e\)#\1r#g‘ sed.txt
同一目的用&写
sed ‘s#l..e#&r#g‘ sed.txt
-n:静默模式,显示结果只和命令相关
-i:直接修改源文件(谨慎使用)
-e 命令1 -e 命令2....:可以同时进行命令1,2....
-f (把每个命令写进文件中)那个文件的路径 :也能同时处理多个命令
-r:使用拓展的正则表达式
for 变量 in 列表
do
循环体
done
如何生成列表
1)(1..10)
2) `seq 10` 等价于1)
seq a b c
a为起始数
b为步进长度
c为结束数
3)引用(``)命令
vim
vim +行号N 文件名:打开文件时直接在N上
vim +文件名:直接处在文件尾部
vim +/pattern 文件名:打开文件定位置
ctrl+f 上翻一屏
ctrl+b 下翻一屏
ctrl+d 下翻半屏
ctrl+u 上翻半屏
删除单个字符:x
n个字符:nx
d是删除命令
d0删除到行首
3dw删除三个单词
3dd删除3行(包含当前光标所在行)
dd删除当前行
末行模式下
/n 表示查找n
:1,9d表示删除第一到第九行
:.,9d删除当前行到第九行
+n表示向下n行
vim如何实现复制粘贴
复制yy
粘贴p
复制y的用法同d的用法
3yy复制三行
修改:先删除内容再自动转换成输入模式
c,c的用法同d命令
替换:r,只能替换单个字符
r+要替换成的字符
R:进入替换模式,用ESC退出
用于替换多个字符
撤销更改;u(最多撤销近50次操作)
3u撤销最近3次操作
ctrl+r撤销刚才的撤销操作
重复前一次的编辑操作:.
可视化模式:
v/V进入
V选中整行
选中后按d:删除
y:复制
p:粘贴
/a:向后查找a
?a:向前查找a
n找下一个,N找上一个
查找并替换
在末行模式下用s命令
%:表示全文
vim 跨文件执行
vim a b
在第一个文件操作后再末行模式下:next
到下一个文件进行操作
:prev回到上一个文件
:last切换到最后一个文件
:first回到第一个文件
分屏显示文件
ctrl+w 松开后再按s(水平分屏),v为(垂直分屏)
ctrl+w+向下的箭头 跳到下一个屏幕
:qa关闭所有窗口
分窗口多个文件
vim -o a b
水平分窗口显示a,b
vim -O 垂直分屏
将当前文件中部分内容另存了为一个文件
:add1,add2 w /新文件路径
将add1到add2的内容新存为文件
将另外一个文件的内容填充在当前文件中
末行模式下
:r /要被添加的文件的路径
跟shell交互
:!command
回车回到vim
显示行号:
set nu
set nonu不显示
忽略大小写
:set ignorecase/set ic
不忽略
:set noignorecase
设定自动缩进
:set autoindent/set ai
取消前面加no
高亮搜索
:set hlsearch
语法着色
:syntax on
vim配置文件
/etc/vimrc
对所以人生效
如果只想对当前用户生效
vim ~/.vimrc
使用vimtutor学习vim:
shell>vimtutor
字符测试
-n
-z测试是否为空
组合测试条件
-a :与关系
例如:
if [ $# -gt 1 -a $# -le 3]
等价于
if [ $# -gt 1 ] && [ $# -le 3 ]
-o:或关系
!:非关系
文件查找:
locate:
在全系统模糊查找文件(非实时)
updatedb:手动生成文件数据库
locate:优势速度快
find
1)实时查找
2)精确查找
3)遍历指定目录中索引文件完成查找
4)支持许多查找标准
find 查找路径 查找标准 查找后的处理运作
查找路径:默认为当前目录
查找标准:默认为指定路径下的所有文件
处理运作:默认为显示到屏幕
find匹配标准
-name ‘filename‘ 对文件名进行精确匹配
-iname ‘filename‘对文件名匹配时不区分大小写
-user USERNAME:根据文件的属主来查找
-group GROUPNAME:根据文件的属组来查找
-uid
-gid
-nouser 专门查找没有属主的文件
-nogroup
-type 根据文件类型来查找
f:普通文件
d
c:字符设备
b:块设备
l:符合连接
p:管道设备
s:套接字文件
-size 根据文件大小来查找
数字+单位
[+|-]数字k
M
G
例如find -size 512M
默认单位为字节
组合条件
-a
-o
-not
例如
find -nouser -a -type d
注意shell括号要加斜线
\(\)
根据时间查找
-mtime(modify指内容)
-ctime(change)
-atime(access)
后面的数字是天数,可以用+|—
-mmin
-cmin
-amin
表示分钟
根据文件权限查找
-perm MODE
精确匹配
MODE可以是755。。。。
-perm -MODE
文件权限能完全包含此MODE就匹配,它的范围大于 -perm MODE
-perm /MODE
表示有任何一位匹配就可以了
运作
-print:显示
-ls :类似于ls -l
-ok command {} \;每一次操作都需要用户确认
-exec command {} \;不需要确认
XARGS命令
find里面的
find -exec
等于
find xargs command
xargs不要\;结尾
但是需要管道
find xx|xargs command
特殊权限
SUID:运行某程序时,相应进程的属主仍保持文件的属主
chmod u+s file :如果file原来就有执行权限则suid 显示为s,否则显示为S
SGID:运行某程序时,相应进程的属组仍保持文件的属组
sticky:表示在一个公共目录,每个人都能创建文件,删除自己的文件,但不能删除别人的文件
chmod o+t DIR 添加sticky
chmod o-t DIR 删除sticky
000
001:只有stciky
..
111
例如
chmod 1755 /backup/test 有sticky
普通用户无法使用:chown
FACL:文件系统的访问列表
利用文件扩展保存额外的访问控制权限
setfacl
-m:设定
-x:取消设定
u:UID perm
g:GID:perm
例如:
setfacl -m u:user1:rw backup
setfacl -x u:user1 backup
getfacl
例如:
getfacl backup
给一个目录设定默认的访问控制列表
例如:
set -m du:user1:rx dir
几个命令
whoami
who显示登陆的用户有哪些
-r 显示当前运行级别
sleep +n :休眠n秒
w:显示登陆用户信息以及该登陆用户正在执行的命令
w显示的信息是who的加强版
last:用于显示登陆/重启的历史(即用户显示/var/log/wtmp文件)
last -n 3:只显示最近三次的信息
lastb 用于显示/var/log/btmp文件,用于显示用户错误的登陆尝试
也支持-n选项
lastlog:显示每一个用户最近一次登陆信息
显示特定用户的
-u username
basename:用户显示路径的基名
basename $0 取脚本本身的基名
mail:打开自己的邮箱系统
mail -s 指定标题
发给root邮件
cat qq |mail -s ‘hi‘ root
hostname:显示当前主机的主机名
hostname xx将hostname 改为xx
生成随机数
RANDOM
0-32768
用法举例
echo $RANDOM
随机数生成器
/dev/random 熵池空了后自己不能生成随机数
/dev/urandom 熵池空了后自己生成随机数
终端类型
console:控制台
pty:物理终端
tty:虚拟控制台(虚拟终端)
ttys:串行终端
pts/数字 :伪终端
case语句:每个分支;;结尾
case SWITCH in
value1)
statement
....
;;
value2)
statement
....
;;
*)#相当于default
statement
....
;;
esac
例如:
case $1 in
[0-9])
echo ‘a‘ ;;
[a-z])
echo‘b‘;;
esac
磁盘管理:
根是自引用的
分区:是磁盘的逻辑边界
目录只是一个路径映射表
两个指向同一个inode的不同路径:叫做硬链接
1)硬链接只能对文件创建
2)不能跨文件系统,但是可以在不同的目录下
3)创建硬链接会增加文件被链接的次数
硬链接次数小于等于一时才能真正删除一个文件
符号链接(软链接)
1)可以应用于目录
2)可以跨文件系统
3)不会增加被链接文件的链接次数
4)其大小为指定的路径所包含的字符个数
创建链接
ln [-s -v] 源文件 目的文件
-s:为软链接
-v:显示过程
不带-s为硬链接
du 目录
查看所有文件的大小
du -s 目录
整个目录大小
du -h 目录
能够进行单位换算
df [option] [file]
显示分区情况
直接打df就能用的
df -i
看inode情况
df -p
不换行显示
设备文件(不占内存,因为没有大小)
块设备:按块为单位,随机访问的设备 如硬盘
字符设备:按字符为单位,线性设备 如键盘
/dev
那两个数字的意思
主设备号
标识设备类型
次设备号
标识同一种类型中不同设备
设备号存在inode当中
创建设备文件命令
mknod [opyion] name type [major|minor]
mknod -m MODE
查看当前系统有多少硬盘以及信息
fdisk -l
管理磁盘分区:
fdisk
p:显示当前硬件的分区,包括没保存的改动
n:创建新分区
e:拓展分区
p:主分区
d:删除一个分区
w:保存退出
q:不保存退出
t:修改分区类型
L:
l:显示所支持的所有类型
高级格式化:mkfs
linux使用虚拟文件系统机制,虚拟文件系统是内核的模块
文件块大小只能是2的次方
内存空间分页面,页框大小一般是4K
bootloader在MBR里,MBR在512个字节大小的扇区里
创建文件系统时创建多少块组,这个数字保存在超级块中
超级块,GDT不能被损坏,所以需要备份多次
超级块中包含分区的全局信息
GDT:块组描述表,包含块组名,块组边界等信息
压缩、解压缩命令:只能压缩文件不能压缩目录
压缩格式:gz,bz2,xz,zip,z
默认压缩后会删除源文件
gzip: .gz
bzip2: .bz2
xz: .xz
gzip +文件名/路径:能够实现压缩,可以添加多个文件
解压缩:
gunzip (等价于 gzip -d ):
gunzip +文件名/路径 实现解压缩
解压完成后会删除原压缩文件
gzip -#:#取1-9,这是指定压缩比,默认压缩比为6
zcat:查看压缩文件
bzip2: .bz2
bzip2:比gzip有着更大的压缩比
也支持 -d
-#
默认压缩时也会删除源文件
但是
bzip2 -k 能够保留源文件
解压缩命令:
bunzip2
查看
bzcat
xz: .xz
压缩比更好,用法和gzip用户一样
解压缩
unxz
查看
xzcat/xzdec
zip:能够归档也能压缩(压缩后不删除源文件)
zip filename.zip file1 file2 ...
压缩时能够保持目录本身的结构
压缩总多文件的功能
archive:归档,归档本身不意味着压缩
例如
zip test.zip /etc/test/*
解压缩
unzip test.zip
只归档不压缩
tar
-c 创建归档文件
-f + 归档后的文件名.tar 操作的归档文件
-x:展开归档,展开后.tar不删除
--xattrs:表示在归档时保留文件的拓展属性信息
-t:不展开归档查看文件
-zcf:归档并调用gzip压缩
-zxf:调用gzip解压缩并展开归档
-jcf:调用bzip2
-jtf:调用bzip2压缩,并查看文件
-jxf:
-Jcf:调用xz
-Jxf:
甚至上面的指令可以不要-z,-j,-J因为tar可以根据文件后缀
选择压缩工具
例如:
tar -tf test.zip
cpio和tar的功能一样只是跟古老
read -p "..."
“”为提示信息
-t #后面为等候时间单位秒
例如:
read -t 5 A B
[-z $A]&& A=100
-z这里表示A超过延时时间没有值,我们手动赋值100
while循环:适用于循环次数未知的场景
while 条件 ; do
statement
....
done
例子:
#!/bin/bash
declare -i I=1
declare -i SUM=0
while [ $I -le 100 ] ; do
let SUM+=$I
let I++
done
echo的特殊用法
echo -e "\033[1mHello\033[0m,world."
echo -e "\033[33mHello\033[0m,world."
两位的3引导颜色,个位调整颜色
4引导背景符
例如:
echo -e "\033[1;37;41mHello\033[0m,world"
RAID:独立冗余磁盘阵列
文件在磁盘上以扇区存储
在文件系统级别上以datablock存储
RAID :0为条带
性能提示:读,写
冗余(容错)能力无
1为镜像
写性能降,读性能提升
有冗余能力
2
3
4:用校验码
5:轮流存校验码
读写性能提升
有冗余能力
jbod:将多块盘连接成一块盘
madam::能将任何块设备做成RAID
until循环
until condition; do
statement
....
done
for 变量 in 列表; do
循环体
done
还有一种类似C语言的写法
for ((( ));do
循环体
done
查看n次是否在线
ping -c 数字n IP号
-W timeout
AWK:报告生成工具
awk ‘pattern{action}‘ file
action:
例如:
awk ‘{print $1,$3}‘
$0表示一行的所有字段
$NF表示最后一个字段
awk - F:指定输入分割符
while,until,for
break:提前退出循环
continue:提前进入下一轮循环
制造死循环;while :;do
done
while read LINE ;do
循环体里可以对LINE进行处理
done < /文件 路径
脚本编写之函数
1)定义函数
function functionname{
command
}
或者
functionname(){
command
}
函数调用:直接在调用处写函数名就可以了
函数自定义执行状态返回值:
return n
n为0-255
接受参数的函数
函数名 参数1 参数2
$1 参数1
$2 参数2
if `command`里面相当于 echo command
进程优先级:越小越高
0-99系统安排
100-139:自己调整
nice值(-20到19),nice值越小,优先级越高
查看当前进程;
ps:process state
a:查看和终端相关的进程
x:查看和终端无关的进程
u:看谁开启终端
-e:显示所有进程
ps -o 参数1, 参数2
例如: ps -o ni,pri
pstree:显示进程树
pgrep:以grep的风格显示匹配的进程,只显示进程号
pgrp -u bash
pidof 找进程的id号
top
M:根据驻留内存大小进行排序
P:根据cpu使用百分比进行排序
T:根据累计时间进行排序
l:是否显示平均负载和启动时间
t:是否显示进行和cpu状态相关信息
m:是否显示内存相关信息
c:是否显示完整的命令行信息
q:退出top
k:终止某个进程
-d:指定刷新时间
-b:批处理模式
-n +n:批处理模式下,只显示几屏
vmstat:系统状态查看命令
free
kill:终止进程
kill pid
kill %作业号
killal command
pkill和pgrep类似
bg:让后台的停止作业继续运行
bg [作业号]
jobs:查看后台所有作业
作业号不同于进程号
+:命令将默认操作的作业
-:+结束后操作的作业
fg:将后台作业调回前台
进程状态:
D:不可中断的睡眠
S:可中断的睡眠
R:运行或就绪
T:停止
Z:僵尸
<:高优先级进程
N:低优先级进程
+:前台进程组中的进程
l:多线程进程
s:会话进程首进程
进程间通信(IPC)
共享内存
信号
semaphore(旗语)
重要的信号;
1 SIGHUP:让一个进程不用重启就可读其配置文件,并让新的配置信息生效
2 SIGINT 中断一个进程
9 SIGKILL 杀死一个进程
15 SIGTERM 终止一个进程,默认信号
指定一个信号:
信号号码:kill -l
信号名称;kill -SIGKILL
信号名称缩写:kill -KILL
调整nice值
调整已经启动的进程的:
renice NI PID
在启动时指定nice值
nice -n NI COMMAND
前台命令送到后台
ctrl+z:把正在前台的作业送往后台
command &:让命令在后台执行
sudo:某个用户能够以另外哪一个用户的身份通过哪些主机来执行什么命令
sudo 命令的绝对路径
sudo后会要输入密码(当前使用者的密码),并在第一次输入密码后保存5分钟
sudo -k 关闭保存密码5分钟这一特性
sudo -l 列出当前用户可以使用的所有sudo类的命令
sudoers文件里添加信息:
who which_host=(run as who) [tag]command
对称加密:用相同密钥,传输速度快
单向加密算法:提取特征码,保证数据的完整性
协商生成算法:密钥交换算法(密钥随时替换)
非对称加密算法:(公钥加密算法)
密钥队:
公钥:p(公开的)
私钥:s
发送方用自己的私钥加密数据,可以实现身份验证
发送方用对方的公钥加密数据可以保证数据的机密性
awk:报告生成器
awk [options] ‘script‘ file1 file2
awk [options] ‘pattern {action}‘ file1 file2
例如: awk ‘{print $1}‘ test.txt
awk ‘BEGIN{OFS=":"}{print $1,$2,$3,$4}‘ test.txt
插入:awk ‘BEGIN{OFS=":"}{print $1,"hello",$2}‘ test.txt
awk变量
FS:field separator 默认是空白字符,读取文本时所使用的字段分割符
RS:record separator 默认是换行符,输入文本信息所使用的换行符
OFS:output field separator
ORS:output row separator
awk -F:输入分割符号:
等价于awk ‘{FS=":"}‘
NR:the number of input records,awk命令所处理的记录数,如果有多个文件,这个数目会吧处理的多个文件中统一计数(一起计数)
NF:number of field:当前记录的field个数
FNR:与NR不同的是,FNR用于记录正处理的行是当前这一文件中被总共处理的行数(各自计数)
ARGV:数组,保存命令行本身这个字符串,如awk‘{print $0}‘ a.txt b.txt这个命令中,ARGV[0]保存awk,ARGV[1]保存a.txt
ARGC:awk命令的参数的个数
FILENAME:awk命令所处理的文件的名称
ENVIRON:当前shell环境变量及其值的关联数组
变量赋值
awk -v 变量名=“ ”
或者
awk ‘‘BEGIN{var="variable testing";print var}‘
printf用法
例子:
awk -F: ‘{printf "%-15s %i\n",$1,$3}‘/etc/passwd
awk支持的pattern
1.正则表达式,格式为/regular expression/
2.表达式,其值为非0或者为非空字符时满足条件,如:$1==" ",$1~“模式”
3.指定的匹配范围,格式为pat1,pat2,pat1和pat2为模式
4.BEGIN/END:特殊模式,仅在awk命令执行前运行一次或者结束前运行一次
5.Empty(空模式):匹配任意输入行
例子:
打印表头:
awk -F: ‘BEGIN{print "Username ID Shell"}{printf "%-10s%-10s%-20s\n",$1,$3,$7}‘ /etc/passwd
常见的action:
1.expression
2.control statements
3.compound statements
4.input statements
5.output statements
控制语句:
1.if-else
语法:if (condition) {then-body}else {[else-body]}
例子:
awk -F: ‘{if ($1=="root") print $1, "admin"; else print $1,"common user"}‘ /etc/passwd
awk -F: ‘{if ($1=="root") printf"%-15s: %s\n",$1,"admin";else printf "%-15s: %s\n",$1,"common user"}‘/etc/passwd
awk -F: -v sum=0 ‘{if ($3>=500)sum++}END{print sum}‘ /etc/passwd
2.while
语法:while (condition){statement1;statement2;...}
awk -F: ‘{i=1;while(i<=3){print $i,i++}}‘ /etc/passwd
3.do-while
语法:do{statement1,statement2,...}while(condition)
awk -F: ‘{i=1;do{print $i;i+++}while(i<=3)}‘ /etc/passwd
4.for
语法:for (variable assignment;condition;iteration process) {statement1,statement2,...}
awk -F: ‘{for(i=1;i<=3;i++)print $i}‘ /etc/passwd
for循环还可以用来遍历数组元素;
语法:for(i in array){statement1,statement2,...}
awk -F: ‘NF!~/^$/{bash{NF}++}END{for (A in bash){printf "%15s:%i\n",A,bash[A]}}‘ /etc/passwd
5.case
语法:switch (expression) {case VALUE or /正则表达式/ :statement1,statement2,...default:statement1,...}
6.break 和continue
常用于循环或者case语句中
7.next
提前结束对本行文本的处理,并接着处理下一行:例如,下面的命令将显示其ID为奇数的用户
awk -F: ‘{if($3%2==0) next;print $1,$3}‘ /etc/passwd
数组
for (var in array){statement1,...}
例子:
netstat -ant |awk ‘/^tcp/{++s[$NF]}END{for(a in S)print a,S[a]}‘
每出现一被/^tcp/模式匹配到的行,数组是S[$NF]就加一,NF为当前匹配到的行的最后一个字段,此处用其值作为数组S的元素索引
awk ‘{counts[$1]++};END{for(url in counts)print counts[url],url}‘ /var/log/httpd/access_log
用户与上一个例子相同,用于统计某日志文件中IP地址的访问量
先放上来呗,我再慢慢改。。。。。。