linux学习笔记2 - linux常用命令

转载请标注原链接:http://www.cnblogs.com/xczyd/p/5543731.html

第一篇博客:linux学习笔记1-ubuntu的安装与基本设置 之中,已经介绍了如何安装linux操作系统,以及一些基本的设置修改。

本篇博客主要介绍linux中的一些常用的命令(主要是shell命令)

==============================================

文件/文件夹相关操作

#在当前目录下,创建一个名为test的文件夹
mkdir test
#在当前目录下,删除一个名为test.txt的文件
rm test.txt
#在当前目录下,删除一个名为test的文件夹,以及其中的所有内容
rm -r test
#在当前目录下,删除一个名为test的文件夹,以及其中的所有内容,而且不需要再确认
rm -rf test
#在当前目录下,把文件或文件夹A移动到文件夹B的下面
mv A B
#在当前目录下,把文件或文件夹A复制到文件夹B的下面
cp A B
#查看文件(非隐藏文件)
ls [PATH]
#查看所有文件(包含隐藏文件)
ls [PATH] -a
#在当前目录下,只显示隐藏文件
ls [PATH] -d .*
#比较文件夹A和文件夹B之间内容的差别
diff -ruNa A B

注:PATH为要查找的目录,不填会选取当前目录

==============================================

结果筛选

在任意命令后面加 | grep XXX 就能对结果做出正向筛选

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中包含了"text"的结果
find -name "*.h" | grep text

在任意命令后面加 | grep -v XXX 就能对结果做出反向筛选

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中不包含"text"的结果
find -name "*.h" | grep -v text

-i参数可以对筛选的文本忽略大小写

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中包含"text"(不考虑大小写)的结果
find -name "*.h" | grep -i text

-E参数和-e参数都是用来进行“或”类型的筛选

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中包含"ABC"或者包含"DEF"结果
find -name "*.h" | grep -E "ABC|DEF" #对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中包含"abc"或者包含"def"结果
find -name "*.h" | grep -e abc -e edf

可以注意到,与find命令类似,grep命令也是默认支持正则表达式的。

想要进行完全匹配,可以使用-w参数

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径恰好为"ruby.h"的行
find -name "*.h" | grep -w "ruby.h"

可以通过叠加的方式来进行“与”类型的筛选,比如:

#对使用find命令找到的以".h"为结尾的文件作筛选,找到文件路径中不包含"text",且包含"doc"和"ppt"的结果
find -name "*.h" | grep -v text | grep doc | grep ppt

grep命令可以通过-Po参数支持从结果中提取部分内容。例如,一个名为example.txt的文本文件包含了若干行格式如下的json数据:

{"uid":"300","duration":"100ms","reasonList":["wt","dl"],"props":{"rec_level":"ALBUM"}}

我们希望提取出duration字段的结果,则可以使用命令:

#对example.txt的每一行,提取出其中"duration":"XXXms"中XXX的具体值
cat example.txt | grep -Po '"duration":".*?ms"' | grep -Po '\d+' 

更多参数及用法可以参考:http://man.linuxde.net/grep

==============================================

查找文件

#查找所有".h"文件
find [PATH] -name "*.h"
#查找文件名中包含"test"的文件
find [PATH] -name "*test*"
#查找所有".txt"文件,且这些文件的内容中含有"hello"字符串
find [PATH] -name "*.h" | xargs grep "hello"
#查找所有".h"和".c"文件,且这些文件的文本内容中含有"hello"字符串
find [PATH] -name "*.h" or -name "*.c" | xargs grep "hello"

注:PATH为要查找的目录,不填会选取当前目录

更多参数及用法可以参考:http://blog.csdn.net/cupidove/article/details/8767450

==============================================

连接远程的linux机器

#以用户名root登陆IP地址为10.2.43.147的机器
ssh root@10.2.43.147
ssh 10.2.43.147 -l root
#以指定端口8080,指定用户user登陆IP地址为10.171.1.26的机器
ssh 10.171.1.26 -l user -p 8080
#断开ssh连接
exit
注意,如果不指定用户名就进行连接的话,会使用当前机器的用户名作为默认用户名。

==============================================

以某用户名来运行程序

此命令大都是为了防止运行程序的时候没有对应的权限,常见的场景为:

#以hbase用户的身份执行hbase shell
sudo -u hbase hbase shell
#以hdfs用户的身份查看hdfs文件系统
sudo -u hdfs hdfs dfs -ls /
#以yarn用户的身份输出进程40404的jstack,并重定向到/tmp/jst001
sudo -u yarn /usr/java/1.7/bin/jstack 40404 > /tmp/jst001

==============================================

修改文件的访问权限

