Linux常用命令

前言

本文对Linux中比较基础常用的命令进行一个总结。

基本操作命令

显示当前在哪个路径下
pwd
用户管理

添加用户

useradd testman

修改密码

passwd aaa111

删除用户但保存用户主目录

userdel testman 

删除用户及其用户主目录

userdel - testman

退出当前用户

logout

显示当前登录用户

who am i
文件目录

改变目录

cd

列出当前路径下文件和目录

ls

显示当前路径下所有文件,包括隐藏文件

ls -a

以长列表形式显示

ls -l

ll

创建目录

mkdir

删除空目录

rmdir

建立空文件

touch
文件操作

复制文件

cp dir1 dir2

复制文件及其子目录

cp -r dir1 dir2

移动文件和修改文件名

mv

删除文件和目录

rm

删除所有内容,包含目录和文件,r表示递归,f表示强制

rm -rf *

建立符号连接,类似于建立某个文件的快捷方式

ln -s 源目标
ln ‐s /etc/inittab inittab,inittab指向实际文件/etc/inittab inittab

显示文件内容带分页,ctrl + page up上翻,长空格下翻

more

less

在文本中查询内容

grep

查找文本文件中的关键字,并高亮显示

grep "text" /ect/hosts --color=auto

配合管道命令,查找多个关键字

grep "text1" /ect/hosts | grep "text2" /ect/hosts

在特定的目录下搜索并显示指定名称的文件和目录
从根目录开始搜索名称为man的文件或目录

find / -name man

十分钟内存取的文件或目录

find /home -amin -10

十小时内存取的文件或目录

find /home -atime -10

十分钟内更改过的文件或目录

find /home -cmin -10

十小时前更改过的文件或目录

find /home -ctime +10

查找/home目录下大小为10k的文件

find /home -size +10k
重定向命令

列表的内容写入文件a.txt中(覆盖写)

ls -l > a.txt

列表的内容追加到文件aa.txt的末尾

ls -al >> aa.txt
压缩和解压
.tar 
解包:tar xvf FileName.tar
打包:tar cvf FileName.tar DirName
(注:tar是打包,不是压缩!)
.gz
解压1:gunzip FileName.gz
解压2:gzip -d FileName.gz
压缩:gzip FileName
.tar.gz.tgz
解压:tar zxvf FileName.tar.gz
压缩:tar zcvf FileName.tar.gz DirName
.bz
解压1:bzip2 -d FileName.bz
解压2:bunzip2 FileName.bz
压缩:未知
.tar.bz
解压:tar jxvf FileName.tar.bz
压缩:未知
.zip
解压:unzip FileName.zip
压缩:zip FileName.zip DirName
.rar
解压:rar x FileName.rar
压缩:rar a FileName.rar DirName
查阅历史记录

查看使用过的命令的历史记录

history

此项说明会显示最近使用的5个命令

history 5
关机

立即关机

shutdown -h now

指定时间关机

shutdown -h 20:25

十分钟后自动关机

shutdown -h +10

系统立刻重新启动

shutdown -r now

基本详细操作命令

文件属性与权限

1、改变所属群组, chgrp

chgrp [-R] dirname/filename ...

