shell命令笔记大全

1、简要说明命令的作用(显示命令所处的man分类页面)
which command
2、更加详细的说明文档
info command
3、查看程序的binary文件所在路径
which command
4、查看程序的搜索路径
whereis command
5、创建和删除

创建:mkdir
删除:rm
删除非空目录:rm -rf file目录
删除日志 rm *log (等价: $find ./ -name “*log” -exec rm {} ;)
移动:mv
复制:cp (复制目录:cp -r )

6、目录切换

找到文件/目录位置:cd
切换到上一个工作目录: cd -
切换到home目录: cd or cd ~
显示当前路径: pwd
更改当前工作路径为path: $cd path

7 、查找文件和目录 find/locate

搜寻文件或目录:
$find ./ -name "core*" | xargs file
find是实时查找,如果需要更快的查询,可试试locate;locate会为文件系统建立索引数据库,如果有文件更新,需要定期执行更新命令来更新索引库:
$locate string
寻找包含有string的路径:
$updatedb
与find不同,locate并不是实时查找。你需要更新数据库,以获得最新的文件索引信息。

8、查看文件内容

查看文件:cat vi head tail more less

显示时同时显示行号:
$cat -n
按页显示列表内容:
$ls -al | more
只看前10行:
$head - 10 **
显示文件第一行:
$head -1 filename
显示文件倒数第五行:
$tail -5 filename
查看两个文件间的差别:
$diff file1 file2
动态显示文本最新信息:
$tail -f crawler.log

9、文件目录和权限修改

改变文件的拥有者 chown
改变文件读、写、执行等属性 chmod
递归子目录修改: chown -R tuxapp source/
增加脚本可执行权限: chmod a+x myscript

10、给文件增加别名

创建符号链接/硬链接:
ln cc ccAgain :硬连接;删除一个,将仍能找到;
ln -s cc ccTo :符号链接(软链接);删除源,另一个无法使用;(后面一个ccTo 为新建的文件)

11、管道和重定向

批处理命令连接执行,使用 |
串联: 使用分号 ;
前面成功,则执行后面一条,否则,不执行:&&
前面失败,则后一条执行: ||
ls /proc && echo  suss! || echo failed.
能够提示命名是否执行成功or失败;

