最最实用的30个Linux命令!

本文中将介绍一些实用又常用的Linux或Unix命令,这些是Linux系统管理员们平常使用的命令。本文不是什么完整列表,而是简要地列出了需要时派得上用场的命令,下面开始逐一介绍如何使用这些命令并附有示例。

Linux命令格式

Linux 命令的通用格式:命令字 [选项] [参数]

 选项:用于调节命令的具体功能

 "-" 引导短格式选项

 "--" 引导长格式选项

注意:多个短格式选项可以合并,但是多个长格式选项,不能合并

参数:命令的对象,如文件、目录名等

 

命令快捷键

tab 键:自动补齐文件名,命令等;按两次 tab 键,系统将输出可用的所有名称列表

反斜杠 "\":强制换行、续行符、转义符

ctrl+U:快速删除光标之前所有字符(可视为剪切)

ctrl+K:快速删除光标之后所有字符(可视为剪切)

ctrl+Y:黏贴刚才所删除(剪切)的字符

ctrl+L:清屏

ctrl+C:取消当前命令行编辑;结束当前执行的命令

ctrl+D:从 shell 提示中注销关闭,类似输入 exit

ctrl+A:把光标移动到行首,类似于 Home 键

ctrl+E:把光标移动到行尾,类似于 End 键

ctrl+Z:转入后台运行

ctrl+R:在历史命令中查找(常用并且很好用)

 

 重要文件及包含的内容

/

根目录

包含了几乎所有的文件目录。相当于中央系统

/boot

引导程序,内核等存放的目录

/sbin

超级用户可以使用的命令的存放目录

/bin

普通用户可以使用的命令的存放目录

 /lib

根目录下的所有程序的共享库目录

/dev

设备文件目录

/home

普通用户的家目录

/root

用户 root 的$HOME目录

/etc

全局的配置文件存放目录

/usr

这个目录中包含了命令库文件和在通常操作中不会修改的文件

/usr/lib

目标库文件,包括动态连接库加上一些通常不是直接调用的可执行文件的存放目录

/usr/bin

一般使用者使用并且不是系统自检等所必需可执行的目录

/usr/sbin

管理员使用的非系统必须的可执行文件存放目录

/usr/local

安装本地程序的一般默认路径

 

1.uptime命令

在Linux中,uptime命令显示了你的系统运行了多久以及目前登录的用户有多少,另外还显示了间隔1分钟、5分钟和15分钟的负载平均值。

# uptime
 08:16:26 up 22 min,  1 user,  load average: 0.00, 0.03, 0.22

检查uptime版本

除了uptime(正常运行时间)和version(版本)外,uptime命令没有其他选项。如果时间不到1天,它只给出hours:mins这种形式的信息。

[tecmint@linuxprobe ~]$ uptime -V
 procps version 3.2.8

2.w命令

该命令会显示目前登录的用户及其进程,另外还会显示负载平均值。此外,它还显示了登录名称、tty名称、远程主机、登录时间、闲置时间、JCPU、PCPU、命令和进程。

# w
08:27:44 up 34 min,  1 user,  load average: 0.00, 0.00, 0.08
USER    TTY    FROM     LOGIN@   IDLE   JCPU   PCPU WHAT
tecmint  pts/0    192.168.50.1     07:59    0.00s  0.29s  0.09s w

可用的选项
-h:不显示标题。

-s:不显示JCPU和PCPU。

-f:不显示字段信息。

-V:(大写V)-显示版本。

3.users命令

users命令显示了目前已登录的用户,除了help(帮助)和version(版本)外,该命令没有其他参数。

# users
 Tecmint

4.who命令

who命令仅仅返回用户名称、日期、时间和主机信息;who命令类似w命令,不像w命令,who并不输出用户执行的操作这一信息,不妨具体看看who和w这两个命令之间的区别。

# who
 tecmint  pts/0        2010-09-18 07:59 (192.168.50.1)
# w
 08:43:58 up 50 min,  1 user,  load average: 0.64, 0.18, 0.06
 USER    TTY    FROM    LOGIN@   IDLE   JCPU   PCPU WHAT
 tecmint  pts/0    192.168.50.1     07:59    0.00s  0.43s  0.10s w

who命令的选项

-b:显示上一次系统重启日期和时间。

-r:显示当前的运行级别。

-a,–all:显示累积的所有信息。

5.whoami命令

whoami命令输出当前用户的姓名;你还可以使用“who am i”命令显示当前用户,如果你以根用户身份使用sudo命令登录,“whoami”命令返回根用户是当前用户,如果你想知道登录的用户具体是哪个,使用“who am i”命令。

# whoami
 tecmint

6.ls命令

ls命令显示了人类可读格式的文件列表。

# ls -l
 total 114
 dr-xr-xr-x.   2 root root  4096 Sep 18 08:46 bin
 dr-xr-xr-x.   5 root root  1024 Sep  8 15:49 boot

按照上一次修改时间排序文件。

# ls -ltr
 total 40
 -rw-r--r--. 1 root root  6546 Sep 17 18:42 install.log.syslog
 -rw-r--r--. 1 root root 22435 Sep 17 18:45 install.log
 -rw-------. 1 root root  1003 Sep 17 18:45 anaconda-ks.cfg

7.crontab命令

可使用crontab命令和-l选项,列出当前用户的计划任务。

# crontab -l
 00 10 * * * /bin/ls >/ls.txt