选项与参数:
-R : 进行递归(recursive)的持续变更,亦即连同次目录下的所有文件、目录
都更新成为这个群组之意。常常用在变更某一目录内所有的文件之情况。
范例:
[root@www ~]# chgrp users install.log
[root@www ~]# ls -l
-rw-r–r– 1 root users 68495 Jun 25 08:53 install.log
[root@www ~]# chgrp testing install.log
chgrp: invalid group name `testing’ <== 发生错误讯息啰~找不到这个群组名~

2、改变文件拥有者, chown

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

选项与参数:
-R : 进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都变更
范例:将install.log的拥有者改为test这个账号:
[root@www ~]# chown test install.log
[root@www ~]# ls -l
-rw-r–r– 1 test users 68495 Jun 25 08:53 install.log
范例:将install.log的拥有者与群组改回为root:
[root@www ~]# chown root:root install.log
[root@www ~]# ls -l
-rw-r–r– 1 root root 68495 Jun 25 08:53 install.log

3、改变权限, chmod

权限的设定方法有两种, 分别可以使用数字或者是符号来进行权限的变更。

  1. 数字类型改变文件权限

    Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己的read/write/execute权限,分别是r:4,w:2,x:1。每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的。

    如果要将.bashrc这个文件所有的权限都设定启用,那么就下达:

    [root@www ~]# ls -al test.txt
    -rw-r–r– 1 root root 395 Jul 4 11:45 test.txt
    [root@www ~]# chmod 777 test.txt
    [root@www ~]# ls -al test.txt
    -rwxrwxrwx 1 root root 395 Jul 4 11:45 test.txt

  2. 符号类型改变文件权限

    基本上就九个权限分别是(1)user (2)group (3)others三种身份啦!那么我们就可以藉由u, g, o来代表三种身份的权限!此外, a 则代表 all 亦即全部的身份!

这里写图片描述

[root@VM_0_2_centos xuan]# ll
-rw-r–r– 1 root root 2554 Jun 27 15:53 test.txt
[root@VM_0_2_centos xuan]# chmod u=rwx,go=rx test.txt
[root@VM_0_2_centos xuan]# ll
total 4
-rwxr-xr-x 1 root root 2554 Jun 27 15:53 test.txt

文件与目录管理

1、文件与目录的检视: ls

[root@www ~]# ls [-aAdfFhilnrRSt] 目录名称
[root@www ~]# ls [–color={never,auto,always}] 目录名称
[root@www ~]# ls [–full-time] 目录名称
选项与参数:
-a :全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
-A :全部的文件,连同隐藏档,但不包括 . 与 .. 这两个目录
-d :仅列出目录本身,而不是列出目录内的文件数据(常用)
-f :直接列出结果,而不进行排序 (ls 默认会以档名排序!)
-F :根据文件、目录等资讯,给予附加数据结构,例如:
*:代表可运行档; /:代表目录; =:代表 socket 文件; |:代表 FIFO 文件;
-h :将文件容量以人类较易读的方式(例如 GB, KB 等等)列出来;
-i :列出 inode 号码,inode 的意义下一章将会介绍;
-l :长数据串列出,包含文件的属性与权限等等数据;(常用)
-n :列出 UID 与 GID 而非使用者与群组的名称 (UID与GID会在帐号管理提到!)
-r :将排序结果反向输出,例如:原本档名由小到大,反向则为由大到小;
-R :连同子目录内容一起列出来,等於该目录下的所有文件都会显示出来;
-S :以文件容量大小排序,而不是用档名排序;
-t :依时间排序,而不是用档名。
–color=never :不要依据文件特性给予颜色显示;
–color=always :显示颜色
–color=auto :让系统自行依据配置来判断是否给予颜色
–full-time :以完整时间模式 (包含年、月、日、时、分) 输出
–time={atime,ctime} :输出 access 时间或改变权限属性时间 (ctime)

2、cp(复制文件)

root@www ~]# cp [-adfilprsu] 来源档(source) 目标档(destination)
[root@www ~]# cp [options] source1 source2 source3 …. directory
选项与参数:
-a :相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用)
-d :若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
-f :为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
-i :若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
-l :进行硬式连结(hard link)的连结档创建,而非复制文件本身;
-p :连同文件的属性一起复制过去,而非使用默认属性(备份常用);
-r :递回持续复制,用於目录的复制行为;(常用)
-s :复制成为符号连结档 (symbolic link),亦即『捷径』文件;

3、rm(移除文件或者目录)

[root@www ~]# rm [-fir] 文件或目录
选项与参数:
-f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
-i :互动模式,在删除前会询问使用者是否动作
-r :递回删除啊!最常用在目录的删除了!这是非常危险的选项!!!

4、mv(移动文件与目录,或者更名)

[root@www ~]# mv [-fiu] source destination
[root@www ~]# mv [options] source1 source2 source3 …. directory
选项与参数:
-f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
-i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
-u :若目标文件已经存在,且 source 比较新,才会升级 (update)

文件内容查阅

1、cat(concatenate)

[root@www ~]# cat [-AbEnTv] file
选项与参数:
-A :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
-b :列出行号,仅针对非空白行做行号显示,空白行不标行号!
-E :将结尾的断行字节 $ 显示出来;
-n :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
-T :将 [tab] 按键以 ^I 显示出来;
-v :列出一些看不出来的特殊字符

2、tac(反向列示)

[root@www ~]# tac [-AbEnTv] file

3、nl(添加行号列印)

[root@www ~]# nl [-bnw] 文件
选项与参数:
-b :指定行号指定的方式,主要有两种:
-b a :表示不论是否为空行,也同样列出行号(类似 cat -n);
-b t :如果有空行,空的那一行不要列出行号(默认值);
-n :列出行号表示的方法,主要有三种:
-n ln :行号在萤幕的最左方显示;
-n rn :行号在自己栏位的最右方显示,且不加 0 ;
-n rz :行号在自己栏位的最右方显示,且加 0 ;
-w :行号栏位的占用的位数。

4、more(一页一页翻动)

[root@www ~]# more /etc/man.config
空白键 (space):代表向下翻一页;
Enter :代表向下翻『一行』;
/字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字;
f :立刻显示出档名以及目前显示的行数;
q :代表立刻离开 more ,不再显示该文件内容。
b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。

5、less(一页一页翻动)

[root@www ~]# less /etc/man.config
空白键 :向下翻动一页;
[pagedown]:向下翻动一页;
[pageup] :向上翻动一页;
/字串 :向下搜寻『字串』的功能;
?字串 :向上搜寻『字串』的功能;
n :重复前一个搜寻 (与 / 或 ? 有关!)
N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
q :离开 less 这个程序;

6、head(取出前面几行)

[root@www ~]# head [-n number] 文件
选项与参数:
-n :后面接数字,代表显示几行的意思

7、tail(取出后面几行)

[root@www ~]# tail [-n number] 文件
选项与参数:
-n :后面接数字,代表显示几行的意思
-f :表示持续侦测后面所接的档名,要等到按下[ctrl]-c才会结束tail的侦测

命令与文件的搜寻

1、which(寻找『运行档』)

[root@www ~]# which [-a] command
选项或参数:
-a :将所有由 PATH 目录中可以找到的命令均列出,而不止第一个被找到的命令名称

2、whereis(寻找特定文件)

[root@www ~]# whereis [-bmsu] 文件或目录名
选项与参数:
-b :只找 binary 格式的文件
-m :只找在说明档 manual 路径下的文件
-s :只找 source 来源文件
-u :搜寻不在上述三个项目当中的其他特殊文

3、locate(搜寻档案系统内是否有指定的档案)

[root@www ~]# locate [-ir] keyword
选项与参数:
-i :忽略大小写的差异;
-r :后面可接正规表示法的显示方式

4、find(寻找文件)

[root@www ~]# find [PATH] [option] [action]
选项与参数:
1.与时间有关的选项:共有 -atime, -ctime 与 -mtime ,以 -mtime 说明
-mtime  n :n 为数字,意义为在 n 天之前的『一天之内』被更动过内容的文件;
-mtime +n :列出在 n 天之前(不含 n 天本身)被更动过内容的文件档名;
-mtime -n :列出在 n 天之内(含 n 天本身)被更动过内容的文件档名。
-newer file :file 为一个存在的文件,列出比 file 还要新的文件档名
范例一:将过去系统上面 24 小时内有更动过内容 (mtime) 的文件列出
[root@www ~]# find / -mtime 0
# 那个 0 是重点!0 代表目前的时间,所以,从现在开始到 24 小时前,
# 有变动过内容的文件都会被列出来!那如果是三天前的 24 小时内?
# find / -mtime 3 有变动过的文件都被列出的意思!
范例二:寻找 /etc 底下的文件,如果文件日期比 /etc/passwd 新就列出
[root@www ~]# find /etc -newer /etc/passwd
# -newer 用在分辨两个文件之间的新旧关系是很有用的!
选项与参数:
2.与使用者或群组名称有关的参数:
-uid n :n 为数字,这个数字是使用者的帐号 ID,亦即 UID ,这个 UID 是记录在
      /etc/passwd 里面与帐号名称对应的数字。这方面我们会在第四篇介绍。
-gid n :n 为数字,这个数字是群组名称的 ID,亦即 GID,这个 GID 记录在
      /etc/group,相关的介绍我们会第四篇说明~
-user name :name 为使用者帐号名称喔!例如 dmtsai 
-group name:name 为群组名称喔,例如 users ;
-nouser    :寻找文件的拥有者不存在 /etc/passwd 的人!
-nogroup   :寻找文件的拥有群组不存在於 /etc/group 的文件!
          当你自行安装软件时,很可能该软件的属性当中并没有文件拥有者,
          这是可能的!在这个时候,就可以使用 -nouser 与 -nogroup 搜寻。
范例三:搜寻 /home 底下属於 vbird 的文件
[root@www ~]# find /home -user vbird
# 这个东西也很有用的~当我们要找出任何一个使用者在系统当中的所有文件时,
# 就可以利用这个命令将属於某个使用者的所有文件都找出来喔!
范例四:搜寻系统中不属於任何人的文件
[root@www ~]# find / -nouser
# 透过这个命令,可以轻易的就找出那些不太正常的文件。
# 如果有找到不属於系统任何人的文件时,不要太紧张,
# 那有时候是正常的~尤其是你曾经以原始码自行编译软件时。
选项与参数:
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.... 的属性存在!
范例五:找出档名为 passwd 这个文件
[root@www ~]# find / -name passwd
# 利用这个 -name 可以搜寻档名啊!
范例六:找出 /var 目录下,文件类型为 Socket 的档名有哪些?
[root@www ~]# find /var -type s
# 这个 -type 的属性也很有帮助喔!尤其是要找出那些怪异的文件,
# 例如 socket 与 FIFO 文件,可以用 find /var -type p 或 -type s 来找!
范例七:搜寻文件当中含有 SGID 或 SUID 或 SBIT 的属性
[root@www ~]# find / -perm +7000 
# 所谓的 7000 就是 ---s--s--t ,那么只要含有 s 或 t 的就列出,
# 所以当然要使用 +7000 ,使用 -7000 表示要含有 ---s--s--t 的所有三个权限,
# 因此,就是 +7000 ~了乎?
选项与参数:
4.额外可进行的动作:
-exec command :command 为其他命令,-exec 后面可再接额外的命令来处理搜寻到的结果。
-print        :将结果列印到萤幕上,这个动作是默认动作!
范例八:将上个范例找到的文件使用 ls -l 列出来~
[root@www ~]# find / -perm +7000 -exec ls -l {} \;
# 注意到,那个 -exec 后面的 ls -l 就是额外的命令,命令不支持命令别名,
# 所以仅能使用 ls -l 不可以使用 ll 喔!注意注意!
范例九:找出系统中,大於 1MB 的文件
[root@www ~]# find / -size +1000k
# 虽然在 man page 提到可以使用 M 与 G 分别代表 MB 与 GB,
# 不过,俺却试不出来这个功能~所以,目前应该是仅支持到 c 与 k 吧!
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值