#给一个目录或文件赋予777权限
chmod -R 777 [PATH]

首先-R代表修改当前文件夹的所有子文件夹,在很多系统命令(比如scp,mv等)都代表这个意思

777是一个8进制的权限代码,每一个数字依次代表属主权限,组权限和其他用户权限。

权限包括读权限,写权限和执行权限。如果有权限就在这个bit位上置1否则置0。

所以数字7(对应bit为111)就代表有读、写、执行权限

PS:不要贪省力修改一个内容很多的文件夹的用户权限,尤其是系统文件。

linux有一个很蛋疼的机制,部分系统命令在执行之前会检查命令本身的权限,权限过高会被认为不安全

而终止执行,比如/usr/lib中包含的sudo命令。一但把/usr/lib的整个文件夹权限改为了777,sudo就没办法

执行了,很可能连恢复都恢复不过来,只能重装

==============================================

查看和设置系统时间

#查看当前系统时间
date
#设置系统时间
date -s "YYYYMMDD HH:mm:ss"
date -s "YYYY-MM-DD HH:mm:ss"
date -s "HH:mm:ss YYYY-MM-DD"
date -s "HH:mm:ss YYYYMMDD"
#与IP为172.16.1.61的节点进行时间同步:
ntpdate -u 172.16.1.61

中国国家授时中心:210.72.145.44

NTP服务器(上海) :ntp.api.bz

美国:time.nist.gov

复旦:ntp.fudan.edu.cn

微软公司授时主机(美国) :time.windows.com

台警大授时中心(*):asia.pool.ntp.org

==============================================

磁盘空间及文件夹大小查看

#查看当前磁盘空间
df -hl
#以兆(M)的形式显示当前文件夹的大小
du -sm
#以兆(M)的形式显示当前文件夹中每一个子文件或者子文件夹的大小
du -am

==============================================

查看系统网络/磁盘/CPU/内存等使用情况

#每隔5秒输出一次当前系统的网络/磁盘/CPU/内存等的使用情况
dstat -tcmndri 5

如果没有dstst就用yum install dstat或者apt-get install dstat安装一下

==============================================

查看环境变量

#显示当前环境的变量名和变量值
export #显示当前环境下名称为TEST的变量的值
export TEST

==============================================

Linux系统分析工具-sar命令

#输出所有系统报告,如CPU、磁盘、内存等
sar -A

该命令的结果存储在/var/log/sar下,可以根据时间寻找对应的信息

具体的描述见:http://lovesoo.org/linux-sar-command-detailed.html

==============================================

向远程linux机器传送文件/从远程linux机器下载文件

#将当前目录下的a.txt文件发送到IP地址为10.1.1.1的机器的/home/user目录下
scp a.txt root@10.1.1.1:/home/user/
#将IP地址为10.1.1.1的机器的home/user/b文件下发送到本地的/home/user目录下
scp -r root@10.1.1.1:/home/user/b /home/user
==============================================

查看进程

#查看所有活动进程
ps -ef

更多参数及用法可以参考:http://blog.sina.com.cn/s/blog_4af3b94f0101lhpu.html

==============================================

检测磁盘是否损坏

#检查/dev/sda这块盘是否存在损坏
badblocks -s -v -o /root/badblocks.log /dev/sda

一般检查时间是比较长的

==============================================

JAVA相关命令

#查看当前系统的java进程
jps

有时会出现process information unavailable的情况,此时需要做两件事:

(1)到/tmp目录下,删除名称为hsperfdata_{processname}的文件夹

(2)到/var/run/{processname}目录下,删除.pid文件

再执行jps,显示结果就正常了

==============================================

查找一个可执行文件所在路径 

#查看ant命令的可执行文件所在路径
which ant

如果你安装好了ant,就会显示文件所在的路径,比如:

/usr/local/Cellar/ant/1.9.3/bin/ant

注意,普通文件是没有办法用which来查询到的

==============================================

查找一个文件的路径

#查找名为android的文件所在路径
which android

注意,可执行文件也可以用这个命令来获得路径

==============================================

vi命令大全

【进入vi的命令】

#打开或新建一个名为example.txt的文件,并将光标置于第一行首
vi example.txt
#打开一个名为example.txt的文件,并将光标置于第10行首
vi +10 example.txt
#打开一个名为example.txt的文件,并将光标置于最后一行首
vi + example.txt  
#打开一个名为example.txt的文件,并将光标置于第一个"ABC"字符串处
vi +/ABC example.txt
#在上次正用vi编辑时发生系统崩溃,恢复example.txt
vi -r example.txt  
#打开多个文件,依次进行编辑
vi example1.txt example2.txt example3.txt …  

【移动光标类命令】