可以使用-e选项编辑crontab,在下面例子中,将用VI编辑工具打开计划任务,进行必要的更改,按:wq键退出,这会自动保存设置。

# crontab -e

8.less命令

less命令允许快速查看文件;你可以向上和向下翻页,按“q”即可退出less窗口。

# less install.log
 Installing setup-2.8.14-10.el6.noarch
 warning: setup-2.8.14-10.el6.noarch: Header V3 RSA/SHA256 Signature, key ID c105b9de: NOKEY
 Installing filesystem-2.4.30-2.1.el6.i686
 Installing ca-certificates-2010.63-3.el6.noarch
 Installing xml-common-0.6.3-32.el6.noarch
 nstalling tzdata-2010l-1.el6.noarch
 Installing iso-codes-3.16-2.el6.noarch

9.more命令

more命令允许快速查看文件,并以百分比的形式显示详细信息,你可以向上和向下翻页,按“q”即可退出more窗口。

# more install.log
 Installing setup-2.8.14-10.el6.noarch
 warning: setup-2.8.14-10.el6.noarch: Header V3 RSA/SHA256 Signature, key ID c105b9de: NOKEY
 Installing filesystem-2.4.30-2.1.el6.i686
 Installing ca-certificates-2010.63-3.el6.noarch
 Installing xml-common-0.6.3-32.el6.noarch
 Installing tzdata-2010l-1.el6.noarch
 Installing iso-codes-3.16-2.el6.noarch
 --More--(10%)

10.cp命令

将文件从来源拷贝到目的地,保留同一种模式。

# cp -p fileA fileB

覆盖文件之前系统会提示你。

# cp -i fileA fileB

11.mv命令

将fileA更名为fileB; -i选项会在覆盖前提示;如果文件已经存在,会要求予以确认。

# mv -i fileA fileB

12.cat命令

cat命令用来同时查看多个文件。

# cat fileA fileB

要是某个文件在一个屏幕/页面显示不了,你可以使用cat命令来合并more和less命令,查看文件内容。

# cat install.log | less
      or
# cat install.log | more

13.cd命令(切换目录)

借助cd命令(切换目录),它会进入到fileA目录。

# cd /fileA

14.pwd命令(输出工作目录)

pwd命令会返回当前的工作目录。

# pwd
/root

15.sort命令

以升序排序一行行文本文件,如果使用-r选项,就会以降序排序。

#sort fileA.txt
#sort -r fileA.txt

16.vi命令

对大多数类似UNIX的操作系统而言,vi是最流行的文本编辑器,下面例子使用-R选项,打开只读方式的文件,按“:q”即可退出vi窗口。

# vi -R /etc/shadows

17.ssh命令(安全外壳)

ssh命令用来登录入到远程主机;比如说,下面这个ssh例子会使用用户作为narad,连接到主机(192.168.50.2)。

# ssh narad@192.168.50.2

想检查ssh的版本,使用选项-V(大写),即可显示ssh的版本。

# ssh -V
OpenSSH_5.3p1, OpenSSL 1.0.0-fips 29 Mar 2010

18.ftp或sftp命令

ftp或sftp命令用来连接到远程ftp主机;ftp是指文件传输协议,而sftp是安全文件传输协议。比如说,下列命令将连接到ftp主机(192.168.50.2)。

# ftp 192.168.50.2
# sftp 192.168.50.2

正如可以使用mput将多个文件上传到到远程主机,我们同样可以使用mget从远程主机下载多个文件。

# ftp > mput *.txt
# ftp > mget *.txt

19.service命令

service命令调用位于/etc/init.d/目录处的脚本,并执行脚本。有两种方法可以启动任何服务;比如说,我们使用service命令,启动名为httpd的服务。

# service httpd start
# /etc/init.d/httpd start

20.free命令

free命令显示了闲置内存、总内存和交换内等方面的信息,单位是字节。

# free
 total           used            free         shared     buffers    cached
 Mem:       1030800     735944     294856          0      51648     547696
 -/+ buffers/cache:     136600     894200
 Swap:      2064376          0    2064376

使用-t选项的free命令显示了已使用的总内存和可以使用的内存,单位是字节。

# free  -t
 total       used       free     shared    buffers     cached
 Mem:       1030800     736096     294704          0      51720     547704
 -/+ buffers/cache:     136672     894128
 Swap:      2064376          0    2064376
 Total:     3095176     736096    2359080

21.top命令

top命令显示了系统的处理器活动,还显示了由内核实时管理的任务,它会显示所使用的处理器和内存;如果使用带“u”选项的top命令,这会显示特定的用户进程详细信息,如下所示:按“O”(大写)即可按你希望的方式来排序,按“q”即可退出top屏幕。

# top -u tecmint
 top - 11:13:11 up  3:19,  2 users,  load average: 0.00, 0.00, 0.00
 Tasks: 116 total,   1 running, 115 sleeping,   0 stopped,   0 zombie
 Cpu(s):  0.0%us,  0.3%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
 Mem:   1030800k total,   736188k used,   294612k free,    51760k buffers
 Swap:  2064376k total,        0k used,  2064376k free,   547704k cached

PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
1889 tecmint   20   0 11468 1648  920 S  0.0  0.2   0:00.59 sshd
1890 tecmint   20   0  5124 1668 1416 S  0.0  0.2   0:00.44 bash
6698 tecmint   20   0 11600 1668  924 S  0.0  0.2   0:01.19 sshd
6699 tecmint   20   0  5124 1596 1352 S  0.0  0.2   0:00.11 bash

22.tar命令

