您的位置:首页 > 运维架构 > Linux

20170809_Linux常用基本命令(20条)

2017-08-09 16:45 288 查看
20170809_Linux常用基本命令(20条)



本博客参考博客:http://blog.csdn.net/ljianhui/article/details/11100625/

也可以参考另一篇博客:

20170724_Linux常用基本命令:http://blog.csdn.net/cmm0401/article/details/76021229

    学习过Linux 的人都知道,Linux 的命令实在太多了。但是玩过Linux 的人从来都不会因为Linux 的命令太多而烦恼,因为我们只需要掌握我们自己最常用的命令就可以了。当然,你也可以在使用的时候man 一下,它会解决你不少问题。使用Linux 的目的不同,所需要掌握的命令也是千差万别。我个人现在是处在学习Linux 下的C/C++/shell 编程,所以把我经常使用的命令整理如下,便于快速查询。

1、cd 命令

主要用于切换当前目录,它的参数是:要切换到的目录的路径,可以是绝对路径,也可以是相对路径。

cd /root/test      #切换到目录 /root/test
cd ./path          #切换到当前目录下的path 目录中,“.”表示当前目录
cd ../path         #切换到上层目录中的path 目录中,“..”表示上一层目录


2、ls 命令

主要用于查看文件与目录,list 的意思,它的参数很多,列出一些常用的参数。(这些参数也可以组合使用,直接连到一块即可)

-l :列出长数据串,包含文件的属性与权限数据等
-a :列出全部的文件,连同隐藏文件(意思是指开头为.的文件)一起列出来
-d :仅仅列出目录本身,而不列出目录的文件数据
-h :将文件容量以较易读的方式(多少GB、多少KB等)列出来
-R :连同子目录的内容一起列出来(递归列出),等于该目录下的所有文件都会列出来
举例子如下:

ls -l    #以长数据串的形式列出当前目录下的文件和目录
ls -lR   #以长数据串的形式列出当前目录下的所有文件


3、grep 命令

该命令主要用于分析一行的信息,若该行当中含有我们所需要的信息,就将该行信息显示出来。

它通常和管道命令一起使用,用于对一些命令的输出进行筛选和加工等,它的简单语法是:

grep [ -acinv ]  [ --color=auto ]  '查找字符串'  filename


它的常用参数如下:

-a :将binary 文件以text 文件的方式进行查找数据
-c :计算找到的“查找字符串”的行数
-i :忽略大小写的区别,即把大小写视为相同
-v :反向选择,即显示没有“查找字符串”的内容的那一行


举例子如下:

#取出文件 /etc/man.config 中包含 MANPATH 的行,并把找到的关键字加上颜色
grep  --color=auto  "MANPATH"  /etc/man.config
#把 ls -l 的输出中包含字母 file(不区分大小写)的内容输出
ls -l | grep -i "file"


4、find 命令

find 是一个基于查找的命令,功能很强大,相对而言,它的使用也相对复杂,参数也很多,所以在这里把它们分类列出:

find [path] [option] [action]


(1)与时间有关的参数:

find [path] [option] [action]
-mtime n    :n 是数字,意思是指在n 天之前的“一天内”被更改过的文件名
-mtime +n   :列出在n 天之前(不包含n 天本身)被更改过的文件名
-mtime -n   :列出在n 天之内(含n 天本身)被更改过的文件名
-newer file :列出比file 还要新的文件名
10560
#例如:在当前目录root下查找今天之内过有改动的文件
find /root -mtime 0


(2)与用户或者用户组名有关的参数:

-user name  :列出文件所有者为name 的所有文件
-group name :列出文件所属用户组为name 的所有文件
-uid n      :列出文件所有者为用户ID是n 的所有文件
-gid n      :列出文件所属用户组为用户组ID 是n 的所有文件
#例如:在目录/home/cmm 下找出文件所有者是cmm的所有文件
find /home/cmm -user cmm


(3)与文件权限及名称有关的参数:

-name filename   :找出文件名是filename 的文件
-size [+-] SIZE  :找出文件大小比SIZE 还要大(+)或者还要小(-)的文件
-type TYPE:查找文件类型是TYPE 的文件,TYPE 的值主要有:一般文件(f)、
设备文件(b、c)、目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p)。
-perm mode       :查找文件权限刚好等于mode 的文件,mode 用数字来表示,如0755
-perm -mode      :查找文件权限必须要全部包括mode 权限的文件,mode 用数字来表示
-perm +mode      :查找文件权限包含任一mode 的权限的文件,mode 用数字表示
#例如:
find / -name passwd    #在根目录下查找文件名是passwd 的文件
find . -perm 0755      #在当前目录下查找文件权限是0755的文件
find . -size +12k      #在当前目录下查找文件大小大于12k 的文件(多少个字节为单位的)
5、cp 命令