h 或 Backspace 或 左箭头  光标左移一个字符

l 或 space 或 右箭头  光标右移一个字符

k 或 Ctrl+p 或 上箭头  光标上移一行

j 或 Enter 或 Ctrl + n 或  下箭头  光标下移一行

w 或 W  光标右移一个字至字首

b 或 B  光标左移一个字至字首

e 或 E  光标右移一个字至字尾

)  光标移至句尾

(  光标移至句首

}  光标移至段落开头

{  光标移至段落结尾

nG  光标移至第n行首

n+  光标下移n行

n-  光标上移n行

n$  光标移至第n行尾

H  光标移至屏幕顶行

M  光标移至屏幕中间行

L  光标移至屏幕最后行

0  光标移至当前行首 (注意是数字零)

$  光标移至当前行尾

PS:句首、句尾、段落首、段落尾的判断在不同系统上似乎不一样,在ubuntu的系统上使用 ( 和使用 { 的效果似乎相同

【屏幕翻滚类命令】

Ctrl + u  向文件首翻半屏

Ctrl + d  向文件尾翻半屏

Ctrl + f  向文件尾翻一屏

Ctrl+b  向文件首翻一屏

nz  将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。

【插入文本类命令】

i   在光标前

I   在当前行首

a  光标后

A  在当前行尾

o  在当前行之下新开一行

O  在当前行之上新开一行

r  替换当前字符

R  替换当前字符及其后的字符,直至按ESC键

s  从当前光标位置处开始,以输入的文本替代指定数目的字符

S  删除指定数目的行,并以所输入文本代替之

ncw 或 nCW  修改指定数目的字

nCC  修改指定数目的行

【删除命令 】

ndw 或 ndW  删除光标处开始及其后的n-1个字

do  删至行首

d$  删至行尾

dd  删除一行

ndd  删除n行

x  删除一个光标后的一个字符

X  删除光标前的一个字符

Ctrl + u  删除输入方式下所输入的文本

【搜索及替换命令】

/pattern  从光标开始处向文件尾搜索pattern

?pattern  从光标开始处向文件首搜索pattern

n  在同一方向重复上一次搜索命令

N  在反方向上重复上一次搜索命令

:s/p1/p2/g  将当前行中所有p1均用p2替代

:n1,n2s/p1/p2/g  将第n1至n2行中所有p1均用p2替代

:%s/p1/p2/g  将文件中所有p1均用p2替换

【选项设置】

al  列出所有选项设置情况

term  设置终端类型

ignorance  在搜索中忽略大小写

list  显示制表位(Ctrl+I)和行尾标志($)

number  显示行号

report  显示由面向行的命令修改过的数目

terse  显示简短的警告信息

warn  在转到别的文件时若没保存当前文件则显示NO write信息

nomagic  允许在搜索模式中,使用前面不带“\”的特殊字符

nowrapscan  禁止vi在搜索到达文件两端时,又从另一端开始

mesg  允许vi显示其他用户用write写到自己终端上的信息

【行方式命令】

:n1,n2 co n3  将n1行到n2行之间的内容拷贝到第n3行下

:n1,n2 m n3  将n1行到n2行之间的内容移至到第n3行下

:n1,n2 d  将n1行到n2行之间的内容删除

【保存和退出命令】

:w  保存当前文件

:e filename  打开文件filename进行编辑

:x 或 :wq  保存当前文件并退出

:q  退出vi

:q!  不保存文件并退出vi

【shell相关命令】

:!command  执行shell命令command

:n1,n2 w!command  将文件中n1行至n2行的内容作为command的输入并执行之,若不指定n1,n2,则表示将整个文件内容作为command的输入

:r!command  将命令command的输出结果放到当前行

【寄存器操作】

"?nyy  将当前行及其下n行的内容保存到寄存器?中,其中?为一个字母,n为一个数字

"?nyw  将当前行及其下n个字保存到寄存器?中,其中?为一个字母,n为一个数字

"?nyl  将当前行及其下n个字符保存到寄存器?中,其中?为一个字母,n为一个数字

"?p  取出寄存器?中的内容并将其放到光标位置处。这里?可以是一个字母,也可以是一个数字

ndd  将当前行及其下共n行文本删除,并将所删内容放到1号删除寄存器中

==============================================

启用和禁用触摸盘 

#禁用触摸盘
sudo rmmod psmouse
#启用触摸盘
sudo modprobe psmouse

==============================================

截图

截全屏:PrintScreen 或者 Alt+PrintScreen

截取一个窗口:Shift+PrintScreen

==============================================

上一篇:thinkphp文章列表及删除文章


下一篇:MySQL TIMESTAMP(时间戳)详解