美文网首页
linux基础命令详解

linux基础命令详解

作者: mayufo | 来源:发表于2018-08-11 15:48 被阅读0次

    cd:变换目录

    .         代表此层目录
    ..        代表上一层目录
    -         代表前一个工作目录
    ~         代表『目前使用者身份』所在的家目录
    ~account  代表 account 这个使用者的家目录(account是个帐号名称)
    
    [root@www ~]# cd [相对路径或绝对路径]
    # 最重要的就是目录的绝对路径与相对路径,还有一些特殊目录的符号罗!
    [root@www ~]# cd ~vbird
    # 代表去到 vbird 这个使用者的家目录,亦即 /home/vbird
    [root@www vbird]# cd ~
    # 表示回到自己的家目录,亦即是 /root 这个目录
    [root@www ~]# cd
    # 没有加上任何路径,也还是代表回到自己家目录的意思喔!
    [root@www ~]# cd ..
    # 表示去到目前的上一级目录,亦即是 /root 的上一级目录的意思;
    [root@www /]# cd -
    # 表示回到刚刚的那个目录,也就是 /root 罗~
    [root@www ~]# cd /var/spool/mail
    # 这个就是绝对路径的写法!直接指定要去的完整路径名称!
    [root@www mail]# cd ../mqueue
    # 这个是相对路径的写法,我们由/var/spool/mail 去到/var/spool/mqueue 就这样写!
    

    pwd:显示目前的目录

    
    [root@www ~]# pwd [-P]
    选项与参数:
    -P  :显示出确实的路径,而非使用连结 (link) 路径。
    
    范例:单纯显示出目前的工作目录:
    [root@www ~]# pwd
    /root   <== 显示出目录啦~
    
    范例:显示出实际的工作目录,而非连结档本身的目录名而已
    [root@www ~]# cd /var/mail   <==注意,/var/mail是一个连结档
    [root@www mail]# pwd
    /var/mail         <==列出目前的工作目录
    [root@www mail]# pwd -P
    /var/spool/mail   <==怎么回事?有没有加 -P 差很多~
    [root@www mail]# ls -ld /var/mail
    lrwxrwxrwx 1 root root 10 Sep  4 17:54 /var/mail -> spool/mail
    

    mkdir:创建一个新的目录

    | 
    
    <pre>[root@www ~]# mkdir [-mp] 目录名称
    选项与参数:
    -m :配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~
    -p :帮助你直接将所需要的目录(包含上一级目录)递回创建起来!
    
    范例:请到/tmp底下尝试创建数个新目录看看:
    [root@www ~]# cd /tmp
    [root@www tmp]# mkdir test    <==创建一名为 test 的新目录
    [root@www tmp]# mkdir test1/test2/test3/test4
    mkdir: cannot create directory `test1/test2/test3/test4': 
    No such file or directory       <== 没办法直接创建此目录啊!
    [root@www tmp]# mkdir -p test1/test2/test3/test4
    # 加了这个 -p 的选项,可以自行帮你创建多层目录!
    
    范例:创建权限为rwx--x--x的目录
    [root@www tmp]# mkdir -m 711 test2
    [root@www tmp]# ls -l
    drwxr-xr-x  3 root  root 4096 Jul 18 12:50 test
    drwxr-xr-x  3 root  root 4096 Jul 18 12:53 test1
    drwx--x--x  2 root  root 4096 Jul 18 12:54 test2
    # 仔细看上面的权限部分,如果没有加上 -m 来强制配置属性,系统会使用默认属性。
    

    rmdir:删除一个空的目录

    
    [root@www ~]# rmdir [-p] 目录名称
    选项与参数:
    -p :连同上一级『空的』目录也一起删除
    
    范例:将於mkdir范例中创建的目录(/tmp底下)删除掉!
    [root@www tmp]# ls -l   <==看看有多少目录存在?
    drwxr-xr-x  3 root  root 4096 Jul 18 12:50 test
    drwxr-xr-x  3 root  root 4096 Jul 18 12:53 test1
    drwx--x--x  2 root  root 4096 Jul 18 12:54 test2
    [root@www tmp]# rmdir test   <==可直接删除掉,没问题
    [root@www tmp]# rmdir test1  <==因为尚有内容,所以无法删除!
    rmdir: `test1': Directory not empty
    [root@www tmp]# rmdir -p test1/test2/test3/test4
    [root@www tmp]# ls -l        <==您看看,底下的输出中test与test1不见了!
    drwx--x--x  2 root  root 4096 Jul 18 12:54 test2
    # 瞧!利用 -p 这个选项,立刻就可以将 test1/test2/test3/test4 一次删除~
    

    PATH

    PATH(一定是大写)这个变量的内容是由一堆目录所组成的,每个目录中间用冒号(:)来隔开

    [root@www ~]# PATH="$PATH":/root
    

    将/root加入PATH当中即可

    ls

    -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) 
                           而非内容变更时间 (modification time)
    
    范例一:将家目录下的所有文件列出来(含属性与隐藏档)
    [root@www ~]# ls -al ~
    total 156
    drwxr-x---  4 root root  4096 Sep 24 00:07 .
    drwxr-xr-x 23 root root  4096 Sep 22 12:09 ..
    -rw-------  1 root root  1474 Sep  4 18:27 anaconda-ks.cfg
    -rw-------  1 root root   955 Sep 24 00:08 .bash_history
    -rw-r--r--  1 root root    24 Jan  6  2007 .bash_logout
    -rw-r--r--  1 root root   191 Jan  6  2007 .bash_profile
    -rw-r--r--  1 root root   176 Jan  6  2007 .bashrc
    drwx------  3 root root  4096 Sep  5 10:37 .gconf
    -rw-r--r--  1 root root 42304 Sep  4 18:26 install.log
    -rw-r--r--  1 root root  5661 Sep  4 18:25 install.log.syslog
    # 这个时候你会看到以 . 为开头的几个文件,以及目录档 (.) (..) .gconf 等等,
    # 不过,目录档档名都是以深蓝色显示,有点不容易看清楚就是了。
    
    范例二:承上题,不显示颜色,但在档名末显示出该档名代表的类型(type)
    [root@www ~]# ls -alF --color=never  ~
    total 156
    drwxr-x---  4 root root  4096 Sep 24 00:07 ./
    drwxr-xr-x 23 root root  4096 Sep 22 12:09 ../
    -rw-------  1 root root  1474 Sep  4 18:27 anaconda-ks.cfg
    -rw-------  1 root root   955 Sep 24 00:08 .bash_history
    -rw-r--r--  1 root root    24 Jan  6  2007 .bash_logout
    -rw-r--r--  1 root root   191 Jan  6  2007 .bash_profile
    -rw-r--r--  1 root root   176 Jan  6  2007 .bashrc
    drwx------  3 root root  4096 Sep  5 10:37 .gconf/
    -rw-r--r--  1 root root 42304 Sep  4 18:26 install.log
    -rw-r--r--  1 root root  5661 Sep  4 18:25 install.log.syslog
    # 注意看到显示结果的第一行,嘿嘿~知道为何我们会下达类似 ./command 
    # 之类的命令了吧?因为 ./ 代表的是『目前目录下』的意思啊!至於什么是 FIFO/Socket ?
    # 请参考前一章节的介绍啊!另外,那个.bashrc 时间仅写2007,能否知道详细时间?
    
    范例三:完整的呈现文件的修改时间 *(modification time)
    [root@www ~]# ls -al --full-time  ~
    total 156
    drwxr-x---  4 root root  4096 2008-09-24 00:07:00.000000 +0800 .
    drwxr-xr-x 23 root root  4096 2008-09-22 12:09:32.000000 +0800 ..
    -rw-------  1 root root  1474 2008-09-04 18:27:10.000000 +0800 anaconda-ks.cfg
    -rw-------  1 root root   955 2008-09-24 00:08:14.000000 +0800 .bash_history
    -rw-r--r--  1 root root    24 2007-01-06 17:05:04.000000 +0800 .bash_logout
    -rw-r--r--  1 root root   191 2007-01-06 17:05:04.000000 +0800 .bash_profile
    -rw-r--r--  1 root root   176 2007-01-06 17:05:04.000000 +0800 .bashrc
    drwx------  3 root root  4096 2008-09-05 10:37:49.000000 +0800 .gconf
    -rw-r--r--  1 root root 42304 2008-09-04 18:26:57.000000 +0800 install.log
    -rw-r--r--  1 root root  5661 2008-09-04 18:25:55.000000 +0800 install.log.syslog
    # 请仔细看,上面的『时间』栏位变了喔!变成较为完整的格式。
    # 一般来说, ls -al 仅列出目前短格式的时间,有时不会列出年份,
    # 藉由 --full-time 可以查阅到比较正确的完整时间格式啊!
    

    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),亦即『捷径』文件;
    -u  :若 destination 比 source 旧才升级 destination !
    最后需要注意的,如果来源档有两个以上,则最后一个目的档一定要是『目录』才行!
    
    范例一:用root身份,将家目录下的 .bashrc 复制到 /tmp 下,并更名为 bashrc
    [root@www ~]# cp ~/.bashrc /tmp/bashrc
    [root@www ~]# cp -i ~/.bashrc /tmp/bashrc
    cp: overwrite `/tmp/bashrc'? n  <==n不覆盖,y为覆盖
    # 重复作两次动作,由於 /tmp 底下已经存在 bashrc 了,加上 -i 选项后,
    # 则在覆盖前会询问使用者是否确定!可以按下 n 或者 y 来二次确认呢!
    
    范例二:变换目录到/tmp,并将/var/log/wtmp复制到/tmp且观察属性:
    [root@www ~]# cd /tmp
    [root@www tmp]# cp /var/log/wtmp . <==想要复制到目前的目录,最后的 . 不要忘
    [root@www tmp]# ls -l /var/log/wtmp wtmp
    -rw-rw-r-- 1 root utmp 96384 Sep 24 11:54 /var/log/wtmp
    -rw-r--r-- 1 root root 96384 Sep 24 14:06 wtmp
    # 注意上面的特殊字体,在不加任何选项的情况下,文件的某些属性/权限会改变;
    # 这是个很重要的特性!要注意喔!还有,连文件创建的时间也不一样了!
    # 那如果你想要将文件的所有特性都一起复制过来该怎办?可以加上 -a 喔!如下所示:
    
    [root@www tmp]# cp -a /var/log/wtmp wtmp_2
    [root@www tmp]# ls -l /var/log/wtmp wtmp_2
    -rw-rw-r-- 1 root utmp 96384 Sep 24 11:54 /var/log/wtmp
    -rw-rw-r-- 1 root utmp 96384 Sep 24 11:54 wtmp_2
    # 了了吧!整个数据特性完全一模一样!真是不赖~这就是 -a 的特性!
    
    
    范例三:复制 /etc/ 这个目录下的所有内容到 /tmp 底下
    [root@www tmp]# cp /etc/ /tmp
    cp: omitting directory `/etc'   <== 如果是目录则不能直接复制,要加上 -r 的选项
    [root@www tmp]# cp -r /etc/ /tmp
    # 还是要再次的强调喔! -r 是可以复制目录,但是,文件与目录的权限可能会被改变
    # 所以,也可以利用『 cp -a /etc /tmp 』来下达命令喔!尤其是在备份的情况下!
    
    范例四:将范例一复制的 bashrc 创建一个连结档 (symbolic link)
    [root@www tmp]# ls -l bashrc
    -rw-r--r-- 1 root root 176 Sep 24 14:02 bashrc  <==先观察一下文件情况
    [root@www tmp]# cp -s bashrc bashrc_slink
    [root@www tmp]# cp -l bashrc bashrc_hlink
    [root@www tmp]# ls -l bashrc*
    -rw-r--r-- 2 root root 176 Sep 24 14:02 bashrc  <==与原始文件不太一样了!
    -rw-r--r-- 2 root root 176 Sep 24 14:02 bashrc_hlink
    lrwxrwxrwx 1 root root   6 Sep 24 14:20 bashrc_slink -> bashrc
    
    范例五:若 ~/.bashrc 比 /tmp/bashrc 新才复制过来
    [root@www tmp]# cp -u ~/.bashrc /tmp/bashrc
    # 这个 -u 的特性,是在目标文件与来源文件有差异时,才会复制的。
    # 所以,比较常被用於『备份』的工作当中喔! ^_^
    
    范例六:将范例四造成的 bashrc_slink 复制成为 bashrc_slink_1 与bashrc_slink_2
    [root@www tmp]# cp bashrc_slink bashrc_slink_1
    [root@www tmp]# cp -d bashrc_slink bashrc_slink_2
    [root@www tmp]# ls -l bashrc bashrc_slink*
    -rw-r--r-- 2 root root 176 Sep 24 14:02 bashrc
    lrwxrwxrwx 1 root root   6 Sep 24 14:20 bashrc_slink -> bashrc
    -rw-r--r-- 1 root root 176 Sep 24 14:32 bashrc_slink_1       <==与原始文件相同
    lrwxrwxrwx 1 root root   6 Sep 24 14:33 bashrc_slink_2 -> bashrc <==是连结档!
    # 这个例子也是很有趣喔!原本复制的是连结档,但是却将连结档的实际文件复制过来了
    # 也就是说,如果没有加上任何选项时,cp复制的是原始文件,而非连结档的属性!
    # 若要复制连结档的属性,就得要使用 -d 的选项了!如 bashrc_slink_2 所示。
    
    范例七:将家目录的 .bashrc 及 .bash_history 复制到 /tmp 底下
    [root@www tmp]# cp ~/.bashrc ~/.bash_history /tmp
    # 可以将多个数据一次复制到同一个目录去!最后面一定是目录!
    

    rm

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

    mv

    
    [root@www ~]# mv [-fiu] source destination
    [root@www ~]# mv [options] source1 source2 source3 .... directory
    选项与参数:
    -f  :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
    -i  :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
    -u  :若目标文件已经存在,且 source 比较新,才会升级 (update)
    范例一:复制一文件,创建一目录,将文件移动到目录中
    [root@www ~]# cd /tmp
    [root@www tmp]# cp ~/.bashrc bashrc
    [root@www tmp]# mkdir mvtest
    [root@www tmp]# mv bashrc mvtest
    # 将某个文件移动到某个目录去,就是这样做!
    
    范例二:将刚刚的目录名称更名为 mvtest2
    [root@www tmp]# mv mvtest mvtest2 <== 这样就更名了!简单~
    # 其实在 Linux 底下还有个有趣的命令,名称为 rename ,
    # 该命令专职进行多个档名的同时更名,并非针对单一档名变更,与mv不同。请man rename。
    
    范例三:再创建两个文件,再全部移动到 /tmp/mvtest2 当中
    [root@www tmp]# cp ~/.bashrc bashrc1
    [root@www tmp]# cp ~/.bashrc bashrc2
    [root@www tmp]# mv bashrc1 bashrc2 mvtest2
    # 注意到这边,如果有多个来源文件或目录,则最后一个目标档一定是『目录!』
    # 意思是说,将所有的数据移动到该目录的意思!
    

    cat

    [root@www ~]# cat [-AbEnTv]
    选项与参数:
    -A  :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
    -b  :列出行号,仅针对非空白行做行号显示,空白行不标行号!
    -E  :将结尾的断行字节 $ 显示出来;
    -n  :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
    -T  :将 [tab] 按键以 ^I 显示出来;
    -v  :列出一些看不出来的特殊字符
    
    
    [root@www ~]# cat [-AbEnTv]
    选项与参数:
    -A  :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
    -b  :列出行号,仅针对非空白行做行号显示,空白行不标行号!
    -E  :将结尾的断行字节 $ 显示出来;
    -n  :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
    -T  :将 [tab] 按键以 ^I 显示出来;
    -v  :列出一些看不出来的特殊字符
    
    范例一:检阅 /etc/issue 这个文件的内容
    [root@www ~]# cat /etc/issue
    CentOS release 5.3 (Final)
    Kernel \r on an \m
    
    范例二:承上题,如果还要加印行号呢?
    [root@www ~]# cat -n /etc/issue
         1  CentOS release 5.3 (Final)
         2  Kernel \r on an \m
         3
    # 看到了吧!可以印出行号呢!这对於大文件要找某个特定的行时,有点用处!
    # 如果不想要编排空白行的行号,可以使用『cat -b /etc/issue』,自己测试看看:
    
    范例三:将 /etc/xinetd.conf 的内容完整的显示出来(包含特殊字节)
    [root@www ~]# cat -A /etc/xinetd.conf
    #$
    ....(中间省略)....
    $
    defaults$
    {$
    # The next two items are intended to be a quick access place to$
    ....(中间省略)....
    ^Ilog_type^I= SYSLOG daemon info $
    ^Ilog_on_failure^I= HOST$
    ^Ilog_on_success^I= PID HOST DURATION EXIT$
    ....(中间省略)....
    includedir /etc/xinetd.d$
     $
    

    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 ~了乎?
    

    相关文章

      网友评论

          本文标题:linux基础命令详解

          本文链接:https://www.haomeiwen.com/subject/ivxdbftx.html