主要用于复制文件,copy 之意,它还可以把多个文件一次性的复制到一个目录下。

-a:将文件的特性一起复制
-p:连同文件的属性一起复制,而非使用默认复制方式,与-a相似,常用于备份文件
-i:若目标文件已经存在,在覆盖时会先询问操作的进行
-r:递归持续的复制,用于目录的复制
-u:目标文件与源文件有差异时才会复制
例如:

cp -a file1 file2           #连同文件的所有特性把文件 file1 复制成 file2
cp file1 file2 file3 dir    #把文件file1 和file2 和file3 复制到目录dir 下


6、mv 命令

该命令用于移动文件、目录或更名,move之意,常用参数如下:

-f :force 强制的意思,如果目标文件已经存在,不会询问直接覆盖
-i :若目标文件已经存在,就会询问是否要进行覆盖
-u :若目标文件已经存在,且比目标文件新,才会更新


注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。

mv file1 file2 file3 dir     # 把文件file1、file2、file3移动到目录dir中
mv file1 file2               # 把文件file1重命名为file2
7、rm 命令

该命令用于删除文件或者目录,remove之意,常用参数如下:

-f :就是force的意思,忽略不存在的文件,不会出现警告消息
-i :互动模式,在删除前会询问用户是否操作
-r :递归删除,最常用于目录删除,它是一个非常危险的参数


例如:

rm -i file    # 删除文件file,在删除之前会询问是否进行该操作
rm -fr dir    # 强制删除目录dir中的所有文件


8、ps 命令

该命令用于查看某一个时间点的进程运行情况,选取下来并输出,process之意,常用参数如下:

-A :所有的进程均显示出来
-a :不与terminal有关的所有进程
-u :有效用户的相关进程
-x :一般与a参数一起使用,可列出较完整的信息
-l :较长、较详细地将PID的信息列出


其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:

ps aux     # 查看系统所有的进程数据
ps ax      # 查看不与terminal有关的所有进程
ps -lA     # 查看系统所有的进程数据
ps axjf    # 查看连同一部分进程树状态
9、kill 命令

该命令通常向某个工作(%jobnumber)或者某个PID(数字)传送一个信号,它通常与ps 和jobs 命令一起使用,基本语法如下:

kill -signal PID


signal 的常用参数如下:

最前面的整数是相对应的信号的代号,使用时也可以用代号来代替后面的宏参数:

1: SIGHUP,  启动被终止的进程
2: SIGINT,  相当于输入ctrl+c,中断一个程序的进行
9: SIGKILL, 强制中断一个进程的进行
15:SIGTERM, 以正常的结束进程方式来终止进程
17:SIGSTOP, 相当于输入ctrl+z,暂停一个进程的进行


举例如下:

# 以正常的结束进程方式来终于第一个后台工作,可用jobs 命令查看后台中的第一个工作进程
kill -SIGTERM %1

# 重新启动进程ID 为PID 的进程,PID 可用ps 命令通过管道命令加上grep 命令进行筛选获得
kill -SIGHUP PID

10、killall 命令

该命令用于向一个命令启动的进程发送一个信号,一般语法如下:

killall [-iIe] [command name]


参数如下:

-i :交互式的意思,若要删除时,会询问用户
-e :表示后面接的command name要一致,但command name 不能超过15个字符
-I :命令名称忽略大小写
#例如:重新启动syslogd
killall -SIGHUP syslogd


11、file 命令

该命令用来判断接在file 命令后面的文件的基本数据类型,因为在Linux 系统中文件的类型不是以后缀名区分的,所以这个命令很重要很有用,用法如下:

file filename
#例如:当前目录下test文件的类型是什么
file ./test
12、tar 命令

该命令用于对文件进行打包,默认情况下并不会压缩,如果对它指定了相应的参数,它还会调用相应的压缩程序(比如:gzip、bzip等)进行压缩和解压缩。参数如下:

-c :新建打包文件
-t :查看打包文件的内容含有哪些文件名
-x :解压缩的功能,可以搭配 -C 指定解压缩的目录,注意 -c、-t、-x 不能同时出现在同一条命令中
-j :通过 bzip2 的支持进行压缩或解压缩
-z :通过 gzip 的支持进行压缩或解压缩
-v :在压缩或解压缩的过程中,将正在处理的文件名显示出来
-f filename :filename 为要处理的文件
-C dir :指定压缩或解压缩的目录 dir