tar命令用于压缩Linux下的文件和文件夹;比如说,下面这个命令将为/home目录创建一个压缩存档,文件名为archive-name.tar。

# tar -cvf archive-name.tar /home

想解压缩tar压缩存档文件,请使用如下所示的选项。

# tar -xvf archive-name.tar

23.grep命令

grep可搜索文件中的特定字符串;只显示/etc/passwd文件中的tecmint用户。我们可以使用-i选项,忽略大小写。

# grep tecmint /etc/passwd
 tecmint:x:500:500::/home/tecmint:/bin/bash

24.find命令

find命令用来搜索文件、字符串和目录;在下面这个例子中,find命令搜索“/”分区中的tecmint单词,并返回输出。

# find / -name tecmint
 /var/spool/mail/tecmint
 /home/tecmint
 /root/home/tecmint

25.lsof命令

lsof意味着“列出所有打开的文件”;下面,lsof命令列出了tecmint用户打开的所有文件。

# lsof -u tecmint 
 COMMAND  PID    USER   FD   TYPE     DEVICE SIZE/OFF   NODE NAME  
 sshd    1889 tecmint  cwd    DIR      253,0     4096      2 /  
 sshd    1889 tecmint  txt    REG      253,0   532336 298069 /usr/sbin/sshd  
 sshd    1889 tecmint  DEL    REG      253,0          412940 /lib/libcom_err.so.2.1  
 sshd    1889 tecmint  DEL    REG      253,0          393156 /lib/ld-2.12.so  
 sshd    1889 tecmint  DEL    REG      253,0          298643 /usr/lib/libcrypto.so.1.0.0  
 sshd    1889 tecmint  DEL    REG      253,0          393173 /lib/libnsl-2.12.so  
 sshd    1889 tecmint  DEL    REG      253,0          412937 /lib/libkrb5support.so.0.1  
 sshd    1889 tecmint  DEL    REG      253,0          412961 /lib/libplc4.so

26.last命令

借助last命令,我们就能观察用户在系统中的活动;该命令还可以以正常用户的身份来执行,它会显示完整的用户信息,比如终端、时间、日期、系统重启或启动以及内核版本,这是用来排查故障的实用命令。

# last 
 tecmint  pts/1        192.168.50.1     Tue Sep 18 08:50   still logged in  
 tecmint  pts/0        192.168.50.1     Tue Sep 18 07:59   still logged in  
 reboot   system boot  2.6.32-279.el6.i Tue Sep 18 07:54 - 11:38  (03:43)  
 root     pts/1        192.168.50.1     Sun Sep 16 10:40 - down   (03:53)  
 root     pts/0        :0.0             Sun Sep 16 10:36 - 13:09  (02:32)  
 root     tty1         :0               Sun Sep 16 10:07 - down   (04:26)  
 reboot   system boot  2.6.32-279.el6.i Sun Sep 16 09:57 - 14:33  (04:35)  
 narad    pts/2        192.168.50.1     Thu Sep 13 08:07 - down   (01:15) 

你可以使用带用户名的last,了解特定用户的活动,如下所示。

# last tecmint 
 tecmint  pts/1        192.168.50.1     Tue Sep 18 08:50   still logged in  
 tecmint  pts/0        192.168.50.1     Tue Sep 18 07:59   still logged in  
 tecmint  pts/1        192.168.50.1     Thu Sep 13 08:07 - down   (01:15)  
 tecmint  pts/4        192.168.50.1     Wed Sep 12 10:12 - 12:29  (02:17) 

27.ps命令

ps命令显示了系统中运行的进程方面的信息;下面这个例子只显示init进程。

# ps -ef | grep init
 root         1     0  0 07:53 ?        00:00:04 /sbin/init
 root      7508  6825  0 11:48 pts/1    00:00:00 grep init

28.kill或pkill命令

使用kill命令来终结进程;先使用ps命令找到进程id,如下所示,然后使用kill -9命令,终止进程。

# ps -ef | grep init
 root         1     0  0 07:53 ?        00:00:04 /sbin/init
 root      7508  6825  0 11:48 pts/1    00:00:00 grep init
# kill- 9 7508
# ps  ps -ef |grep terminal
root     7884      1  1 02:05 ?        00:00:00 /usr/bin/gnome-terminal -x /bin/sh -c cd 
# pkill- 9 terminal

29.rm命令

rm命令用来清除或删除文件,并不提示予以确认。

# rm filename
###循环删除多个文档
# rm -rf *

使用-i选项即可在删除之前予以确认;使用“-r”和“-f”这两个选项将强行删除文件,并不予以确认。

# rm -i test.txt
rm: remove regular file `test.txt'?

30.mkdir命令

mkdir命令用来在Linux下创建目录。

# mkdir directoryname

31.which命令

请用命令查出ifconfig命令程序的绝对路径

[root@localhost ~]# which ifconfig
/usr/sbin/ifconfig

32.type 命令

请用命令展示以下命令哪些是内部命令,哪些是外部命令?(cd \ pwd \ ls \ ifconfig \ du)

[root@localhost ~]# type cd
cd 是 shell 内嵌 (由此可见该命令cd为内部命令)
[root@localhost /]# type pwd
pwd 是 shell 内嵌(由此可见该命令pwd为内部命令)
[root@localhost /]# type ls
ls 是 `ls --color=auto' 的别名(由此可见该命令ls为外部命令)
[root@localhost /]# type ifconfig
ifconfig 是 /usr/sbin/ifconfig(由此可见该命令ls为外部命令)
[root@localhost /]# type du
du 是 /usr/bin/du(由此可见该命令ls为外部命令)