重定向
ls proc/*.c > list 2> &l 将标准输出和标准错误重定向到同一文件;

12、 find文件查找

查找txt和pdf文件:

find . \( -name "*.txt" -o -name "*.pdf" \) -print
正则方式查找.txt和pdf:

find . -regex  ".*\(\.txt|\.pdf\)$"
-iregex: 忽略大小写的正则

否定参数 ,查找所有非txt文本:

find . ! -name "*.txt" -print
指定搜索深度,打印出当前目录的文件(深度为1):

find . -maxdepth 1 -type f

按类型搜索
find . -type d -print  //只列出所有目录
-type f 文件 / l 符号链接 / d 目录

按时间搜索
-atime 访问时间 (单位是天,分钟单位则是-amin,以下类似)
-mtime 修改时间 (内容被修改)
-ctime 变化时间 (元数据或权限变化)
最近第7天被访问过的所有文件:

find . -atime 7 -type f -print
最近7天内被访问过的所有文件:

find . -atime -7 -type f -print
查询7天前被访问过的所有文件:

find . -atime +7 type f -print
按大小搜索:
w字 k M G 寻找大于2k的文件:

find . -type f -size +2k
按权限查找:

find . -type f -perm 644 -print //找具有可执行权限的所有文件
按用户查找:

find . -type f -user weber -print// 找用户weber所拥有的文件

13、grep文本搜索

-o 只输出匹配的文本行 VS -v 只输出没有匹配的文本行
-c 统计文件中包含文本的次数
grep -c “text” filename
-n 打印匹配的行号
-i 搜索时忽略大小写
-l 只打印文件名

14、xargs命令行参数转换
xargs 能够将输入数据转化为特定命令的命令行参数;这样,可以配合很多命令来组合使用。比如grep,比如find; - 将多行输出转化为单行输出

xargs参数说明

-d 定义定界符 (默认为空格 多行的定界符为 n)
-n 指定输出为多行
-I {} 指定替换字符串,这个字符串在xargs扩展时会被替换掉,用于待执行的命令需要多个参数时
-0:指定0为输入定界符
cat file.txt | xargs -I {} ./command.sh -p {} -1

#统计程序行数
find source_dir/ -type f -name "*.cpp" -print0 |xargs -0 wc -l

15、sort排序

字段说明

-n 按数字进行排序 VS -d 按字典序进行排序
-r 逆序排序
-k N 指定按第N列排序

16、uniq消除重复行

消除重复行
sort unsort.txt | uniq
统计各行在文件中出现的次数
sort unsort.txt | uniq -c
找出重复行
sort unsort.txt | uniq -d
可指定每行中需要比较的重复内容:-s 开始位置 -w 比较字符数

17、tr进行转换

通用用法
echo 12345 | tr '0-9' '9876543210' //加解密转换,替换对应字符
cat text| tr '\t' ' '  //制表符转空格
tr删除字符
cat file | tr -d '0-9' // 删除所有数字
-c 求补集

cat file | tr -c '0-9' //获取文件中所有数字
cat file | tr -d -c '0-9 \n'  //删除非数字数据
tr压缩字符
tr -s 压缩文本中出现的重复字符;最常用于压缩多余的空格:

cat file | tr -s ' '
字符类
tr中可用各种字符类:
alnum:字母和数字
alpha:字母
digit:数字
space:空白字符
lower:小写
upper:大写
cntrl:控制(非可打印)字符
print:可打印字符
使用方法:tr [:class:] [:class:]

tr '[:lower:]' '[:upper:]'

18、cut切分文本

截取文件的第2列和第4列
cut -f2,4 filename
去文件除第3列的所有列
cut -f3 --complement filename
-d 指定定界符
cat -f2 -d";" filename
cut 取的范围
N- 第N个字段到结尾
-M 第1个字段为M
N-M N到M个字段
cut 取的单位
-b 以字节为单位
-c 以字符为单位
-f 以字段为单位(使用定界符)
示例:

cut -c1-5 file //打印第一到5个字符
cut -c-2 file  //打印前2个字符
截取文本的第5到第7列

$echo string | cut -c5-7

19、paste 按列拼接文本

将两个文本按列拼接到一起;

cat file1
1
2

cat file2
colin
book

paste file1 file2
1 colin
2 book
默认的定界符是制表符,可以用-d指明定界符:

paste file1 file2 -d ","
1,colin
2,book

20、wc统计行和字符

$wc -l file // 统计行数

$wc -w file // 统计单词数

$wc -c file // 统计字符数

21、sed 文本替换利器

首处替换
sed 's/text/replace_text/' file   //替换每一行的第一处匹配的text
全局替换
sed 's/text/replace_text/g' file
默认替换后,输出替换后的内容,如果需要直接替换原文件,使用-i:

sed -i 's/text/repalce_text/g' file
移除空白行
sed '/^$/d' file
变量转换
已匹配的字符串通过标记&来引用.

echo this is en example | sed 's/\w+/[&]/g'
$>[this]  [is] [en] [example]
子串匹配标记
第一个匹配的括号内容使用标记 1 来引用

sed 's/hello\([0-9]\)/\1/'
双引号求值
sed通常用单引号来引用;也可使用双引号,使用双引号后,双引号会对表达式求值:

sed 's/$var/HLLOE/'
当使用双引号时,我们可以在sed样式和替换字符串中指定变量;

eg:
p=patten
r=replaced
echo "line con a patten" | sed "s/$p/$r/g"
$>line con a replaced
其它示例
字符串插入字符:将文本中每行内容(ABCDEF) 转换为 ABC/DEF:

sed 's/^.\{3\}/&\//g' file

22、awk数据流处理工具

*   awk脚本结构
awk ' BEGIN{ statements } statements2 END{ statements } '
*   工作方式
1.执行begin中语句块;
2.从文件或stdin中读入一行,然后执行statements2,重复这个过程,直到文件全部被读取完毕;
3.执行end语句块;

print 打印当前行

*   使用不带参数的print时,会打印当前行
echo -e "line1\nline2" | awk 'BEGIN{print "start"} {print } END{ print "End" }'

*   print 以逗号分割时,参数以空格定界;

echo | awk ' {var1 = "v1" ; var2 = "V2"; var3="v3"; \
print var1, var2 , var3; }'
$>v1 V2 v3

*   使用-拼接符的方式(”“作为拼接符);
echo | awk ' {var1 = "v1" ; var2 = "V2"; var3="v3"; \
print var1"-"var2"-"var3; }'
$>v1-V2-v3

特殊变量: NR NF $0 $1 $2
NR:表示记录数量,在执行过程中对应当前行号;
NF:表示字段数量,在执行过程总对应当前行的字段数;
$0:这个变量包含执行过程中当前行的文本内容;
$1:第一个字段的文本内容;
$2:第二个字段的文本内容;

echo -e "line1 f2 f3\n line2 \n line 3" | awk '{print NR":"$0"-"$1"-"$2}'

*   打印每一行的第二和第三个字段
awk '{print $2, $3}' file

*   统计文件的行数
awk ' END {print NR}' file

*   累加每一行的第一个字段
echo -e "1\n 2\n 3\n 4\n" | awk 'BEGIN{num = 0 ;
print "begin";} {sum += $1;} END {print "=="; print sum }'

传递外部变量
echo | awk '{print vara}' vara=$var #  输入来自stdin
awk '{print vara}' vara=$var file # 输入来自文件

用样式对awk处理的行进行过滤
awk 'NR < 5' #行号小于5
awk 'NR==1,NR==4 {print}' file #行号等于1和4的打印出来
awk '/linux/' #包含linux文本的行(可以用正则表达式来指定,超级强大)
awk '!/linux/' #不包含linux文本的行

设置定界符

使用-F来设置定界符(默认为空格):
awk -F: '{print $NF}' /etc/passwd

读取命令输出

使用getline,将外部shell命令的输出读入到变量cmdout中:
echo | awk '{"grep root /etc/passwd" | getline cmdout; print cmdout }'

在awk中使用循环
for(i=0;i<10;i++){print $i;}
for(i in array){print array[i];}

index(string,search_string):返回search_string在string中出现的位置

sub(regex,replacement_str,string):将正则匹配到的第一处内容替换为replacement_str;

match(regex,string):检查正则表达式是否能够匹配字符串;

length(string):返回字符串长度

23、df查看磁盘空间

查看磁盘空间利用大小:
df -h
-h: human缩写,以易读的方式显示结果(即带单位:比如M/G,如果不加这个参数,显示的数字以B为单位)

查看当前目录所占空间大小:
du -sh
-h 人性化显示
-s 递归整个目录的大小

24、打包和压缩

打包
打包是将多个文件归并到一个文件:

tar -cvf etc.tar /etc <==仅打包,不压缩!
-c :打包选项
-v :显示打包进度
-f :使用档案文件
注:有的系统中指定参数时不需要在前面加上-,直接使用tar xvf

压缩
$gzip demo.txt
生成 demo.txt.gz

25、解包和解压缩

解包

tar -xvf demo.tar
-x 解包选项

解压后缀为 .tar.gz的文件 1. 先解压缩,生成**.tar:

$gunzip    demo.tar.gz
解包:

$tar -xvf  demo.tar
$bzip2 -d demo.tar.bz2
bz2解压:

tar jxvf demo.tar.bz2
如果tar 不支持j,则同样需要分两步来解包解压缩,使用bzip2来解压,再使用tar解包:

bzip2 -d  demo.tar.bz2
tar -xvf  demo.tar
-d decompose,解压缩

tar解压参数说明:

-z 解压gz文件
-j 解压bz2文件
-J 解压xz文件

26、查询进程

查询正在运行的进程信息
$ps -ef
eg:查询归属于用户colin115的进程
$ps -ef | grep colin115
$ps -lu colin115
查询进程ID(适合只记得部分进程字段)

$pgrep 查找进程
eg:查询进程名中含有re的进程
[/home/weber#]pgrep -l re
2 kthreadd
28 ecryptfs-kthrea
29515 redis-server
以完整的格式显示所有的进程

$ps -ajx
显示进程信息,并实时更新

$top
查看端口占用的进程状态:

lsof -i:3306
查看用户username的进程所打开的文件

$lsof -u username
查询init进程当前打开的文件

$lsof -c init
查询指定的进程ID(23295)打开的文件:

$lsof -p 23295
查询指定目录下被进程开启的文件(使用+D 递归目录):

$lsof +d mydir1/

27、终止进程

杀死指定PID的进程 (PID为Process ID)

$kill PID
杀死相关进程

kill -9 3434
杀死job工作 (job为job number)

$kill %job

28、进程监控

查看系统中使用CPU、使用内存最多的进程;

$top
(->)P
输入top命令后,进入到交互界面;接着输入字符命令后显示相应的进程状态:

对于进程,平时我们最常想知道的就是哪些进程占用CPU最多,占用内存最多。以下两个命令就可以满足要求:

P:根据CPU使用百分比大小进行排序。
M:根据驻留内存大小进行排序。
i:使top不显示任何闲置或者僵死进程。

29、分析线程栈

使用命令pmap,来输出进程内存的状况,可以用来分析线程堆栈;

$pmap PID

eg:
[/home/weber#]ps -fe| grep redis
weber    13508 13070  0 08:14 pts/0    00:00:00 grep --color=auto redis
weber    29515     1  0  2013 ?        02:55:59 ./redis-server redis.conf
[/home/weber#]pmap 29515
29515:   ./redis-server redis.conf
08048000    768K r-x--  /home/weber/soft/redis-2.6.16/src/redis-server
08108000      4K r----  /home/weber/soft/redis-2.6.16/src/redis-server
08109000     12K rw---  /home/weber/soft/redis-2.6.16/src/redis-server

30、监控 CPU

查看CPU使用率

$sar -u

eg:
$sar -u 1 2
[/home/weber#]sar -u 1 2
Linux 2.6.35-22-generic-pae (MyVPS)     06/28/2014      _i686_  (1 CPU)

09:03:59 AM     CPU     %user     %nice   %system   %iowait    %steal     %idle
09:04:00 AM     all      0.00      0.00      0.50      0.00      0.00     99.50
09:04:01 AM     all      0.00      0.00      0.00      0.00      0.00    100.00
后面的两个参数表示监控的频率,比如例子中的1和2,表示每秒采样一次,总共采样2次;

查看CPU平均负载

$sar -q 1 2
sar指定-q后,就能查看运行队列中的进程数、系统上的进程大小、平均负载等;

31、查询内存

查看内存使用状况 sar指定-r之后,可查看内存使用状况;

$sar -r 1 2
09:08:48 AM kbmemfree kbmemused  %memused kbbuffers  kbcached  kbcommit   %commit  kbactive   kbinact
09:08:49 AM     17888    359784     95.26     37796     73272    507004     65.42    137400    150764
09:08:50 AM     17888    359784     95.26     37796     73272    507004     65.42    137400    150764
Average:        17888    359784     95.26     37796     73272    507004     65.42    137400    150764
查看内存使用量

$free -m

32、查询网络服务和端口

netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Memberships) 等等。

列出所有端口 (包括监听和未监听的):

netstat -a
列出所有 tcp 端口:

netstat -at
列出所有有监听的服务状态:

netstat -l
使用netstat工具查询端口:

$netstat -antp | grep 6379
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      25501/redis-server

$ps 25501
  PID TTY      STAT   TIME COMMAND
25501 ?        Ssl   28:21 ./redis-server ./redis.conf

lsof(list open files)是一个列出当前系统打开文件的工具。在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等; 在查询网络端口时,经常会用到这个工具。

查询7902端口现在运行什么程序:

#分为两步
#第一步,查询使用该端口的进程的PID;
    $lsof -i:7902
    COMMAND   PID   USER   FD   TYPE    DEVICE SIZE NODE NAME
    WSL     30294 tuapp    4u  IPv4 447684086       TCP 10.6.50.37:tnos-dp (LISTEN)

#查到30294
#使用ps工具查询进程详情:
$ps -fe | grep 30294
tdev5  30294 26160  0 Sep10 ?        01:10:50 tdesl -k 43476
root     22781 22698  0 00:54 pts/20   00:00:00 grep 11554

33、网络路由

查看路由状态:

$route -n
发送ping包到地址IP:

$ping IP
探测前往地址IP的路由路径:

$traceroute IP
DNS查询,寻找域名domain对应的IP:

$host domain
反向DNS查询:

$host IP

34、镜像下载

直接下载文件或者网页:

wget url
常用选项:

–limit-rate :下载限速
-o:指定日志文件;输出都写入日志;
-c:断点续传

35、登录

SSH登陆:

$ssh ID@host
ssh登陆远程服务器host,ID为用户名。

ftp/sftp文件传输:

$sftp ID@host
登陆服务器host,ID为用户名。sftp登陆后,可以使用下面的命令进一步操作:

get filename # 下载文件
put filename # 上传文件
ls # 列出host上当前路径的所有文件
cd # 在host上更改当前路径
lls # 列出本地主机上当前路径的所有文件
lcd # 在本地主机更改当前路径
lftp同步文件夹(类似rsync工具):

lftp -u user:pass host
lftp user@host:~> mirror -n

36、网络复制

将本地localpath指向的文件上传到远程主机的path路径:

$scp localpath ID@host:path
以ssh协议,遍历下载path路径下的整个文件系统,到本地的localpath:

$scp -r ID@site:path localpath

37、用户

添加用户
$useradd -m username
该命令为用户创建相应的帐号和用户目录/home/username;
用户添加之后,设置密码:
密码以交互方式创建:
$passwd username

$userdel -r username
不带选项使用 userdel,只会删除用户。用户的家目录将仍会在/home目录下。要完全的删除用户信息,使用-r选项;

帐号切换 登录帐号为userA用户状态下,切换到userB用户帐号工作:

$su userB
进入交互模型,输入密码授权进入;

38、用户的组

默认情况下,添加用户操作也会相应的增加一个同名的组,用户属于同名组; 查看当前用户所属的组:

$groups
一个用户可以属于多个组,将用户加入到组:

$usermod -G groupNmame username
变更用户所属的根组(将用加入到新的组,并从原有的组中除去):

$usermod -g groupName username

系统的所有用户及所有组信息分别记录在两个文件中:/etc/passwd , /etc/group 默认情况下这两个文件对所有用户可读:

查看所有用户及权限:

$more /etc/passwd
查看所有的用户组及权限:

$more /etc/group

39、用户权限

使用ls -l可查看文件的属性字段,文件属性字段总共有10个字母组成,第一个字母表示文件类型,如果这个字母是一个减号”-”,则说明该文件是一个普通文件。字母”d”表示该文件是一个目录,字母”d”,是dirtectory(目录)的缩写。 后面的9个字母为该文件的权限标识,3个为一组,分别表示文件所属用户、用户所在组、其它用户的读写和执行权限; 例如:

[/home/weber#]ls -l /etc/group
-rwxrw-r-- colin king 725 2013-11-12 15:37 /home/colin/a
表示这个文件对文件拥有者colin这个用户可读写、可执行;对colin所在的组(king)可读可写;对其它用户只可读

使用chmod命令更改文件的读写权限,更改读写权限有两种方法,一种是字母方式,一种是数字方式

字母方式:

$chmod userMark(+|-)PermissionsMark
userMark取值:

u:用户
g:组
o:其它用户
a:所有用户
PermissionsMark取值:

r:读
w:写
x:执行
例如:

$chmod a+x main         对所有用户给文件main增加可执行权限
$chmod g+w blogs        对组用户给文件blogs增加可写权限
数字方式:

数字方式直接设置所有权限,相比字母方式,更加简洁方便;

使用三位八进制数字的形式来表示权限,第一位指定属主的权限,第二位指定组权限,第三位指定其他用户的权限,每位通过4(读)、2(写)、1(执行)三种数值的和来确定权限。如6(4+2)代表有读写权,7(4+2+1)有读、写和执行的权限。

例如:

$chmod 740 main     将main的用户权限设置为rwxr-----

40、环境变量

bashrc与profile都用于保存用户的环境信息,bashrc用于交互式non-loginshell,而profile用于交互式login shell。

/etc/profile,/etc/bashrc 是系统全局环境变量设定
~/.profile,~/.bashrc用户目录下的私有环境变量设定

当登入系统获得一个shell进程时,其读取环境设置脚本分为三步:

首先读入的是全局环境变量设置文件/etc/profile,然后根据其内容读取额外的文档,如/etc/profile.d和/etc/inputrc
读取当前登录用户Home目录下的文件~/.bash_profile,其次读取~/.bash_login,最后读取~/.profile,这三个文档设定基本上是一样的,读取有优先关系
读取~/.bashrc
~/.profile与~/.bashrc的区别:

这两者都具有个性化定制功能
~/.profile可以设定本用户专有的路径,环境变量,等,它只能登入的时候执行一次
~/.bashrc也是某用户专有设定文档,可以设定路径,命令别名,每次shell script的执行都会使用它一次
例如,我们可以在这些环境变量中设置自己经常进入的文件路径,以及命令的快捷方式:

.bashrc
alias m='more'
alias cp='cp -i'
alias mv='mv -i'
alias ll='ls -l'
alias lsl='ls -lrt'
alias lm='ls -al|more'

log=/opt/applog/common_dir
unit=/opt/app/unittest/common

.bash_profile
. /opt/app/tuxapp/openav/config/setenv.prod.sh.linux
export PS1='$PWD#'
通过上述设置,我们进入log目录就只需要输入cd $log即可;

41、查询系统版本

查看Linux系统版本:

$uname -a
$lsb_release -a
查看Unix系统版本:操作系统版本:

$more /etc/release

42 、查询硬件信息

查看CPU使用情况:

$sar -u 5 10
查询CPU信息:

$cat /proc/cpuinfo
查看CPU的核的个数:

$cat /proc/cpuinfo | grep processor | wc -l
查看内存信息:

$cat /proc/meminfo
显示内存page大小(以KByte为单位):

$pagesize
显示架构:

$arch

43、设置系统时间

显示当前系统时间:

$date
设置系统日期和时间(格式为2014-09-15 17:05:00):

$date -s 2014-09-15 17:05:00
$date -s 2014-09-15
$date -s 17:05:00
设置时区:

选择时区信息。命令为:tzselect
根据系统提示,选择相应的时区信息。
强制把系统时间写入CMOS(这样,重启后时间也正确了):

$clock -w
警告

设置系统时间需要root用户权限.

格式化输出当前日期时间:

$date +%Y%m%d.%H%M%S
>20150512.173821

44、检测和设置系统资源限制

显示当前所有的系统资源limit 信息:

ulimit – a
对生成的 core 文件的大小不进行限制:

ulimit – c unlimited

更多关注公众号


qrcode_for_gh_e6ca5e404568_258.jpg

你可能感兴趣的:(shell命令笔记大全)