上面的参数太多,但通常我们是需要记住如下三条命令即可:

压缩 : tar -jcv -f filename.tar.bz2 要被处理的文件或目录
查询 : tar -jtv -f filename.tar.bz2
解压 : tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
注:文件名并不一定要以后缀 tar.bz2 结尾,这里主要是为了说明使用的压缩程序是 bzip2。

另外,下面的语句也很常用:
压缩:   tar  -cvf  filename

解压缩:  tar  -xvf  filename

13、cat 命令

该命令用于查看文本文件的内容,后面要接查看的文件名,通常可用管道与 more 或 less 一起使用,从而可以一页页的查看数据。

cat text | less     #查看text 文件的内容,从前向后一页一页的翻看,也可以向前翻看(但more 没有向前翻看的功能)。
#同时,这条指令也可以用 less text 来代替。


14、chgrp 命令

该命令用来改变文件的所属用户组。

chgrp [-R] diename/filename
-R:进行递归的持续的对所有文件和子目录更改
# 例如:递归的把目录 dir 中的所有文件和所有子目录下所有文件的所属用户组均更改为users
chgrp users -R ./dir


15、chown 命令

该命令用于改变文件的所有者,与 chgrp 命令的使用方法相同,只是修改文件的属性不同而已。

16、chmod 命令

该命令用于改变文件的权限,很实用。

chmod [-R] xyz 文件或者目录
-R :进行递归的持续的更改,即连同子目录下的所有文件都会更改


同时,chmod 还可以使用 u(user)、g(group)、o(other)、a(all)、+(加入)、-(删除)、=(设置)跟 rwx 搭配来对文件的权限进行更改。

文件的权限分为三类:

r:读权限:对文件,可以查看文件内容;对目录,可以列出目录中的内容。

w:写权限:对文件,可以修改文件内容;对目录,可以在目录中创建或删除文件。

x:执行权限:对文件,可以执行文件;对目录,可以进入目录。

#例如:
chmod 0755 file    #把文件 file 的文件权限改变为 -rxwr-xr-x
chmod g+w file     #把文件 file 的文件权限加入用户组可写权限


(1)linux下修改文件所属用户组:

chgrp: change group的简写,修改文件所属的用户组。

chgrp  users  test.log

修改后查看: ls  -l

-rwxrwx---  1 work users 0 Jun  8 15:46 test.log

如果要修改该目录下所有文件和目录,使用 -R 参数。

chgrp  -R  users  test

要被改变的 group 名,必须在 /etc/group 文件中。 /etc/group 文件系统中记录所有的组名称。

(2) linux下修改文件所有者:

chown :change owner的简写, 修改文件的所有者。

chown [-R]   账号名称  文件或目录

-R 递归,将子目录下文件全部修改。

将文件所有者修改bin

chown  bin  test.log

修改的用户必须在 /etc/passwd 文件中, /etc/passwd  文件系统中记录用户信息。

chown 还可以修改组名称。

chown  root:root  test.log

将所有者和用户组的名称都修改为 root。

17、vim 命令主要用于文本编辑,它接一个或者多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim 是一个非常好用的文本编辑器,它里面有好多很实用的命令,请自行琢磨。

18、gcc 命令

对于一个用Linux 进行C 语言开发的人来说,这个命令就非常重要了。它用于把编辑好的 C 源程序文件编译成可执行文件,由于 g++ 的很多参数跟 gcc 类似,这里只介绍 gcc 的参数,常用参数如下:

-o:output 之意,用于编译生成一个可执行文件的文件名
-c:用于把源文件生成目标文件(.o格式),并且阻止编译器创建一个完整的程序
-I:增加编译时搜索头文件的路径
-L:增加编译时搜索静态链接库的路径
-S:把源文件生成汇编代码文件
-lpthread:连接NPTL实现的线程库
-std=c99:用于指定使用的C语言版本,比如c99版本等
-lm:表示标准库的目录中名为 libm.a 的函数库

#例如:
#把源文件 test.c 按照 c99标准编译成可执行程序 test
gcc -o test test.c -lm -std=c99

#把源文件 test.c 转换为相应的汇编程序源文件 test.s
gcc -S test.c


19、time 命令

该命令用于预算一个程序的执行时间。它的使用很简单,就像平时输入命令一样,不过在命令的前面加入一个 time 即可:

例如:

time ./process
time ps aux


在程序或命令运行结束后,在最后输出了三个时间,它们分别是:

user:     用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和。

system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和。

real:      实际时间,从command命令行开始执行到运行终止的消逝时间。