33.stat命令

查看/tmp/目录下以vmlinuz开头文件的详细状态信息

[root@localhost /]# stat /tmp/vmlinuz-0-rescue-354622b8ec094726a50177638e8ac3ea
  文件:"/tmp/vmlinuz-0-rescue-354622b8ec094726a50177638e8ac3ea"
  大小:6224704   块:12160      IO 块:4096   普通文件
设备:fd00h/64768dInode:101778954   硬链接:1
权限:(0755/-rwxr-xr-x)  Uid:(    0/    root)   Gid:(    0/    root)
环境:unconfined_u:object_r:default_t:s0
最近访问:2019-07-23 20:41:36.196748328 +0800
最近更改:2019-07-23 20:41:36.211749087 +0800
最近改动:2019-07-23 20:55:26.430471398 +0800
创建时间:-

34.systemctl 命令(适用于CentOS7)

请用命令关闭防火墙

临时关闭防火墙
systemctl stop firewalld
永久关闭防火墙
systemctl disable firewalld
临时关闭selinux安全机制
setenforce 0
永久关闭selinux安全机制
sed -i '7 s/enforcing/disabled/' /etc/selinux/config

35.man命令

用来提供在线帮助,使用权限是所有用户。在Linux系统中存储着一部联机使用的手册,以供用户在终端上查找。使用man命令可以调阅其中的帮助信息,非常方便实用。

man [-acdfhkKtwW] [-m system] [-p string] [-C config_file] [-Mpath] [-P pager] [-S section_list][section] name ...
-C config_life:指定设定文件 man.conf,缺省值是 /etc/man.conf

二、常用命令

1.ls [选项] [目录名 | 列出相关目录下的所有目录和文件

 

-a  列出包括.a开头的隐藏文件的所有文件
-A  通-a,但不列出"."和".."
-l  列出文件的详细信息
-c  根据ctime排序显示
-t  根据文件修改时间排序
---color[=WHEN] 用色彩辨别文件类型 WHEN 可以是'never'、'always'或'auto'其中之一
   白色:表示普通文件
   蓝色:表示目录
   绿色:表示可执行文件
   红色:表示压缩文件
   浅蓝色:链接文件
   红色闪烁:表示链接的文件有问题
   黄色:表示设备文件
   灰色:表示其它文件

 

2.mv [选项] 源文件或目录 目录或多个源文件 | 移动或重命名文件

 

-b  覆盖前做备份
-f  如存在不询问而强制覆盖
-i  如存在则询问是否覆盖
-u  较新才覆盖
-t  将多个源文件移动到统一目录下,目录参数在前,文件参数在后
eg:
   mv a /tmp/ 将文件a移动到 /tmp目录下
   mv a b 将a命名为b
   mv /home/zenghao test1.txt test2.txt test3.txt

 

3.cp [选项] 源文件或目录 目录或多个源文件 | 将源文件复制至目标文件,或将多个源文件复制至目标目录。

 

-r -R 递归复制该目录及其子目录内容
-p  连同档案属性一起复制过去
-f  不询问而强制复制
-s  生成快捷方式
-a  将档案的所有特性都一起复制

 

4.scp [参数] [原路径] [目标路径] | 在Linux服务器之间复制文件和目录

 

-v  详细显示输出的具体情况
-r  递归复制整个目录
(1) 复制文件:  
命令格式:  
scp local_file remote_username@remote_ip:remote_folder  
或者  
scp local_file remote_username@remote_ip:remote_file  
或者  
scp local_file remote_ip:remote_folder  
或者  
scp local_file remote_ip:remote_file  
第1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名  
第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名   
(2) 复制目录:  
命令格式:  
scp -r local_folder remote_username@remote_ip:remote_folder  
或者  
scp -r local_folder remote_ip:remote_folder  
第1个指定了用户名,命令执行后需要输入用户密码;  
第2个没有指定用户名,命令执行后需要输入用户名和密码;
eg:
   从 本地 复制到 远程
   scp /home/daisy/full.tar.gz root@172.19.2.75:/home/root 
   从 远程 复制到 本地
   scp root@/172.19.2.75:/home/root/full.tar.gz /home/daisy/full.tar.gz

 

5.rm [选项] 文件 | 删除文件

 

-r  删除文件夹
-f  删除不提示
-i  删除提示
-v  详细显示进行步骤

 

6.touch [选项] 文件 | 创建空文件或更新文件时间

 

-a  只修改存取时间
-m  值修改变动时间
-r  eg:touch -r a b ,使b的时间和a相同
-t  指定特定的时间 eg:touch -t 201211142234.50 log.log 
   -t time [[CC]YY]MMDDhhmm[.SS],C:年前两位

 

7.pwd 查看当前所在路径

 

8.cd 改变当前目录

 

- :返回上层目录
.. :返回上层目录
回车  :返回主目录
/   :根目录

 

9.mkdir [选项] 目录… | 创建新目录

 

-p  递归创建目录,若父目录不存在则依次创建
-m  自定义创建目录的权限  eg:mkdir -m 777 hehe
-v  显示创建目录的详细信息

 

10.rmdir 删除空目录

 

-v  显示执行过程
-p  若自父母删除后父目录为空则一并删除

 

11.rm [选项] 文件… | 一个或多个文件或目录

 

-f  忽略不存在的文件,不给出提示
-i  交互式删除
-r  将列出的目录及其子目录递归删除
-v  列出详细信息

 

12.echo:显示内容

 

-n  输出后不换行
-e  遇到转义字符特殊处理  
   eg:
       echo "hehe"   显示hehe
       ehco -e "hehe"    显示he(换行了)he

 

13.cat [选项] [文件]..| 一次显示整个文件或从键盘创建一个文件或将几个文件合并成一个文件

 

-n  编号文件内容再输出
-E  在结束行提示$

 

14.tac | 反向显示

 

15.more | 按页查看文章内容,从前向后读取文件,因此在启动时就加载整个文件

 

+n  从第n行开始显示
-n  每次查看n行数据
+/String    搜寻String字符串位置,从其前两行开始查看
-c  清屏再显示
-p  换页时清屏

 

16.less | 可前后移动地逐屏查看文章内容,在查看前不会加载整个文件

 

-m  显示类似于more命令的百分比
-N  显示行号
/   字符串:向下搜索“字符串”的功能
?   字符串:向上搜索“字符串”的功能
n   重复前一个搜索(与 / 或 ? 有关)
N   反向重复前一个搜索(与 / 或 ? 有关)
b   向后翻一页
d   向后翻半页

 

17.nl [选项]… [文件]… | 将输出内容自动加上行号 

 

-b 
-b a 不论是否有空行,都列出行号(类似 cat -n) 
-b t 空行则不列行号(默认) 
-n 有ln rn rz三个参数,分别为再最左方显示,最右方显示不加0,最右方显示加0

 

18.head [参数]… [文件]… | 显示档案开头,默认开头10行

 

-v  显示文件名
-c number   显示前number个字符,若number为负数,则显示除最后number个字符的所有内容
-number/n (+)number     显示前number行内容,
-n number   若number为负数,则显示除最后number行数据的所有内容

 

19.tail [必要参数] [选择参数] [文件] | 显示文件结尾内容

 

-v  显示详细的处理信息
-q  不显示处理信息
-num/-n (-)num      显示最后num行内容
-n +num 从第num行开始显示后面的数据
-c  显示最后c个字符
-f  循环读取

 

20.which 可执行文件名称 | 查看可执行文件的位置,在PATH变量指定的路径中查看系统命令是否存在及其位置

 

21.whereis [-bmsu] [BMS 目录名 -f ] 文件名| 定位可执行文件、源代码文件、帮助文件在文件系统中的位置

 

-b   定位可执行文件。
-m   定位帮助文件。
-s   定位源代码文件。
-u   搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件。
-B   指定搜索可执行文件的路径。
-M   指定搜索帮助文件的路径。
-S   指定搜索源代码文件的路径。

 

22.locate | 通过搜寻数据库快速搜寻档案

 

-r  使用正规运算式做寻找的条件

 

23.uname -a (Linux查看版本当前操作系统内核信息)

 

Linux centos 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux

 

24.find find [PATH] [option] [action] | 在文件树种查找文件,并作出相应的处理

 

选项与参数:
1. 与时间有关的选项:共有 -atime, -ctime 与 -mtime 和-amin,-cmin与-mmin,以 -mtime 说明
   -mtime n :n 为数字,意义为在 n 天之前的『一天之内』被更动过内容的档案;
   -mtime +n :列出在 n 天之前(不含 n 天本身)被更动过内容的档案档名;
   -mtime -n :列出在 n 天之内(含 n 天本身)被更动过内容的档案档名。
   -newer file :file 为一个存在的档案,列出比 file 还要新的档案档名

2. 与使用者或组名有关的参数:
   -uid n :n 为数字,这个数字是用户的账号 ID,亦即 UID
   -gid n :n 为数字,这个数字是组名的 ID,亦即 GID
   -user name :name 为使用者账号名称!例如 dmtsai
   -group name:name 为组名,例如 users ;
   -nouser :寻找档案的拥有者不存在 /etc/passwd 的人!
   -nogroup :寻找档案的拥有群组不存在于 /etc/group 的档案!

3. 与档案权限及名称有关的参数:
   -name filename:搜寻文件名为 filename 的档案(可使用通配符)
   -size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的档案。这个 SIZE 的规格有:
       c: 代表 byte
       k: 代表 1024bytes。所以,要找比 50KB还要大的档案,就是『 -size +50k 』
   -type TYPE :搜寻档案的类型为 TYPE 的,类型主要有:
       一般正规档案 (f)
       装置档案 (b, c)
       目录 (d)
       连结档 (l)
       socket (s)
       FIFO (p)
   -perm mode :搜寻档案权限『刚好等于』 mode的档案,这个mode为类似chmod的属性值,举例来说,-rwsr-xr-x 的属性为4755!
   -perm -mode :搜寻档案权限『必须要全部囊括 mode 的权限』的档案,举例来说,
       我们要搜寻-rwxr--r-- 亦即 0744 的档案,使用-perm -0744,当一个档案的权限为 -rwsr-xr-x ,亦即 4755 时,也会被列出来,因为 -rwsr-xr-x 的属性已经囊括了 -rwxr--r-- 的属性了。
   -perm +mode :搜寻档案权限『包含任一 mode 的权限』的档案,举例来
       说,我们搜寻-rwxr-xr-x ,亦即 -perm +755 时,但一个文件属性为 -rw-------也会被列出来,因为他有 -rw.... 的属性存在!
4. 额外可进行的动作:
   -exec command :command 为其他指令,-exec 后面可再接额外的指令来处理搜寻到的结果。
   -print :将结果打印到屏幕上,这个动作是预设动作!
   eg:
       find / -perm +7000 -exec ls -l {} ; ,额外指令以-exec开头,以;结尾{}代替前面找到的内容
   | xargs 
       -i  默认的前面输出用{}代替 
       eg:
           find . -name "*.log" | xargs -i mv {} test4

 

25.grep ‘正则表达式’ 文件名 | 用正则表达式搜索文本,并把匹配的行打印出来

 

-c  只输出匹配行的计数。
-I  不区分大小写(只适用于单字符)。
-l  只显示文件名
-v  显示不包含匹配文本的所有行。
-n  显示匹配行数据及其行号

 

25.file | 判断文件类型

 

26.gzip [-cdtv#] 檔名 | 压缩、解压缩,源文件都不再存在

 

-d  进行解压缩
-c  将压缩的数据输出到屏幕上
-v  :显示原档案/压缩文件案的压缩比等信息
-#  :压缩等级,-1最快,但压缩比最差,=9最慢,但压缩比最好

 

27.gunzip | 解压缩

 

28.bzip2 | 压缩、解压缩

 

-d  :解压
-z  :压缩
-k  :保留源文件
-c :将压缩的过程产生的数据输出到屏幕上!
-v :可以显示出原档案/压缩文件案的压缩比等信息;
-# :与 gzip 同样的,都是在计算压缩比的参数, -9 最佳, -1 最快!

 

29.bzcat 读取数据而无需解压

 

30.tar [主选项+辅选项] 文件或者目录 | 多个目录或档案打包、压缩成一个大档案

 

主选项:
   -c  建立打包档案,可搭配 -v 来察看过程中被打包的档名(filename)
   -t  察看打包档案的内容含有哪些档名,重点在察看『档名』就是了;
   -x  解打包或解压缩的功能,可以搭配 -C (大写) 在特定目录解开
辅选项:
   -j  透过 bzip2 的支持进行压缩/解压缩:此时档名最好为 *.tar.bz2
   -z  透过 gzip 的支持进行压缩/解压缩:此时档名最好为 *.tar.gz
   -v  在压缩/解压缩的过程中,将正在处理的文件名显示出来!
   -f filename -f 后面要立刻接要被处理的档名!
   -C 目录   这个选项用在解压缩,若要在特定目录解压缩,可以使用这个选项。
   --exclude FILE:在压缩打包过程中忽略某文件 eg: tar --exclude /home/zenghao -zcvf myfile.tar.gz /home/* /etc
   -p  保留备份数据的原本权限与属性,常用于备份(-c)重要的配置文件
   -P(大写)  保留绝对路径,亦即允许备份数据中含有根目录存在之意;
eg:
   压 缩:tar -jcvf filename.tar.bz2 要被压缩的档案或目录名称
   查 询:tar -jtvf filename.tar.bz2
   解压缩:tar -jxvf filename.tar.bz2 -C 欲解压缩的目录

 

31.exit 退出当前shell 


32.logout 退出登录shell 


33.shutdown -h now

 

34.users 显示当前登录系统地用户

 

35.who 登录在本机的用户与来源

 

-H或--heading  显示各栏位的标题信息列。

 

36.w 登录在本机的用户及其运行的程序

 

-s  使用简洁格式列表,不显示用户登入时间,终端机阶段作业和程序所耗费的CPU时间。
-h  不显示各栏位的标题信息列。

 

37.write 给当前联机的用户发消息

 

38.wall 给所有登录再本机的用户发消息

 

39.last 查看用户的登陆日志

 

40.lastlog 查看每个用户最后的登陆时间

 

41.finger [选项] [使用者] [用户@主机] | 查看用户信息

 

-s 显示用户的注册名、实际姓名、终端名称、写状态、停滞时间、登录时间等信息
-l 除了用-s选项显示的信息外,还显示用户主目录、登录shell、邮件状态等信息,以及用户主目录下的.plan、.project和.forward文件的内容。
-p 除了不显示.plan文件和.project文件以外,与-l选项相同

 

42.hostname 查看主机名

 

43.alias ii = “ls -l” | 添加别名

 

44.unalias ii | 清除别名

 

45.useradd [-u UID] [-g 初始群组] [-G 次要群组] [-c 说明栏] [-d 家目录绝对路径] [-s shell] 使用者账号名 | 新增用户

 

-M  不建立用户家目录!(系统账号默认值)
-m  建立用户家目录!(一般账号默认值)
-r  建立一个系统的账号,这个账号的 UID 会有限制 
-e  账号失效日期,格式为『YYYY-MM-DD』
-D  查看useradd的各项默认值

 

46.passwd | 修改密码

 

-l  使密码失效
-u  与-l相对,用户解锁
-S  列出登陆用户passwd文件内的相关参数
-n  后面接天数,shadow 的第 4 字段,多久不可修改密码天数
-x  后面接天数,shadow 的第 5 字段,多久内必须要更动密码
-w  后面接天数,shadow 的第 6 字段,密码过期前的警告天数
-i  后面接『日期』,shadow 的第 7 字段,密码失效日期
使用管道刘设置密码:echo "zeng" | passwd --stdin zenghao

 

47.userdel 删除用户

 

-r  用户文件一并删除

 

48.chage [-ldEImMW] 账号名 | 修改用户密码的相关属性

 

-l  列出该账号的详细密码参数;
-d  后面接日期,修改 shadow 第三字段(最近一次更改密码的日期),格式YYYY-MM-DD
-E  后面接日期,修改 shadow 第八字段(账号失效日),格式 YYYY-MM-DD
-I  后面接天数,修改 shadow 第七字段(密码失效日期)
-m  后面接天数,修改 shadow 第四字段(密码最短保留天数)
-M  后面接天数,修改 shadow 第五字段(密码多久需要进行变更)
-W  后面接天数,修改 shadow 第六字段(密码过期前警告日期)

 

49.usermod [-cdegGlsuLU] username | 修改用户的相关属性

 

-c  后面接账号的说明,即 /etc/passwd 第五栏的说明栏,可以加入一些账号的说明。
-d  后面接账号的家目录,即修改 /etc/passwd 的第六栏;
-e  后面接日期,格式是 YYYY-MM-DD 也就是在 /etc/shadow 内的第八个字段数据啦!
-f  后面接天数为 shadow 的第七字段。
-g  后面接初始群组,修改 /etc/passwd 的第四个字段,亦即是GID的字段!
-G  后面接次要群组,修改这个使用者能够支持的群组
-l  后面接账号名称。亦即是修改账号名称, /etc/passwd 的第一栏!
-s  后面接 Shell 的实际档案,例如 /bin/bash 或 /bin/csh 等等。
-u  后面接 UID 数字啦!即 /etc/passwd 第三栏的资料;
-L  冻结密码
-U  解冻密码

 

50.id [username] | 查看用户相关的id信息,还可以用来判断用户是否存在

 

51.groups 查看登陆用户支持的群组, 第一个输出的群组为有效群组

 

52.newgrp 切换有效群组

 

53.groupadd [-g gid] 组名 | 添加组

 

-g  设定添加组的特定组id

 

54.groupmod [-g gid] [-n group_name] 群组名 | 修改组信息

 

-g  修改既有的 GID 数字
-n  修改既有的组名

 

55.groupdel [groupname] | 删除群组

 

56.gpasswd | 群组管理员功能

 

root管理员动作:
   -gpasswd groupname 设定密码
   -gpasswd [-A user1,...] [-M user3,...] groupname
       -A  将 groupname 的主控权交由后面的使用者管理(该群组的管理员)
       -M  将某些账号加入这个群组当中
   -gpasswd [-r] groupname
       -r  将 groupname 的密码移除
群组管理员动作:
   - gpasswd [-ad] user groupname 
       -a  将某位使用者加入到 groupname 这个群组当中
       -d  将某位使用者移除出 groupname 这个群组当中

 

57.chfn修改个人信息

 

58.mount [-t vfstype] [-o options] device dir

 

-ro 采用只读方式挂接设备
-rw 采用读写方式挂接设备
eg:mount /home/mydisk.iso /tmp/mnt 通过mnt访问mydisk内的内容

 

59.umount 取消挂载

 

60.cut

 

-b :以字节为单位进行分割。这些字节位置将忽略多字节字符边界,除非也指定了 -n 标志。
-c :以字符为单位进行分割。
-d :自定义分隔符,默认为制表符。
-f  :与-d一起使用,指定显示哪个区域。

 

61.sort

 

-n   依照数值的大小排序。
-o<输出文件>   将排序后的结果存入指定的文件。
-r   以相反的顺序来排序。
-t<分隔字符>   指定排序时所用的栏位分隔字符。
-k  选择以哪个区间进行排序。

 

62.wc 统计指定文件中的字节数、字数、行数, 并将统计结果显示输出

 

-l filename 报告行数
-c filename 报告字节数
-m filename 报告字符数
-w filename 报告单词数

 

63.uniq 去除文件中相邻的重复行

 

-c或——count:在每列旁边显示该行重复出现的次数;
-d或--repeated:仅显示重复出现的行列;
-f<栏位>或--skip-fields=<栏位>:忽略比较指定的栏位;
-s<字符位置>或--skip-chars=<字符位置>:忽略比较指定的字符;
-u或——unique:仅显示出一次的行列;
-w<字符位置>或--check-chars=<字符位置>:指定要比较的字符。

 

64.set 显示环境变量和普通变量 


65.env 显示环境变量 


66.export 把普通变量变成环境变量 


67.unset 删除一个环境变量

 

aaa(){} 定义函数

 

68.read

 

-p  接提示字符
-t  接等待的秒数

 

69.declare、typeset

 

-i 声明为整数
-a 声明为数组
-f 声明为函数
-r 声明为只读

 

70.ulimit 限制使用者的某些系统资源

 

-f  此 shell 可以建立的最大档案容量 (一般可能设定为 2GB)单位为 Kbytes eg: ulimit -f 1024 限制使用者仅能建立 1MBytes 以下的容量的档案

 

71.df [选项] [文件] | 显示指定磁盘文件的可用空间,如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示

 

-a  显示全部文件系统
-h  文件大小友好显示
-l  只显示本地文件系统
-i  显示inode信息
-T  显示文件系统类型

 

72.du [选项] [文件] | 显示每个文件和目录的磁盘使用空间

 

-h  方便阅读的方式
-s  只显示总和的大小

 

73.ln [参数] [源文件或目录] [目标文件或目录] | 某一个文件在另外一个位置建立一个同步的链接

 

-s  建立软连接   
-v  显示详细的处理过程

 

74.diff [参数] [文件1或目录1] [文件2或目录2] | 比较单个文件或者目录内容

 

-b  不检查空格字符的不同。
-B  不检查空白行。
-i  不检查大小写
-q  仅显示差异而不显示详细信息
eg: diff a b > parch.log 比较两个文件的不同并产生补丁

 

75.date [参数]… [+格式] | 显示或设定系统的日期与时间

 

%H 小时(以00-23来表示)。 
%M 分钟(以00-59来表示)。 
%P AM或PM。
%D 日期(含年月日)
%U 该年中的周数。
date -s “2015-10-17 01:01:01″ //时间设定
date +%Y%m%d         //显示前天年月日
date +%Y%m%d --date="+1 day/month/year"  //显示前一天/月/年的日期
date +%Y%m%d --date="-1 day/month/year"  //显示后一天/月/年的日期
date -d '2 weeks' 2周后的日期

 

76.cal [参数] 月份] [年份] | 查看日历

 

-1  显示当月的月历
-3  显示前、当、后一个月的日历
-m  显示星期一为一个星期的第一天
-s  (默认)星期天为第一天
-j  显示当月是一年中的第几天的日历
-y  显示当前年份的日历

 

77.ps | 列出当前进程的快照

 

a   显示所有的进程
-a  显示同一终端下的所有程序
e   显示环境变量
f   显示进程间的关系
-H  显示树状结构
r   显示当前终端的程序
T   显示当前终端的所有程序
-au 显示更详细的信息
-aux    显示所有包含其他使用者的行程 
-u  指定用户的所有进程

例如:输入ps  -aux回车会显示linux下所有的进程

78.top [参数] | 显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等

 

79.kill [参数] [进程号] | 杀死进程

 

80.free [参数] | 显示linux系统中空闲的、已用的物理内存及swap内存,及被内核使用的buffer

 

81.vmstat | 对操作系统的虚拟内存、进程、CPU活动进行监控

 

82.iostat [参数] [时间t] [次数n](每隔t时间刷新一次,最多刷新n次)| 对系统的磁盘操作活动进行监视,汇报磁盘活动统计情况,同时也会汇报出CPU使用情况

 

-p[磁盘] 显示磁盘和分区的情况

 

83.watch [参数] [命令] |重复执行某一命令以观察变化

 

-n  时隔多少秒刷新
-d  高亮显示动态变化

 

84.at [参数] [时间] | 在一个指定的时间执行一个指定任务,只能执行一次

 

HH:MM[am|pm] + number [minutes|hours|days|weeks] 强制在某年某月某日的某时刻进行该项任务
atq 查看系统未执行的任务
atrm n 删除编号为n的任务
at -c n 显示编号为n的任务的内容

 

85.crontab | 定时任务调度

 

file    载入crontab
-e  编辑某个用户的crontab文件内容
-l  显示某个用户的crontab文件内容
-r  删除某个用户的crontab文件

 

86.ifconfig [网络设备] [参数] | 查看和配置网络设备

 

87.route | 显示和操作IP路由表

 

88.ping [参数] [主机名或IP地址] | 测试与目标主机的连通性

 

-q  只显示最后的结果

 

89.netstat | 显示与IP、TCP、UDP和ICMP协议相关的统计数据

 

90.telnet [参数] [主机] | 用于远程登录,采用明文传送报文,安全性不好

 

91.rcp [参数] [源文件] [目标文件] | 远程文件拷贝

 

-r  递归复制
-p  保留源文件的属性
usage: rcp –r remote_hostname:remote_dir local_dir

 

92.wget [参数] [URL地址] | 直接从网络上下载文件

 

-o FILE 把记录写到FILE文件中    eg : wget -O a.txt URL
wget --limit-rate=300k URL  限速下载

 

93.awk

 

-F 分隔符  以分隔符分隔内容
{}  要执行的脚本内容 eg:cat /etc/passwd |awk  -F ':'  '{print $1""$7}'

 

94.sed 对数据行进行替换、删除、新增、选取等操作

 

a   新增,在新的下一行出现
c   取代,取代 n1,n2 之间的行 eg: sed '1,2c Hi' ab
d   删除
i   插入,在新的上一行出现

 

95.paste 合并文件,需确保合并的两文件行数相同

 

-d  指定不同于空格或tab键的域分隔符
-s  按行合并,单独一个文件为一行

 

96.su [参数] user | 切换登陆

 

-l  切换时连同环境变量、工作目录一起改变
-c command  执行command变回原来的使用者

 

97.sudo | 以特定用户的权限执行特定命令

 

-l  列出当前用户可执行的命令
-u username#uid 以指定用户执行命令

 

98.cat /proc/version (Linux查看当前操作系统版本信息)

Linux version 2.6.32-504.el6.x86_64 (mockbuild@c6b9.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) ) #1 SMP Wed Oct 15 04:27:16 UTC 2014

99.cat /etc/issue  或cat /etc/redhat-release(Linux查看版本当前操作系统发行版信息)

CentOS release 6.6 (Final) Kernel \r on an \m

CentOS release 6.6 (Final)

100.cat /proc/cpuinfo


processor	: 0
vendor_id	: GenuineIntel
cpu family	: 6
model		: 158
model name	: Intel(R) Core(TM) i5-7500 CPU @ 3.40GHz
stepping	: 9
microcode	: 94
cpu MHz		: 3408.229
cache size	: 6144 KB
physical id	: 0
siblings	: 2
core id		: 0
cpu cores	: 2
apicid		: 0
initial apicid	: 0
fpu		: yes
fpu_exception	: yes
cpuid level	: 22
wp		: yes

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值