注:用户CPU时间和系统CPU时间 之和为CPU时间,即命令占用CPU执行的时间总和。

实际时间要大于CPU时间,因为Linux 是多任务操作系统,往往在执行一条命令时,系统还要处理其它任务。

另一个需要注意的问题是即使每次执行相同命令,但所花费的时间也是不一样,其花费时间是与系统运行相关的。

20、date 命令

用来输出标准的当前的日期和时间,也可以深入设置。

cal 命令

用来显示当前月份或者未来或者过去任何年份中的月份。

apt 命令

Debian系列以“apt”命令为基础,“apt”代表了Advanced Package Tool。APT是一个为Debian系列系统(Ubuntu,Kubuntu等等)开发的高级包管理器,在Gnu/Linux系统上,它会为包自动地,智能地搜索,安装,升级以及解决依赖。和 yum命令相比,Apt更高级和智能。

apt -get   用来安装,升级所有的已安装的包到最新版。

touch 命令

该命令代表了将文件的访问和修改时间更新为当前时间。touch 命令只会在文件不存在的情况下才会创建它。如果文件已经存在了,它只会更新时间戳,但是并不会改变文件内容。

sudo 命令

sudo(super user do)命令允许授权用户执行超级用户或者其他用户的命令,通过在 sudoers 列表的安全策略来指定。

注意:sudo 允许用户借用超级用户的权限,然而”su”命令实际上是允许用户以超级用户登录。所以sudo比su更安全。

并不建议使用sudo或者su来处理日常用途,因为它可能导致严重的错误如果你意外的做错了事,这就是为什么在linux社区流行一句话:

“To err is human, but to really foul up everything, you need root password.”

“人非圣贤孰能无过,但是拥有root密码就真的万劫不复了。”

history 命令
该命令用于查看在终端所执行过的所有命令的历史。

注意:按住 “CTRL + R” 就可以搜索已经执行过的命令,它可以在你写命令时自动补全。

uname 命令

uname(Unix name),显示机器名、操作系统和内核的详细信息。

root@tecmint:~# uname -a
Linux  tecmint  3.8.0-19-generic  #30-Ubuntu SMP  Wed May 1 16:36:13 UTC 2013  i686 i686 i686   GNU/Linux


注意: uname 显示内核类别, uname -a 显示详细信息。

上面的输出详细说明了:uname -a

  “Linux“: 机器的内核名
  “tecmint“: 机器的分支名
  “3.8.0-19-generic“: 内核发布版本
  “#30-Ubuntu SMP“: 内核版本
  “i686“: 处理器架构
  “GNU/Linux“: 操作系统名
top 命令
top 用于显示系统中各个进程的信息和资源占用状况,类似于 Windows 的任务管理器。

使用该命令可确定哪些进程正在运行,以及它们消耗了多少的内存和 CPU。

一种常见的情况是当你运行一个应用程序时,它在一分钟后挂掉。这时,你首先检查应用程序的返回错误,发现是一个内存错误。

netstat 命令

netstat 用于显示网络状态信息。该命令可显示正在使用的网络端口及其传入连接。

但是,netstat 在 Linux 中不能开箱即用。如果需要安装它,需要在 net-tools 包中找到它。

作为在本地进行试验或将应用程序推送到主机的开发者,可能会收到端口已被分配或地址已被使用的错误。

使用 netstat 得到协议、进程和端口这些信息。

dig 命令    nslookup 命令

dig 命令是常用的域名查询工具,可以用来测试域名系统工作是否正常。

域名服务器( DNS )有助于将 URL 解析为一组应用程序服务器。然而,你会发现有些 URL 不能被解析,这会导致应用程序的连接问题。

例如,假如你尝试从应用程序的主机访问你的数据库。你收到一个”不能解析”的错误。要进行故障排查,你尝试使用 dig(DNS 查询工具)或nslookup(查询 Internet 域名服务器)来确定应用程序似乎无法解析数据的原因。

要使用这些命令,需要安装 BIND Utilities 

df 命令

可以使用 df 显示空闲的磁盘空间( display free disk space )以排查磁盘空间问题。

当在容器管理器上运行应用程序时,可能会收到一条错误信息,提示容器主机上缺少可用空间。虽然磁盘空间应该由系统管理程序来管理和优化,你仍可以使用df 找出目录中的现有空间并确认是否没有空间。

df   显示每个文件系统的磁盘空间、绝对空间以及其可用性。

-h   选项表示以可读性较高的方式来显示信息,上面的例子表示这个主机具有大量的磁盘空间。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: