linux常用命令_linux常用命令全集 - CSDN
精华内容
参与话题
  • linux常用命令(详解)

    万次阅读 多人点赞 2018-08-29 09:45:41
    一、日常使用命令/常用快捷键命令 开关机命令  1、shutdown –h now:立刻进行关机  2、shutdown –r now:现在重新启动计算机  3、reboot:现在重新启动计算机  4、su -:切换用户;passwd:修改用户密码 ...

    一、日常使用命令/常用快捷键命令

    开关机命令

            1、shutdown –h now:立刻进行关机

            2、shutdown –r now:现在重新启动计算机

            3、reboot:现在重新启动计算机

            4、su -:切换用户;passwd:修改用户密码

            5、logout:用户注销

    常用快捷命令

            1、tab = 补全

            2、ctrl + l -:清屏,类似clear命令

            3、ctrl + r -:查找历史命令(history);ctrl+c = 终止

            4、ctrl+k = 删除此处至末尾所有内容

            5、ctrl+u = 删除此处至开始所有内容

    常用工具命令

    man:帮助命令
        wc:文本统计统计
            wordcount
             3      5         29         a.txt
             行数    单词数    字符数    文件名
            常见参数:
                -l:只查看行数
                -w: 只查看单词数
                -c:只查看字符数
        du:文件大小统计
            格式:du [选项参数] dir_path
            常见参数:
                    -s:只统计该文件目录的大小,不递归
                    -h:人性化的显示单位
        find:文件检索命令

    语法
    
    find   path   -option   [   -print ]   [ -exec   -ok   command ]   {} \;
    
    参数说明 :
    
    find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。
    
    expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份。
    
    -mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件
    
    -amin n : 在过去 n 分钟内被读取过
    
    -anewer file : 比文件 file 更晚被读取过的文件
    
    -atime n : 在过去n天内被读取过的文件
    
    -cmin n : 在过去 n 分钟内被修改过
    
    -cnewer file :比文件 file 更新的文件
    
    -ctime n : 在过去n天内被修改过的文件
    
    -empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名称是 name
    
    -ipath p, -path p : 路径名称符合 p 的文件,ipath 会忽略大小写
    
    -name name, -iname name : 文件名称符合 name 的文件。iname 会忽略大小写
    
    -size n : 文件大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组。-type c : 文件类型是 c 的文件。
    
    d: 目录
    
    c: 字型装置文件
    
    b: 区块装置文件
    
    p: 具名贮列
    
    f: 一般文件
    
    l: 符号连结
    
    s: socket
    
    -pid n : process id 是 n 的文件
    
    你可以使用 ( ) 将运算式分隔,并使用下列运算。
    
    exp1 -and exp2
    
    ! expr
    
    -not expr
    
    exp1 -or exp2
    
    exp1, exp2
    实例
    
    将目前目录及其子目录下所有延伸档名是 c 的文件列出来。
    
    # find . -name "*.c"
    
    将目前目录其其下子目录中所有一般文件列出
    
    # find . -type f
    
    将目前目录及其子目录下所有最近 20 天内更新过的文件列出
    
    # find . -ctime -20
    
    查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前询问它们:
    
    # find /var/log -type f -mtime +7 -ok rm {} \;
    
    查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件:
    
    # find . -type f -perm 644 -exec ls -l {} \;
    
    为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径:
    
    # find / -type f -size 0 -exec ls -l {} \;

    二、常用目录/文件操作命令

    1.展示目录列表命令ls(list)

      ls             展示当前目录下的可见文件
      ls -a         展示当前目录下所有的文件(包括隐藏的文件)
      ls -l(ll)      展示当前目录下文件的详细信息
      ll -a          展示当前目录下所有文件的详细信息
      ll -h          友好的显示当前目录下文件的详细信息(其实就是文件的大小可读性更强了)

      pwd:显示目前的目录

    2.切换目录命令cd(change directory)

      cd test         切换到test目录下
      cd .. 切换到上一级目录
      cd / 切换到系统根目录下
      cd ~ 切换到当前用户的根目录下
      cd - 切换到上一级所在的目录

    3.目录的创建(mkdir)和删除(rmdir)命令

      mkdir test 在当前目录下创建一个test目录
      mkdir -p test/a/b 在test目录下的a目录下创建一个b目录,如果上一级目录不存在,则连它的父目录一起创建
      rmdir test 删除当前目录下的test目录(注意:该命令只能够删除空目录)

    4.文件的创建(touch)和删除(rm)命令

      touch test.txt         在当前目录下创建一个test.txt的文件
      rm test.txt 删除test.txt的文件(带询问的删除,需输入y才能删除)
      rm -f test.txt 直接删除text.txt文件
      rm -r test 递归删除,即删除test目录以及其目录下的子目录(带询问的删除)
      rm -rf test 直接删除test目录以及其目录下的子目录

    5.文件打包或解压命令tar

          1. 打包并压缩文件

    Linux中的打包文件一般是以.tar结尾的,压缩的命令一般是以.gz结尾的。

    而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。

    命令:tar -zcvf 打包压缩后的文件名 要打包压缩的文件

    其中:z:调用gzip压缩命令进行压缩

      c:打包文件

      v:显示运行过程

      f:指定文件名

    示例:打包并压缩/test下的所有文件 压缩后的压缩包指定名称为xxx.tar.gz

    tar -zcvf xxx.tar.gz aaa.txt bbb.txt ccc.txt

    或:tar -zcvf xxx.tar.gz /test/*

     

     
     

     

     

          1. 解压压缩包(重点)

    命令:tar [-xvf] 压缩文件

    其中:x:代表解压

    示例:将/test下的xxx.tar.gz解压到当前目录下

     

     
     


    tar -xvf xxx.tar.gz

    示例:将/test下的xxx.tar.gz解压到根目录/usr下

    tar -xvf xxx.tar.gz -C /usr------C代表指定解压的位置

     

     
     

     

     

     

     

     

     

     

        1. Linux的权限命令

    权限是Linux中的重要概念,每个文件/目录等都具有权限,通过ls -l命令我们可以 查看某个目录下的文件或目录的权限

     

    文件的类型:

    d:代表目录

    -:代表文件

    l:代表链接(可以认为是window中的快捷方式)

    后面的9位分为3组,每3位置一组,分别代表属主的权限,与当前用户同组的     用户的权限,其他用户的权限

    r:代表权限是可读,r也可以用数字4表示

    w:代表权限是可写,w也可以用数字2表示

    x:代表权限是可执行,x也可以用数字1表示

     

     

    属主(user

    属组(group

    其他用户

    r

    w

    x

    r

    w

    x

    r

    w

    x

    4

    2

    1

    4

    2

    1

    4

    2

    1

    linux中用户的分类
            小李     小李对象    老王
            所有者u    同组用户g    其他人o
        linux中文件权限
            读r        写w        执行x    没有权限-
            
        文件详情信息:
            -rw-r--r--. 1 root root       5 Aug 28 02:27 a.txt    
            d rwx r-x r-x. 2 root root    4096 Aug 27 08:52 test
            第一位:d:目录,-:文件
            rw-                r--                r--
            所有者           同组用户        其他人
            只有读写          只有读            只有读
            
        1:该文件的链接数
        root:文件所属者
        root:文件所属组
         5 Aug 28 02:27:最后的修改时间

    修改文件/目录的权限的命令:chmod

    示例:修改/test下的aaa.txt的权限为属主有全部权限,属主所在的组有读写权限,

    其他用户只有读的权限

    chmod u=rwx,g=rw,o=r aaa.txt

    上述示例还可以使用数字表示:

    chmod 764 aaa.txt

     

    修改文件的所属用户和所属组 chown
            chown username:groupName aa.txt
            chown username: aa.txt
            chown :groupName aa.txt
        
            -R:递归子目录修改所属者和所属组

    三、文件/文件夹的cp rm及文件的查看

    cp (复制文件或目录)

    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 身份,将 root 目录下的 .bashrc 复制到 /tmp 下,并命名为 bashrc

    [root@www ~]# cp ~/.bashrc /tmp/bashrc
    [root@www ~]# cp -i ~/.bashrc /tmp/bashrc
    cp: overwrite `/tmp/bashrc'? n  <==n不覆盖,y为覆盖

    rm (移除文件或目录)

    语法:

     rm [-fir] 文件或目录

    选项与参数:

    • -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
    • -i :互动模式,在删除前会询问使用者是否动作
    • -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!
    •  

    将刚刚在 cp 的实例中创建的 bashrc 删除掉!

    [root@www tmp]# rm -i bashrc
    rm: remove regular file `bashrc'? y

    如果加上 -i 的选项就会主动询问喔,避免你删除到错误的档名!

    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 文件内容查看

    Linux系统中使用以下命令来查看文件的内容:

    • cat  由第一行开始显示文件内容
    • tac  从最后一行开始显示,可以看出 tac 是 cat 的倒著写!
    • nl   显示的时候,顺道输出行号!
    • more 一页一页的显示文件内容
    • less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
    • head 只看头几行
    • tail 只看尾巴几行

    你可以使用 man [命令]来查看各个命令的使用文档,如 :man cp。

    cat

    由第一行开始显示文件内容

    语法:

    cat [-AbEnTv]

    选项与参数:

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

    检看 /etc/issue 这个文件的内容:

    [root@www ~]# cat /etc/issue
    CentOS release 6.4 (Final)
    Kernel \r on an \m

    tac

    tac与cat命令刚好相反,文件内容从最后一行开始显示,可以看出 tac 是 cat 的倒着写!如:

    [root@www ~]# tac /etc/issue
    
    Kernel \r on an \m
    CentOS release 6.4 (Final)

    nl

    显示行号

    语法:

    nl [-bnw] 文件

    选项与参数:

    • -b :指定行号指定的方式,主要有两种:
      -b a :表示不论是否为空行,也同样列出行号(类似 cat -n);
      -b t :如果有空行,空的那一行不要列出行号(默认值);
    • -n :列出行号表示的方法,主要有三种:
      -n ln :行号在荧幕的最左方显示;
      -n rn :行号在自己栏位的最右方显示,且不加 0 ;
      -n rz :行号在自己栏位的最右方显示,且加 0 ;
    • -w :行号栏位的占用的位数。

    实例一:用 nl 列出 /etc/issue 的内容

    [root@www ~]# nl /etc/issue
         1  CentOS release 6.4 (Final)
         2  Kernel \r on an \m

    more

    一页一页翻动

    [root@www ~]# more /etc/man.config
    #
    # Generated automatically from man.conf.in by the
    # configure script.
    #
    # man.conf from man-1.6d
    ....(中间省略)....
    --More--(28%)  <== 重点在这一行喔!你的光标也会在这里等待你的命令

    在 more 这个程序的运行过程中,你有几个按键可以按的:

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

    less

    一页一页翻动,以下实例输出/etc/man.config文件的内容:

    [root@www ~]# less /etc/man.config
    #
    # Generated automatically from man.conf.in by the
    # configure script.
    #
    # man.conf from man-1.6d
    ....(中间省略)....
    :   <== 这里可以等待你输入命令!

    less运行时可以输入的命令有:

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

    head

    取出文件前面几行

    语法:

    head [-n number] 文件 

    选项与参数:

    • -n :后面接数字,代表显示几行的意思
    [root@www ~]# head /etc/man.config

    默认的情况中,显示前面 10 行!若要显示前 20 行,就得要这样:

    [root@www ~]# head -n 20 /etc/man.config

    tail

    取出文件后面几行

    语法:

    tail [-n number] 文件 

    选项与参数:

    • -n :后面接数字,代表显示几行的意思
    • -f :表示持续侦测后面所接的档名,要等到按下[ctrl]-c才会结束tail的侦测
    [root@www ~]# tail /etc/man.config
    # 默认的情况中,显示最后的十行!若要显示最后的 20 行,就得要这样:
    [root@www ~]# tail -n 20 /etc/man.config

    系统常用操作命令

    visudo:编辑sudo命令的配置
            编辑第98行
            ## Allow root to run any commands anywhere
                root    ALL=(ALL)                               ALL
                用户名  登录的主机=(以什么样的身份运行)  可以执行什么命令
            如果想让huadian用户也居于root相关权限。。
                huadian  ALL=(root)  NOPASSWD:service iptables status
                huadian  ALL=(root)  NOPASSWD:service iptables start
            推荐用法    
                huadian  ALL=(root)  NOPASSWD:ALL
                
            使用权限:sudo     service iptables status  ----(检查防火墙状态)

    网络管理:ping、ifconfig
        服务管理命令:
            service:必须掌握
                格式:
                    service s_name start|stop|status|restart
                linux系统所有自带服务名称:/etc/init.d/
                    常用:
                        关闭防火墙服务
                        service iptables stop
                        重启网络服务:
                        service network restart
                        mysql数据库服务的名称:
                            mysql版本低于5.5  mysqld
                            mysql版本高于5.5  mysql
                
            chkconfig:设置是否开机启动           :必须掌握
                判定是否开机启动
                    chkconfig iptables --list
                    2.3.4.5是on表示开机启动
                设置
                    chkconfig iptables on|off
                        
        进程管理:ps
            ps:查当前进程
                查看java的进程
                ps -ef | grep java
            jps:==(ps -ef | grep java) 只有在linux中安装了JDK才能用
            kill :杀死某个进程
                kill -9 pid
                
        端口管理
            nststat:查看端口开放情况
                -a:表示列举所有的连接、服务器监听
                -t:列出所有tcp协议的服务
                -u:列出所有udp协议的服务
                -n:使用端口号来显示
                -l:列出所有的监听
                -p:列出所有服务的进程id(pid)
                常用:netstat -atunlp
            
        redhat的selinux安全机制
            关闭selinux安全机制
                vim /etc/selinux/config
                    SELINUX=disabled
                重启机器生效

     

    vim/vi命令看下一篇帖子

    vim/vi命令看下一篇帖子

    vim/vi命令看下一篇帖子

    展开全文
  • linux常用的20个命令

    万次阅读 多人点赞 2018-05-09 09:07:25
    玩过Linux的人都会知道,Linux中的命令的确是非常多,但是玩过Linux的人也从来不会因为Linux命令如此之多而烦恼,因为我们只需要掌握我们最常用命令就可以了。当然你也可以在使用时去找一下man,他会帮你解决...


    玩过Linux的人都会知道,Linux中的命令的确是非常多,但是玩过Linux的人也从来不会因为Linux的命令如此之多而烦恼,因为我们只需要掌握我们最常用的命令就可以了。当然你也可以在使用时去找一下man,他会帮你解决不少的问题。然而每个人玩Linux的目的都不同,所以他们常用的命令也就差异非常大,而我主要是用Linux进行C/C++和shell程序编写的,所以常用到的命令可以就会跟一个管理Linux系统的人有所不同。因为不想在使用是总是东查西找,所以在此总结一下,方便一下以后的查看。不多说,下面就说说我最常用的Linux命令。

    1、cd命令
    这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:
    [plain] view plain copy
    1. cd /root/Docements # 切换到目录/root/Docements  
    2. cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录    
    3. cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录  
    2、ls命令
    这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:
    [plain] view plain copy
    1. -l :列出长数据串,包含文件的属性与权限数据等  
    2. -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)  
    3. -d :仅列出目录本身,而不是列出目录的文件数据  
    4. -h :将文件容量以较易读的方式(GB,kB等)列出来  
    5. -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来  
    注:这些参数也可以组合使用,下面举两个例子:
    [plain] view plain copy
    1. ls -l #以长数据串的形式列出当前目录下的数据文件和目录  
    2. ls -lR #以长数据串的形式列出当前目录下的所有文件  
    3、grep命令
    该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为
    [plain] view plain copy
    1. grep [-acinv] [--color=auto] '查找字符串' filename  
    它的常用参数如下:
    [plain] view plain copy
    1. -a :将binary文件以text文件的方式查找数据  
    2. -c :计算找到‘查找字符串’的次数  
    3. -i :忽略大小写的区别,即把大小写视为相同  
    4. -v :反向选择,即显示出没有‘查找字符串’内容的那一行  
    5. # 例如:  
    6. # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色  
    7. grep --color=auto 'MANPATH' /etc/man.config  
    8. # 把ls -l的输出中包含字母file(不区分大小写)的内容输出  
    9. ls -l | grep -i file  
    4、find命令
    find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:
    [plain] view plain copy
    1. find [PATH] [option] [action]  
    2.   
    3. # 与时间有关的参数:  
    4. -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;  
    5. -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;  
    6. -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;  
    7. -newer file : 列出比file还要新的文件名  
    8. # 例如:  
    9. find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件  
    10.   
    11. # 与用户或用户组名有关的参数:  
    12. -user name : 列出文件所有者为name的文件  
    13. -group name : 列出文件所属用户组为name的文件  
    14. -uid n : 列出文件所有者为用户ID为n的文件  
    15. -gid n : 列出文件所属用户组为用户组ID为n的文件  
    16. # 例如:  
    17. find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件  
    18.   
    19. # 与文件权限及名称有关的参数:  
    20. -name filename :找出文件名为filename的文件  
    21. -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件  
    22. -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、  
    23.              目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);  
    24. -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;  
    25. -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示  
    26. -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示  
    27. # 例如:  
    28. find / -name passwd # 查找文件名为passwd的文件  
    29. find . -perm 0755 # 查找当前目录中文件权限的0755的文件  
    30. find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte  
    5、cp命令
    该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:
    [plain] view plain copy
    1. -a :将文件的特性一起复制  
    2. -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  
    3. -i :若目标文件已经存在时,在覆盖时会先询问操作的进行  
    4. -r :递归持续复制,用于目录的复制行为  
    5. -u :目标文件与源文件有差异时才会复制  
    例如 :
    [plain] view plain copy
    1. cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  
    2. cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  
    6、mv命令
    该命令用于移动文件、目录或更名,move之意,它的常用参数如下:
    [plain] view plain copy
    1. -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  
    2. -i :若目标文件已经存在,就会询问是否覆盖  
    3. -u :若目标文件已经存在,且比目标文件新,才会更新  
    注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。

    例如:
    [plain] view plain copy
    1. mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  
    2. mv file1 file2 # 把文件file1重命名为file2  
    7、rm命令
    该命令用于删除文件或目录,remove之间,它的常用参数如下:
    [plain] view plain copy
    1. -f :就是force的意思,忽略不存在的文件,不会出现警告消息  
    2. -i :互动模式,在删除前会询问用户是否操作  
    3. -r :递归删除,最常用于目录删除,它是一个非常危险的参数  
    例如:
    [plain] view plain copy
    1. rm -i file # 删除文件file,在删除之前会询问是否进行该操作  
    2. rm -fr dir # 强制删除目录dir中的所有文件  
    8、ps命令
    该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
    [plain] view plain copy
    1. -A :所有的进程均显示出来  
    2. -a :不与terminal有关的所有进程  
    3. -u :有效用户的相关进程  
    4. -x :一般与a参数一起使用,可列出较完整的信息  
    5. -l :较长,较详细地将PID的信息列出  
    其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:
    [plain] view plain copy
    1. ps aux # 查看系统所有的进程数据  
    2. ps ax # 查看不与terminal有关的所有进程  
    3. ps -lA # 查看系统所有的进程数据  
    4. ps axjf # 查看连同一部分进程树状态  
    9、kill命令
    该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:
    [plain] view plain copy
    1. kill -signal PID  
    signal的常用参数如下:
    注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。
    [plain] view plain copy
    1. 1:SIGHUP,启动被终止的进程  
    2. 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行  
    3. 9:SIGKILL,强制中断一个进程的进行  
    4. 15:SIGTERM,以正常的结束进程方式来终止进程  
    5. 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行  
    例如:
    [plain] view plain copy
    1. # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程  
    2. kill -SIGTERM %1   
    3. # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得  
    4. kill -SIGHUP PID  
    10、killall命令
    该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
    [plain] view plain copy
    1. killall [-iIe] [command name]  
    它的参数如下:
    [plain] view plain copy
    1. -i :交互式的意思,若需要删除时,会询问用户  
    2. -e :表示后面接的command name要一致,但command name不能超过15个字符  
    3. -I :命令名称忽略大小写  
    4. # 例如:  
    5. killall -SIGHUP syslogd # 重新启动syslogd  
    11、file命令
    该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:
    [plain] view plain copy
    1. file filename  
    2. #例如:  
    3. file ./test  
    12、tar命令
    该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
    [plain] view plain copy
    1. -c :新建打包文件  
    2. -t :查看打包文件的内容含有哪些文件名  
    3. -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  
    4. -j :通过bzip2的支持进行压缩/解压缩  
    5. -z :通过gzip的支持进行压缩/解压缩  
    6. -v :在压缩/解压缩过程中,将正在处理的文件名显示出来  
    7. -f filename :filename为要处理的文件  
    8. -C dir :指定压缩/解压缩的目录dir  
    上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:
    [plain] view plain copy
    1. 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  
    2. 查询:tar -jtv -f filename.tar.bz2  
    3. 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录  
    注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip2

    13、cat命令
    该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:
    [plain] view plain copy
    1. cat text | less # 查看text文件中的内容  
    2. # 注:这条命令也可以使用less text来代替  
    14、chgrp命令
    该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:
    [plain] view plain copy
    1. chgrp [-R] dirname/filename  
    2. -R :进行递归的持续对所有文件和子目录更改  
    3. # 例如:  
    4. chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users  
    15、chown命令
    该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。

    16、chmod命令
    该命令用于改变文件的权限,一般的用法如下:
    [plain] view plain copy
    1. chmod [-R] xyz 文件或目录  
    2. -R:进行递归的持续更改,即连同子目录下的所有文件都会更改  
    同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。

    [plain] view plain copy
    1. # 例如:  
    2. chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x  
    3. chmod g+w file # 向file的文件权限中加入用户组可写权限  
    18、vim命令
    该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。

    19、gcc命令
    对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:
    [plain] view plain copy
    1. -o :output之意,用于指定生成一个可执行文件的文件名  
    2. -c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序  
    3. -I :增加编译时搜索头文件的路径  
    4. -L :增加编译时搜索静态连接库的路径  
    5. -S :把源文件生成汇编代码文件  
    6. -lm:表示标准库的目录中名为libm.a的函数库  
    7. -lpthread :连接NPTL实现的线程库  
    8. -std= :用于指定把使用的C语言的版本  
    9.   
    10. # 例如:  
    11. # 把源文件test.c按照c99标准编译成可执行程序test  
    12. gcc -o test test.c -lm -std=c99  
    13. #把源文件test.c转换为相应的汇编程序源文件test.s  
    14. gcc -S test.c  
    20、time命令
    该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:
    [plain] view plain copy
    1. time ./process  
    2. time ps aux  
    在程序或命令运行结束后,在最后输出了三个时间,它们分别是:
    user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;
    system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;
    real:实际时间,从command命令行开始执行到运行终止的消逝时间;

    注:用户CPU时间和系统CPU时间之和为CPU时间,即命令占用CPU执行的时间总和。实际时间要大于CPU时间,因为Linux是多任务操作系统,往往在执行一条命令时,系统还要处理其它任务。另一个需要注意的问题是即使每次执行相同命令,但所花费的时间也是不一样,其花费时间是与系统运行相关的。

    展开全文
  • Linux系统常用基本命令总结

    万次阅读 多人点赞 2020-07-30 19:22:46
    目录 ...常用命令与示例 一、文件基本操作命令 1. ls命令 2. pwd命令 3. mkdir命令 4. cd命令 5. touch命令 6. cp命令 7. mv命令 8. rmdir命令 9. rm命令 10. cat命令 11 more和 les...

    目录

    Linux基本命令

    Linux的简介

    Linux的厂商

    Linux的目录结构

    基于虚拟机的环境搭建

    常用命令与示例

    一、文件基本操作命令

    1. ls命令

    2.  pwd命令

    3.  mkdir命令

    4. cd命令

    5. touch命令

    6. cp命令

    7. mv命令

    8.  rmdir命令

    9.  rm命令

    10.  cat命令

    11  more和 less命令

    12.  head命令

    13.  tail命令

    二、用户、组管理命令

    1. groupadd命令

    2. useradd命令

    3. userdel命令

    4. groupdel命令

    5. passwd命令

    6. usermod命令

    7. id命令

    三、 文件属性操作命令

    1. chown命令

    2. chgrp命令

     3. chmod命令

    四、i节点及其相关命令

    (1)ln命令示例一——建立硬连接

    (2)ln命令示例二——建立符号连接

    五、 查找命令

    1. which命令

    2. whereis命令

    3. find命令

    六、 文件内容操作命令

    1. grep命令

    2. wc命令

    3. sort命令

    4. diff 命令

    5. cut 命令

    七、 压缩与打包命令

    1. tar命令

    八、网卡配置命令

    (1)ifconfig命令示例一——显示接口(网卡)配置参数

    (2)ifconfig命令示例二——设置接口(网卡)配置参数

    (3)ifconfig命令示例三——禁用某块网卡

    (4)ifconfig命令示例四——激活某块网卡

    九、rpm命令

    (1)rpm命令示例一——查询系统中安装的软件包

    (2)rpm命令示例二——查询软件包中文件清单

    (3)rpm命令示例三——卸载指定的软件包

    (4)rpm命令示例四——安装软件包

    (5)rpm命令示例五——强制安装软件包

    (6)rpm命令示例五——忽略依赖关系安装软件包

    # rpm  -ivh  --nodeps  php-4.3.9-3.1-i386.rpm

    (7)卸载

    十、 其他安装方式

    yum安装       yum install 软件名字       yum install yum-fastestmirror       yum remove

    源码安装

    十一、 查看进程命令

    1. ps命令

    2. pstree命令

    3. top命令

    4. kill命令


     

    Linux基本命令

    Linux的简介

    Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    Linux操作系统诞生于1991 年10 月5 日(这是第一次正式向外公布时间)。Linux存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。

     

    Linux的厂商

     

    Linux的目录结构

    基于虚拟机的环境搭建

    vi /etc/sysconfig/network-scripts/ifcfg-eth0

    DEVICE=eth0 #网卡设备名称
                ONBOOT=yes #启动时是否激活 yes|no
                BOOTPROTO=static #协议类型 dhcp bootp none
                IPADDR=192.168.134.136 #网络IP地址
                NETMASK=255.255.255.0 #网络子网地址
                GATEWAY=                     #网关地址
                BROADCAST=192.168.134.255 #广播地址
                TYPE=Ethernet #网卡类型为以太网

    关闭防火墙

         service iptables stop

         chkconfig iptables off

    常用命令与示例

    说明:

    • Linux 命令及其参数是严格区分大小写

    • Linux文件名严格区分大小写

    一、文件基本操作命令

    1. ls命令

    • ls命令的功能是显示指定目录下的文件目录清单相当于dos下的dir命令,而且其参数更加丰富多样。

    1ls示例一——不带参数

    [root@yxy ~]# ls

    anaconda-ks.cfg  install.log  install.log.syslog

    功能:显示指定目录中的文件清单,如果没有指定任何目录,则默认为当前目录。

    2ls示例二——显示隐含文件

    [root@yxy ~]# ls -a

    .   anaconda-ks.cfg  .bash_logout   .bashrc  install.log         .tcshrc

    ..  .bash_history    .bash_profile  .cshrc   install.log.syslog

    参数-a的功能:显示隐含文件。

    说明:若文件名以“.”开头,则认为是隐含的,进而普通的ls命令不显示以“.”开头的文件;所以要完全显示某目录下的文件清单,必须加上-a参数才行。

    3ls示例三——长格式输出

    [root@yxy ~]# ls -l

    总用量 24

    -rw-------. 1 root root  1116 11月 13 18:15 anaconda-ks.cfg

    -rw-r--r--. 1 root root 12526 11月 13 18:15 install.log

    -rw-r--r--. 1 root root  3482 11月 13 18:14 install.log.syslog

    参数-l 的功能是:以长格式列表输出指定目录中的文件清单

    以上述输出中文件install.log为例

     解释长格式输出的内容如下

    文件权限  连接数  属主    属组    大小   日期     时间      文件名

    -rw-r--r--.    1   root   root   12526  1113 18:15 install.log

    Linux文件有三种典型的权限,即r读权限、w写权限和x执行权限。在长格式输出中在文件类型的后面有9列权限位,实际上这是针对不同用户而设定的,如下所示。

    属主的权限  属组的权限  其他用户的权限

         rwx                 rwx                  r-x

    4ls示例四——递归显示

    [root@yxy ~]# ls -R

    .:

    anaconda-ks.cfg  install.log  install.log.syslog

    参数-R 的功能是:递归显示指定目录下的文件清单,

    即会显示指定目录分支内各子目录中的文件清单。

    2.  pwd命令

    示例:pwd

    [root@yxy ~]# pwd

    /root

    功能:显示当前目录

    3.  mkdir命令

    1mkdir示例一

    [root@yxy ~]# mkdir abc

    功能:在当前目录下创建目录abc

    2mkdir示例二——创建多级目录

    [root@yxy ~]# mkdir -p a/b/c

    [root@yxy ~]# ls -R a

    a:

    b

     

    a/b:

    c

     

    a/b/c:功能:参数-p功能是如果要创建的目录的父目录不存在,则先创建其父目录,再创建该目录; 如果指定的目录存在,则不影响原目录,也不会报错。在本示例中会连续创建a目录、a/b目录、a/b/c目录。

    4. cd命令

    (1)cd示例一——切换工作目录

    [root@yxy ~]# cd /var

    [root@yxy var]# pwd

    /var

    功能:将当前的工作目录切换为/var

    (2)cd示例二——切换到当前用户的主目录

    [root@yxy var]# cd

    [root@yxy ~]# pwd

    /root

    功能:不带参数的cd命令直接将当前的工作目录切换为该用户的主目录。主目录又称为家目录,在RHEL中是在创建用户时,自动在/home下为用户创建一个用其用户名同名的目录,并将该目录的所有权划归给该用户所有。

    注意:字符“~”代表(当前)用户的主目录。                   

    5. touch命令

    1touch示例一——创建空文件

    [root@yxy ~]# touch myfile

    [root@yxy ~]# ls -l myfile

    -rw-r--r--. 1 root root 0 11月 13 23:48 myfile

    功能:如果myfile不存在,则创建一个大小为0字节名为myfile的空文件。

    2touch示例二——改变文件的最后修改时间

    再执行一次touch myfile

    [root@yxy ~]# touch myfile

    [root@yxy ~]# ls -l myfile

    -rw-r--r--. 1 root root 0 11月 13 23:49 myfile

    功能:如果myfile已存在,则将改变myfile的最后修改时间。

    6. cp命令

    1cp示例一——复制文件

    [root@yxy ~]# cp /etc/*   abc

    功能:将/etc/目录下的文件复制到目录abc中。*是通配符,可以匹配多个字符;“?”只能匹配一个字符。

    2cp示例二——复制目录

    [root@yxy ~]# cp  -R   /etc  abc

    功能:增加了参数-,就能将目录/etc下面的所有子目录和文件都复制到目录abc中。

    7. mv命令

    1mv示例一——将文件移动到目录中

    [root@yxy ~]# mv  myfile  mydir1

    功能:如果mydir1存在且是个目录,则将文件myfile移动到目录mydir1中。

    2mv示例二——文件改名

    [root@yxy ~]# mv myfile myfile2

    功能:将文件(或目录)myfile改名myfile2

    8.  rmdir命令

    [root@yxy ~]# rmdir   mydir1

    功能:删除指定的空目录

    9.  rm命令

    1rm示例一——删除文件

    [root@yxy ~]# rm  php.ini

    功能:删除指定的文件 php.ini。

    2rm示例二——删除目录

    [root@yxy ~]# rm  -rf  abc

    功能:参数-r递归的意思,即可以删除非空目录;参数-f强制的意思。

    10.  cat命令

    1cat示例一——显示文件内容

    [root@yxy ~]# cat myfile

    hello,world

    功能:指定文件myfile的内容

    2cat示例二——创建文件

    [root@yxy ~]# cat  >  myfile2

    Welcome to Linux World!

    ctrl+d结束输入

    功能:利用输出重定向符“>”来创建简短的文本文件myfile2。

    11  more less命令

    # more  /etc/httpd/conf/httpd.conf

    功能:分屏显示指定文件httpd.conf的内容,非常适合显示超过一屏的文本文件。每按一下空格键,向后翻一屏;每按一次回车键,向后翻一行。

    说明:less与more功能很相似,只不过less功能更强大,支持PageUp键向前翻屏,及PageDown向后翻屏。

    12.  head命令

    1head示例一——显示文件头10行内容

    # head  /etc/httpd/conf/httpd.conf

    功能:默认显示指定文件的10的内容。

    2head示例二——显示文件头n行内容

    # head -n 19 /etc/httpd/conf/httpd.conf

    功能:参数-n设置显示指定行数,本例会显示文件的头19行的内容。

    13.  tail命令

    1tail示例一——显示文件最后10行内容

    # tail  /etc/httpd/conf/httpd.conf

    功能:默认显示指定文件的末尾10的内容。

     2tail示例二——显示文件最后n行内容

    # tail  -n 12  /etc/httpd/conf/httpd.conf

    功能:参数-n设置显示指定行数;

              本例会显示文件的末尾12行的内容。

    二、用户、组管理命令

    • Linux采用来组织和管理用户

    • 在Linux中每个用户有唯一的用户标识符UID,该UID是一个无符号整数。

    • 同时每个用户也必须至少属于一个组,也有组标识符GID

    • 其中UID与GID独立编号。

     

    1. groupadd命令

    1groupadd示例一——创建组账号

    [root@yxy ~]# groupadd  mygroup1

    功能:创建一个新组mygroup1,其GID号为已存在GID号的下一个顺序编号。

    说明:创建一个组的同时会在/etc/group文件中为该组增加相应的一行,用来记录该组的名称、GID号及成员等信息

    2groupadd示例二——创建组账号并设置其GID

    # groupadd  -g 5000  mygroup2

    功能:创建一个新组mygroup2,并指定其GID号为5000,其中-g用来设置用户的主要组,每个用户都有一个主要组。

    2. useradd命令

    1useradd示例一——创建用户账号

    [root@yxy ~]# useradd  user1

    功能:创建一个用户user1,同时在/etc/passwd文件和/etc/shadow文件增加一行,并自动为用户创建相应的主目录:/home/user1。

    说明:/etc/passwd文件记录了系统中每个用户的用户名、UID号、GID号、主目录、shell等信息

    注意:用户的口令原来也存放在此文件中,现在为了保证安全采用了影子口令文件/etc/shadow来保存每个用户的口令

    2useradd示例二——创建用户账号并设置相应属性值

    # useradd  -u 600  -g mygroup1  -G mygroup2  -d  /home/student1  s1

    功能:创建用户s1,其中参数

    -u指定UID号为600;

    -g指定用户的主要组为mygroup1;

    -G指定用户的附加组为mygroup2,每个用户可以有多个附加组;

    -d 指定用户的主目录为/home/student1。

    3. userdel命令

    1userdel示例一——删除用户

    [root@yxy ~]# userdel  user1

    功能:删除指定的用户user1。

    2userdel示例二——删除用户的同时删除其主目录

    [root@yxy ~]# userdel  -r  user2

    功能:删除指定的用户user2,同时删除其主目录

    4. groupdel命令

    [root@yxy ~]# groupdel mygroup2

    功能:删除指定的组

    注意:当某个组是某现有用户的主要组时,则不能被删除。

     

    5. passwd命令

    1passwd示例一——改变口令

    [root@yxy ~]# passwd

    Changing password for user user1.

    Changing password for user1

    (current) Unix password:

    New Unix password:

    BAD PASSWORD: it is too simplistic/systematic

    New Unix password:

    BAD PASSWORD: is too similar to the old one

    New Unix password:

    Retype new Unix password:

    passwd: all authentication tokens updated successfully.

    功能:普通用户只可以修改自己的口令

    2passwd示例二——禁止用户登录 

    [root@yxy ~]# passwd  -l  user1

    Locking password for user user1.

    passwd: Success

    功能:参数-l 可以给指定的用户user1加锁,即禁止该用户登录。

    3passwd示例三——恢复用户登录

    [root@yxy ~]# passwd  –u  user1

    Unlocking password for user user1.

    passwd: Success.

    功能:参数-u 可以给指定的用户user1解锁,即恢复该用户登录。

    4passwd示例四——删除用户口令

     [root@yxy ~]# passwd  -d  user1

    Removing password for user user1.

    passwd: Success

    功能:参数-d 可以删除指定的用户user1口令,即以user1登录时无需口令。

    6. usermod命令

    # usermod  -u  601  -g 501  s1

    功能:将(已存在的)用户s1的UID号修改为601、主要组修改为501

    7. id命令

    [root@yxy ~]# id  user1

    uid=501(user1) gid=501(user1) groups=501(user1)

    功能:显示用户的UIDGID及所属的组信息

     

    三、 文件属性操作命令

     

    1. chown命令

    1chown示例一——改变文件的属主

    [root@yxy ~]# chown  user1  hello.txt

    功能:将指定文件hello.txt的属主(所有者)改为user1。

    2chown示例二——递归改变文件的属主

    # chown  -R  user1  mydir

    功能:参数-R,表示递归即可以深入到指定目录中的每一层,将所有子目录和文件的属主(所有者)改为指定的用户;本例中会mydir目录中所有子目录和文件的属主设定为user1

    2. chgrp命令

    1chgrp示例一——改变文件的属组

    # chgrp  mygroup1  hello.txt

    功能:将指定文件hello.txt的属组改为mygroup1。

    2chgrp示例二——递归改变文件的属组

    # chgrp  -R  mygroup1  mydir

    功能:参数-R,表示递归,即可以深入到指定目录中的每一层,将所有子目录和文件的属组改为指定的组;本例中会将mydir目录中所有子目录和文件的属组设定为mygroup1。

     3. chmod命令

    1chmod示例一——字母方式

       图中字母u针对属主、g针对属组、o针对其他用户、a针对所有用户;

        =表示赋予(设置)指定权限,要注意它会覆盖原权限,+表示在原有权限的基础上增加指定权限,-表示在原有权限的基础上去掉指定权限;

        rwx三种权限,既可以单独使用也可以组合使用

    # chmod  u+x  host.conf

    功能:为文件host.conf的属主增加执行权限。

    # chmod  g-w,o=x  host.conf

    功能:将文件host.conf的属组去掉写权限,同时将其他用户设置为只有执行权限,而文件属主的权限不变。

    2chmod示例二——数字方式

    chmod的数字使用方式,使用起来也是很方便的,关键是一个数制转换的问题。

    这种方式是先将每个权限位化成二进制数,其中如果某权限位是“-”则用0来表示,否则用1来表示;接着,将这9列权限分为三组(每三位一组),再将每组化成一个八进制数。

    例如,某文件有如下权限rwxrw-r--,则转换为二进制数为111110100,再化为八进制数则为764;反之,当看到八进制数764时也应该很快转化为相应权限。

    # chmod  764  host.conf

    功能:将文件host.conf的权限设置为:

    属主拥有全部权限;

    属组拥有读写权限;

    其他用户拥有只读权限。

     

    四、i节点及其相关命令

    1ln命令示例一——建立硬连接

    [root@yxy ~]# ln  myfile  myfile.hlink

    功能:为文件myfile创建名为myfile.hlink的硬连接。

    [root@yxy ~]# ls  -il

    180590 -rw-rw-r--  2  user1 user1   12 Aug 17 12:14 myfile

    180590 -rw-rw-r--  2  user1 user1   12 Aug 17 12:14 myfile.hlink

    说明:通过ls  il 命令可以看出myfile与myfile.hlink的i节点号(最左面的数)是一样的,即硬连接与原文件共用同一个i节点,请注意两个文件的连接数(位于长格式列表中权限位与属主之间的数)都增加了1变成2了。

    2ln命令示例二——建立符号连接

    [root@yxy ~]# ln  -s  myfile  myfile.slink

    功能:为文件myfile创建名为myfile.slink的符号连接。

    [root@yxy ~]# ls  -li

    180590 -rw-rw-r--    2  user1 user1   12 Aug 17 12:14 myfile

    180590 -rw-rw-r--    2  user1 user1   12 Aug 17 12:14 myfile.hlink

    180606 lrwxrwxrwx  1  user1 user1    6 Aug 21 06:21 myfile.slink -> myfile

    说明:硬链接若一个inode号对应多个文件名时,则称之为硬链接。硬链接具有以下几个特性:文件拥有相同的inode号和数据块;只能对已存在的文件创建硬链接;不能跨越文件系统创建硬链接;不能堆目录创建硬链接;删除一个硬链接文件不影响其他相同inode号的文件。软链接在Linux中,若文件的数据块中存放的内容是另一文件的路径名,则称之为软连接。软链接类似于Windows系统下的快捷方式。软连接有自己的inode号和用户数据块。为此,软链接避免了硬链接的诸多限制,软链接主要具有以下特点:软链接有自己的文件属性及权限等;可以对不存在的文件或目录创建软链接;软链接可以跨越文件系统创建;删除软链接时不会影响被指向的文件;若原文件被删除时,相关软链接文件被称为死链接(当该路路劲的文件重新创建时,死链接可以恢复正常)。

     

    五、 查找命令

    1. which命令

    [root@yxy ~]# which cp

    /bin/cp

    [root@yxy ~]# which updatedb

    /usr/bin/updatedb

    功能:显示命令的绝对路径。

    注意:该命令只能在命令搜索路径指定的目录中去查找命令或程序。

    2. whereis命令

    [root@yxy ~]# whereis ln

    ln: /bin/ln /usr/share/man/man1/ln.1.gz /usr/share/man/man1p/ln.1p.gz

    功能查询指定命令所在目录以及帮助文档所在目录。

    3. find命令

    1find示例一——按文件名查找

    # find  /  -name  "dhcpd*"

    功能:参数-name指明按文件名进行查找,即从/目录开始查找以dhcpd开头的所有文件。

    2find示例二——按文件大小查找

    [root@yxy ~]# find  /etc  -size  8

    功能:从/etc下开始查找大小为8块的文件,此处默认512字节为1块。若认为块大小为1k,则应写为8k。

       其它可以使用的单位有c(字节)、w(双字节)、M(兆字节)和G(吉字节)。

    3find示例三——按文件类型查找

    # find  /var  -type d  -print

    功能:从/var目录下开始查找类型为目录的文件,其中参数-print是显示到屏幕上的意思,经常省略。

    4find示例四——按文件的修改时间查找

    [root@yxy ~]# find  .  -cmin -5

    功能:从当前目录下查找5分钟之内修改过的文件。

       如果把“-5”改为 “+5”,则表示查找5分钟以前修改过的文件。不带“+”或“-”,则认为整5分钟。

      如果把时间单位改为天,则使用参数“-ctime”,请看示例:

    [root@yxy ~]# find  .  -ctime -5

    5find示例五——按文件的权限查找

    [root@yxy ~]#find  mytmp  -perm  755

    功能:查找mytmp目录下的权限恰为755的文件。

    [root@yxy ~]#find  mytmp  -perm  +755

    功能:查找mytmp目录下的满足755中任何一种权限的文件,即符合任何一个指定的权限位即可。

    [root@yxy ~]#find  mytmp  -perm  -755

    功能:查找mytmp目录下的权限至少满足755的文件,即指定的所有权限位必须符合才算满足查询条件。

     

    六、 文件内容操作命令

     

    1. grep命令

    1grep示例一——在指定的文件中查找包含特定的字符串的行

    [root@yxy ~]# grep  "bind"  host.conf

    功能:在文件host.conf中查找包含字符串“bind”行。

    [root@yxy ~]# grep  "network"  /etc/*.conf

    功能:利用通配符可在多个文件中查找包含特定的字符串的行。本例会在/etc下扩展名为.conf文件中查找包含字符串“network”的行。

    2grep示例二——查找不包含指定字符串的行

    # grep  -v  "network"  /etc/nsswitch.conf

    功能:查找/etc/nsswitch.conf文件中包含字符串“network”的行。

    2. wc命令

    1wc示例一——统计指定文件的行数、单词数和字符数

    [user1@server2 ~]# wc  /etc/nsswitch.conf

      63  272  1718  /etc/nsswitch.conf

    功能:统计出文件/etc/nsswitch.conf共有63行、272个单词、1718个字符。

    2wc示例二——参数使用

    # wc  -l  /etc/nsswitch.conf

    63  /etc/nsswitch.conf

    功能:参数-l的功能可统计出指定文件的行数。另外,利用参数-w统计单词,利用-c统计字符数。

    3. sort命令

    1sort示例一——按正序输出

    [root@yxy ~]# sort  mytest

    功能:将指定文件以行为单位按正序输出。

    2sort示例二——按逆序输出

    [root@yxy ~]# sort  -r  mytest

    功能:将指定文件以行为单位按逆序输出。

    4. diff 命令

    [root@yxy ~]# diff  test  mytest

    功能:比较文件test与mytest是否相同,将不同之处输出到屏幕上。

    5. cut 命令

       cut命令是一个文本提取工具,它以为单位,将每行看作一条记录,而字段之间的分隔符可以灵活地定义

    1cut示例一——按特定的分隔符提取指定的字段

    [user1@server2 ~]# cut  -d:  -f1  /etc/passwd

    功能:参数-d用来定义字段之间的分隔符,参数-f指定提取第几个字段;本例为提取/etc/passwd文件中以“:”为分隔符的第1个字段。

    七、 压缩与打包命令

     

    1. tar命令

     tar命令是经典的备份/还原命令,几乎所有最新的软件包都是通过tar发布的。

    1tar命令示例一——打包(备份)

    [user1@server2 ~]# tar  -cvf  myetc.tar  /etc

    功能:  参数-c的功能是打包(创建),

               参数-v是显示处理过程,

               参数-f是用来指定文档名;

    本例的功能是:将目录/etc打包为一个名为myetc.tar的文档。

    2tar命令示例二——打包(备份)并压缩

    # tar  -zcvf  myetc.tar.gz  /etc

    功能:将目录/etc打包并压缩为一个名为myetc.tar.gz的文档。

    说明:其中参数-z是调用gzip命令来压缩,扩展名为gz

    参数-Z是调用compress命令来压缩,扩展名为Z,

    参数-j是调用bzip2命令来压缩,扩展名为bz2

     

    八、网卡配置命令

    1ifconfig命令示例一——显示接口(网卡)配置参数

    [root@server2 ~]# ifconfig

    功能:显示网卡参数的配置情况,包括IP地址子网掩码、广播地址等。

    2ifconfig命令示例二——设置接口(网卡)配置参数

    # ifconfig  eth0  10.22.1.103  netmask  255.255.255.0

    功能:设置网卡eth0的IP地址为10.22.1.103、掩码为255.255.255.0

    说明:eth0是系统中1以太网卡的名称,eth1是系统中2以太网卡的名称,以此类推。lo是环回测试网卡的名称。

    3ifconfig命令示例三——禁用某块网卡

    [root@server2 ~]# ifconfig  eth0  down

    功能:禁用网卡eth0。

    说明:此时再用不带参数的ifconfig命令是不能显示eth0的信息的,需要加上参数-a才可显示被禁用的网卡信息。

    4ifconfig命令示例四——激活某块网卡

    [root@server2 ~]# ifconfig  eth0  up

    功能激活网卡eth0。

    九、rpm命令

    1rpm命令示例一——查询系统中安装的软件包

    [root@yxy ~]# rpm -qa

    功能:查询系统中安装的软件包列表,其中参数-q的功能是“查询”,参数-a的功能是“所有的”。

    2rpm命令示例二——查询软件包中文件清单

    [root@yxy ~]#rpm  -ql  php

    功能:查询已安装的软件包php中的文件列表,其中参数-l的功能是“列出指定软件包中的文件”。

    3rpm命令示例三——卸载指定的软件包

    [root@yxy ~]# rpm  -e  php

    功能:卸载已安装的软件包php,参数-e的功能是“卸载”。

    说明请注意执行上述命令时,采用的身份是不同的,普通用户只能执行查询操作。

    4rpm命令示例四——安装软件包

    # rpm  -ivh  php-4.3.9-3.1-i386.rpm

    功能:安装软件包php,

       参数-i的功能是“安装”,

       参数-v的功能是“显示处理过程”,

       参数-h的功能是显示“#”来表示进度。

    5rpm命令示例五——强制安装软件包

    # rpm  -ivh  --force  php-4.3.9-3.1-i386.rpm

    功能:强制安装软件包php,参数--force表示强制的意思。

    说明:如果要安装的软件的版本比较低或该软件包在系统中已存在,系统会给出提示并拒绝安装,此时可以加上参数—force来进行强制安装。

    6rpm命令示例五——忽略依赖关系安装软件包

    # rpm  -ivh  --nodeps  php-4.3.9-3.1-i386.rpm

    功能:安装软件包php时忽略与其它软件包的依赖关系,参数--nodeps表示忽略依赖关系

    说明:在安装或卸载软件时经常会遇到提示“该软件包与某某软件包存在依赖关系”,只有加上参数--nodeps忽略掉依赖关系才能进行安装或卸载。

    7)卸载


                 首先通过  rpm -q <关键字> 可以查询到rpm包的名字

    然后 调用 rpm -e <包的名字> 删除特定rpm包

    如果遇到依赖,无法删除,使用 rpm -e --nodeps <包的名字> 不检查依赖,直接删除rpm包

     

    十、 其他安装方式

    1. yum安装
             yum install 软件名字
             yum install yum-fastestmirror
             yum remove

    2. 源码安装

    ./configure
                make
                make install
                make clean
    make distclean

    十一、 查看进程命令

    1. ps命令

    1ps命令示例一——不带参数

    [user1@server2 ~]# ps

    功能:查询在当前控制台上运行的进程。

    2ps命令示例二——查看所有进程

    [user1@server2 ~]# ps  -aux

    功能:查询系统中所有运行的进程,包括后台进程,其中参数a是所有进程,参数x包括不占用控制台的进程,参数u显示用户。

    3ps命令示例三——查看所有进程

    [user1@server2 ~]# ps  -ef

    功能:查询系统中所有运行的进程,包括后台进程,而且可以显示出每个进程的父进程号。

    2. pstree命令

    1pstree命令示例一——树状格式显示进程列表

    [user1@server2 ~]# pstree

    功能:以树状格式显示系统的进程列表。

    2pstree命令示例二——带进程号的树状格式显示进程列表

    [user1@server2 ~]# pstree  -p

    功能:以树状格式显示系统的进程列表,并标识出每个进程的进程号。 

    3. top命令

    [user1@server2 ~]# top

    功能:动态地显示系统中的进程。

    4. kill命令

    1kill命令示例一——杀掉指定进程

    [user1@server2 ~]# kill  3029

    功能:kill命令可以杀掉一个进程,当然普通用户只能杀掉自己的进程。

    说明:上述命令中3029是进程号;一般在执行kill命令之前,先用pspstree来查询一下将要被杀掉的进程的进程号。

    2kill命令示例二——强制杀掉指定进程

    [user1@server2 ~]# kill  -9  3029

    功能:强制终止3029号进程的运行,其中参数-9代表强制的意思。

    说明:实际上kill命令是向该进程发送信号,该进程接到信号后决定是否停止运行,有些守护进程必须要收到参数9才终止运行。

     

    展开全文
  • 来自:JAVA小咖秀链接:https://juejin.im/post/5ee444ea6fb9a047ca10f796ls最高使用频率的命令之一。命令格式: ls [OPTION]....

    来自:JAVA小咖秀

    链接:https://juejin.im/post/5ee444ea6fb9a047ca10f796


    ls

    最高使用频率的命令之一。

    命令格式:  ls [OPTION]... [FILE]...单纯的输入:

    [root@iz2ze76ybn73dvwmdij06zz /]# ls
    bin   dev  home  lib64       media  opt    proc  run   srv  tmp  var
    boot  etc  lib   lost+found  mnt    patch  root  sbin  sys  usr  www
    
    
    加 option -l 它展示了权限,属主,属组,大小,时间,文件名称
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -l
    总用量 68
    lrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/bin
    dr-xr-xr-x.   5 root root  4096 8月  26 22:39 boot
    drwxr-xr-x   19 root root  2960 4月  11 12:59 dev
    drwxr-xr-x.  81 root root  4096 9月   5 17:09 etc
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 home
    lrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/lib
    lrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64
    drwx------.   2 root root 16384 10月 15 2017 lost+found
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 media
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 mnt
    drwxr-xr-x.   3 root root  4096 8月  26 22:40 opt
    drwxr-xr-x    2 root root  4096 8月  26 23:00 patch
    dr-xr-xr-x  110 root root     0 4月  11 12:59 proc
    dr-xr-x---.  12 root root  4096 9月  11 20:59 root
    drwxr-xr-x   26 root root   760 9月   7 21:50 run
    lrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbin
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 srv
    dr-xr-xr-x   13 root root     0 4月  11 12:59 sys
    drwxrwxrwt.   9 root root  4096 9月  15 03:19 tmp
    drwxr-xr-x.  13 root root  4096 8月  26 22:36 usr
    drwxr-xr-x.  19 root root  4096 8月  26 22:55 var
    drwxr-xr-x    6 root root  4096 8月  26 22:39 www
    
    
    ls -a (all)   linux  '.'(点)开头的文件默认是隐藏的,-a可以查询所有的文件。
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -a
    .             bin   etc   lib64       mnt    .pearrc  run   sys    usr
    ..            boot  home  lost+found  opt    proc     sbin  .test  var
    .autorelabel  dev   lib   media       patch  root     srv   tmp    www
    
    
    ls -F 以"/"结尾的方式展示文件夹。
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -F
    bin@   dev/  home/  lib64@       media/  opt/    proc/  run/   srv/  tmp/  var/
    boot/  etc/  lib@   lost+found/  mnt/    patch/  root/  sbin@  sys/  usr/  www/
    
    
    ls -r 倒叙展示,默认的顺序是(a,b,c,d)正序这样展示
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -r
    www  usr  sys  sbin  root  patch  mnt    lost+found  lib   etc  boot
    var  tmp  srv  run   proc  opt    media  lib64       home  dev  bin
    
    
    ls -R ()递归展示子目录
    [root@iz2ze76ybn73dvwmdij06zz test]# ls -R
    .:
    data
    
    ./data:
    img
    
    ./data/img:
    car  product  user
    
    ./data/img/car:
    
    ./data/img/product:
    
    ./data/img/user:
    
    
    ls -lS 按照文件大小降序显示
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -lS
    总用量 72
    drwx------.   2 root root 16384 10月 15 2017 lost+found
    dr-xr-xr-x.   5 root root  4096 8月  26 22:39 boot
    drwxr-xr-x.  81 root root  4096 9月   5 17:09 etc
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 home
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 media
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 mnt
    drwxr-xr-x.   3 root root  4096 8月  26 22:40 opt
    drwxr-xr-x    2 root root  4096 8月  26 23:00 patch
    dr-xr-x---.  12 root root  4096 9月  15 22:03 root
    drwxr-xr-x.   2 root root  4096 4月  11 12:59 srv
    drwxr-xr-x    3 root root  4096 9月  15 22:10 test
    drwxrwxrwt.   9 root root  4096 9月  15 03:19 tmp
    drwxr-xr-x.  13 root root  4096 8月  26 22:36 usr
    drwxr-xr-x.  19 root root  4096 8月  26 22:55 var
    drwxr-xr-x    6 root root  4096 8月  26 22:39 www
    drwxr-xr-x   19 root root  2960 4月  11 12:59 dev
    drwxr-xr-x   26 root root   760 9月   7 21:50 run
    lrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64
    lrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbin
    lrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/bin
    lrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/lib
    dr-xr-xr-x  110 root root     0 4月  11 12:59 proc
    dr-xr-xr-x   13 root root     0 4月  11 12:59 sys
    
    
    ls -g 不输出所有者(属主)信息
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -g
    总用量 72
    lrwxrwxrwx    1 root     7 8月  26 22:36 bin -> usr/bin
    dr-xr-xr-x.   5 root  4096 8月  26 22:39 boot
    -rw-r--r--    1 root     0 9月  15 22:20 c
    drwxr-xr-x   19 root  2960 4月  11 12:59 dev
    drwxr-xr-x.  81 root  4096 9月   5 17:09 etc
    drwxr-xr-x.   2 root  4096 4月  11 12:59 home
    lrwxrwxrwx    1 root     7 8月  26 22:36 lib -> usr/lib
    lrwxrwxrwx    1 root     9 8月  26 22:36 lib64 -> usr/lib64
    drwx------.   2 root 16384 10月 15 2017 lost+found
    drwxr-xr-x.   2 root  4096 4月  11 12:59 media
    drwxr-xr-x.   2 root  4096 4月  11 12:59 mnt
    drwxr-xr-x.   3 root  4096 8月  26 22:40 opt
    drwxr-xr-x    2 root  4096 8月  26 23:00 patch
    dr-xr-xr-x  110 root     0 4月  11 12:59 proc
    dr-xr-x---.  12 root  4096 9月  15 22:18 root
    drwxr-xr-x   26 root   760 9月   7 21:50 run
    lrwxrwxrwx    1 root     8 8月  26 22:36 sbin -> usr/sbin
    drwxr-xr-x.   2 root  4096 4月  11 12:59 srv
    dr-xr-xr-x   13 root     0 4月  11 12:59 sys
    drwxr-xr-x    3 root  4096 9月  15 22:18 test
    drwxrwxrwt.   9 root  4096 9月  15 03:19 tmp
    drwxr-xr-x.  13 root  4096 8月  26 22:36 usr
    drwxr-xr-x.  19 root  4096 8月  26 22:55 var
    drwxr-xr-x    6 root  4096 8月  26 22:39 www
    
    
    ls -lG 隐藏所有组(属组)信息
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -lG
    总用量 72
    lrwxrwxrwx    1 root     7 8月  26 22:36 bin -> usr/bin
    dr-xr-xr-x.   5 root  4096 8月  26 22:39 boot
    -rw-r--r--    1 root     0 9月  15 22:20 c
    drwxr-xr-x   19 root  2960 4月  11 12:59 dev
    drwxr-xr-x.  81 root  4096 9月   5 17:09 etc
    drwxr-xr-x.   2 root  4096 4月  11 12:59 home
    lrwxrwxrwx    1 root     7 8月  26 22:36 lib -> usr/lib
    lrwxrwxrwx    1 root     9 8月  26 22:36 lib64 -> usr/lib64
    drwx------.   2 root 16384 10月 15 2017 lost+found
    drwxr-xr-x.   2 root  4096 4月  11 12:59 media
    drwxr-xr-x.   2 root  4096 4月  11 12:59 mnt
    drwxr-xr-x.   3 root  4096 8月  26 22:40 opt
    drwxr-xr-x    2 root  4096 8月  26 23:00 patch
    dr-xr-xr-x  110 root     0 4月  11 12:59 proc
    dr-xr-x---.  12 root  4096 9月  15 22:18 root
    drwxr-xr-x   26 root   760 9月   7 21:50 run
    lrwxrwxrwx    1 root     8 8月  26 22:36 sbin -> usr/sbin
    drwxr-xr-x.   2 root  4096 4月  11 12:59 srv
    dr-xr-xr-x   13 root     0 4月  11 12:59 sys
    drwxr-xr-x    3 root  4096 9月  15 22:18 test
    drwxrwxrwt.   9 root  4096 9月  15 03:19 tmp
    drwxr-xr-x.  13 root  4096 8月  26 22:36 usr
    drwxr-xr-x.  19 root  4096 8月  26 22:55 var
    drwxr-xr-x    6 root  4096 8月  26 22:39 www
    10.ls -li 显示文件的索引号
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -li
    
    
    ls -li 显示文件的索引号
    [root@iz2ze76ybn73dvwmdij06zz /]# ls -li
    
    总用量 72
      7628 lrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/bin
    1179650 dr-xr-xr-x.   5 root root  4096 8月  26 22:39 boot
      4923 -rw-r--r--    1 root root     0 9月  15 22:20 c
      1026 drwxr-xr-x   19 root root  2960 4月  11 12:59 dev
    917505 drwxr-xr-x.  81 root root  4096 9月   5 17:09 etc
    655362 drwxr-xr-x.   2 root root  4096 4月  11 12:59 home
        17 lrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/lib
        13 lrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64
        11 drwx------.   2 root root 16384 10月 15 2017 lost+found
    786434 drwxr-xr-x.   2 root root  4096 4月  11 12:59 media
    131074 drwxr-xr-x.   2 root root  4096 4月  11 12:59 mnt
    393219 drwxr-xr-x.   3 root root  4096 8月  26 22:40 opt
    1966081 drwxr-xr-x    2 root root  4096 8月  26 23:00 patch
         1 dr-xr-xr-x  110 root root     0 4月  11 12:59 proc
    131073 dr-xr-x---.  12 root root  4096 9月  15 22:18 root
       218 drwxr-xr-x   26 root root   760 9月   7 21:50 run
        15 lrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbin
    393220 drwxr-xr-x.   2 root root  4096 4月  11 12:59 srv
         1 dr-xr-xr-x   13 root root     0 4月  11 12:59 sys
    2097153 drwxr-xr-x    3 root root  4096 9月  15 22:18 test
    393217 drwxrwxrwt.   9 root root  4096 9月  15 03:19 tmp
    1048578 drwxr-xr-x.  13 root root  4096 8月  26 22:36 usr
    262145 drwxr-xr-x.  19 root root  4096 8月  26 22:55 var
    1441793 drwxr-xr-x    6 root root  4096 8月  26 22:39 www
    
    
    ls -lt 按照修改时间排序(倒序)依次创建文件 a b
    [root@iz2ze76ybn73dvwmdij06zz test]# ls -lt
    总用量 0
    -rw-r--r-- 1 root root 0 9月  15 22:18 b
    -rw-r--r-- 1 root root 0 9月  15 22:18 a
    
    
    ls -version
    [root@iz2ze76ybn73dvwmdij06zz test]# ls --version
    ls (GNU coreutils) 8.22
    Copyright (C) 2013 Free Software Foundation, Inc.
    许可证:GPLv3+:GNU 通用公共许可证第3 版或更新版本<http://gnu.org/licenses/gpl.html>。
    本软件是自由软件:您可以自由修改和重新发布它。
    在法律范围内没有其他保证。
    
    由Richard M. Stallman 和David MacKenzie 编写。
    

    cat

    cat,又是一个相对高频率的命令。比较官方的说法是命令用于链接文件并打印到标准输出设备上。这个文本输出命令可以用来查看文件内容,创建内容等,下面我们介绍几个比较实用的用法。命令格式 : cat [选项]... [文件]...

    cat -n 查看并显示行号
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat -n a
        1  this is a txt
        2  hello every body
        3  hello world
        4  hahaha
    
    
    cat 创建一个空文件 b
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >b <<EOF
    > EOF
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# ls
    a  b
    
    
    cat 清空文件内容
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >a<<EOF
    > EOF
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a
    
    
    cat 写入内容(如果原来有内容将被覆盖)
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >a<<EOF
    > today is a good day
    > because off work
    > hahaha
    > EOF
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a
    today is a good day
    because off work
    hahaha
    
    
    cat 同时显示多个文件内容( b中写出happy)
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a > b
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat b
    today is a good day
    because off work
    hahaha
    
    
    追加内容 可以看到用了连个>以后内容是追加的
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a >> b
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat b
    today is a good day
    because off work
    hahaha
    today is a good day
    because off work
    hahaha
    
    
    cat --help (如想学习更多,可以自己动手尝试)
    [root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat --help
    用法:cat [选项]... [文件]...
    将[文件]或标准输入组合输出到标准输出。
    
     -A, --show-all           等于-vET
     -b, --number-nonblank    对非空输出行编号
     -e                       等于-vE
     -E, --show-ends          在每行结束处显示"$"
     -n, --number             对输出的所有行编号
     -s, --squeeze-blank      不输出多行空行
     -t                       与-vT 等价
     -T, --show-tabs          将跳格字符显示为^I
     -u                       (被忽略)
     -v, --show-nonprinting   使用^ 和M- 引用,除了LFD和 TAB 之外
         --help    显示此帮助信息并退出
         --version    显示版本信息并退出
    
    如果没有指定文件,或者文件为"-",则从标准输入读取。
    
    示例:
     cat f - g  先输出f 的内容,然后输出标准输入的内容,最后输出g 的内容。
     cat        将标准输入的内容复制到标准输出。
    
    GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
    请向<http://translationproject.org/team/zh_CN.html> 报告cat 的翻译错误
    要获取完整文档,请运行:info coreutils 'cat invocation'
    
    


    用户权限

    大家都知道linux是一个多任务,多用户的操作系统。多个用户可以在同一时间操作系统执行不同的任务,一个用户也可以多个人登陆操作。一般来说root的权限最大,我们经常使用的数据库一般会用一个mysql的用户,网页相关的我们可能用一个www的账号,大家都是知道删除跑路的故事,因此有一些操作权限是要交给一些专人管理的。为了系统的学习,我觉得有必要了解一下它的基本知识。

    linux角色分类

    超级用户:root (user id --UID) 0 最高的管理权限。

    普通用户:

    系统用户 UID:1-999(rhel7  centos7) 1-499(rhel6)
        
        本地用户 UID:1000+(rhel7 centos7)  500+(rhel6)
    
    

    UID:用户身份标示,唯一标示。

    linux组分类

    组:

    组分类:

    根据账号的功能分类:
    
               超级用户组:root GID:0
               普通用户组 :
                                   系统用户组: GID 1---999
                                    本地用户组: GID 1000+
    
    
    linux用户和组的关系

    一个用户属于一个组,也可以属于多个组,多个用户可以在一个组,可以在多个组。

    linux用户和组的相关配置文件

    1./etc/passwd:用户 and 属性信息。

    2./etc/group: 组 and 属性信息。

    3./etc/shadow: 用户密码 and 属性信息。

    4./etc/gshadow:组密码 and 属性信息。

    5./etc/default/useradd: 设置添加用户规则文件。

    6./etc/login.defs:设置用户账号限制。

    linux用户信息文件

    用户管理中最重要的一个文件,这个文件是对所有用户开放的,每一行存一个用户的信息,每个属性之间用冒号分割。

    cat /etc/passwd
    root:x:0:0:root:/root:/bin/zsh
    bin:x:1:1:bin:/bin:/sbin/nologin
    daemon:x:2:2:daemon:/sbin:/sbin/nologin
    adm:x:3:4:adm:/var/adm:/sbin/nologin
    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
    
    

    举例:root:x:0:0:root:/root:/bin/zsh

    1.登陆用户名:root

    2.用户密码占位符:x

    3.用户UID:0

    4.用户组GID:0

    5.对用户账户的描述:root

    6.用户家目录位置:/root

    7.用户默认的shell:/bin/zsh (默认是/bin/bash)

    linux密码信息文件

    该文件只有root用户有读权限,每一行存一个用户的记录,每个属性用冒号分割。

    cat /etc/shadow
    root:$6$LxE7qiaZ$ZZXf/aCO1Zqs1oOS9WDutUk9rFOq4MOoSG9IeXq2f5sduGrgfYvzOWHZmJZFGC.0Of1DjCna0M.oQZTY8r00/.:17769:0:99999:7:::
    bin:*:17110:0:99999:7:::
    daemon:*:17110:0:99999:7:::
    
    

    举例:bin:*:17110:0:99999:7:::1.登录用户名: bin

    2.加密的密码:  * 号代表密码被锁定

    3.最近更改密码的日期: 17110代表到1970-1-1密码不可改的天数

    4.密码修改期限:99999 代表永远不用改,如果是其他数字则表示从1970-1-1内的多少天必须修改密码。

    5.更改密码最大有效天数:  代表密码保持有效的最大天数。

    6.密码过期警告:密码到正式失效前有多少天(-1,永远不提示)

    7.密码过期后多少天禁用用户:可登陆,单不能操作。

    8.用户被禁用日期:多少天后账号过期,不能登陆。

    9.保留参数

    linux组信息文件

    用户组的组信息存放在这,一行存一个组记录,属性用冒号分割。

    ➜  ~ cat /etc/group
    root:x:0:
    bin:x:1:
    daemon:x:2:
    sys:x:3:
    adm:x:4:
    tty:x:5:
    disk:x:6:
    lp:x:7:
    mem:x:8:
    kmem:x:9:
    
    

    举例:root:x:0:

    1.组名:root

    2.组密码占位符: x

    3.组GID: 0


    安装包管理基础

    相信大部分人应该和我一样,最开始都是用 windows上手的,那在windows平台的安装包就再熟悉不过了,比如.exe,是不是太常见了,一般在windows安装过mysql的,相信.msi也是见过的。大多数的服务器都是linux的,因此我们来学习一下linux的安装包基础知识。不同发行版的系统用的工具也是不相同的。目前大多数的公司服务器是基于centos,因此后续会以centos为例比较多。

    基于redhat

    yum

    zypper

    rpm

    基于centos

    yum

    rpm

    rpm

    全称: Redhat Package Manager

    下载网址: http://rpmfind.net

    先来看下包的命名格式,以  rpm-5.4.10-10.i586.rpm 为例。

    rpm : 软件包名

    5 : 主版本号

    4 : 次版本号

    10 : 修订号

    i586 : cpu架构平台

    rpm : 包后缀

    yum

    解决软件包安装的依赖关系问题,自动下载软件包,基于c/s架构。repo文件是yum源的配置文件,改文件定义软件仓库的信息。为什么说它是c/s架构,原来rpm软件的头(header)里会记录改软件的依赖信息,因此可以对头内容进行分析,就可以知道其相关的依赖,并将这些信息记录下来。那么服务端是提供这些rpm的软件包,然后分析包的依赖关系,将记录存在服务器某目录上。客户端在安装软件时下载其记录依赖关系文件并分析,最后一次性下载。


    进程管理基础

    一般来说程序分为两类,一种是系统程序,一种是应用程序。一个运行了程序,就可以说是一个进程了,进程是占用内存空间的,而当你杀掉进城时,资源也会随之释放。

    进程的类型

    用户进程:用户自己的程序,用户可以控制他的开启和关闭。

    交互进程:   与用户进行交互操作的进程。

    批处理进程:是一个进程集合,按顺序启动其他进程。

    守护进程:一直运行的进程.crond。

    进程的属性

    进程ID : (pid) 唯一的数字标示,区分不同的进程。

    进程有父进程和子进程。

    启动进程的用户ID(uid)和用户的属组。

    进程的三种状态:

    • 运行 -- R

    • 休眠 -- S

    • 僵尸 -- Z

    进程的优先级: 取值范围(-20,19) ,数值越小优先级越大,默认为0。

    进程链接的终端。

    进程占用资源情况。

    父子进程的关系

    父子进程的关系,父亲管理儿子。父进程终止时子进程一定终止,而子进程终止时父进程不一定终止。

    进程管理工具
    ps:   查看进程。
        top:  可以查看进程的动态信息。
        kill:  杀进程。
        pstree:  查看进程树。
        pgrep:  搜进程。
        lsof:  查看进程打开的文件。
    
    


    进程管理实践

    ps

    静态的显示当前进程的信息 。

    命令:  ps

    语法:  ps 参数

    常用参数:

    a      显示所有用户的进程
                   r       显示运行中的进程
                   l        长格式输出
                   u        按用户名和启动时间的顺序来显示进程
                   f         用树形格式来显示进程
                   x        显示没有控制终端的进程
    
    

    操作:BSD格式来显示进程

    ➜  ~ ps aux
    USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/syst
    root         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]
    root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]
    root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0H
    root         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]
    root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]
    root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]
    root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]
    root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]
    root        12  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/1]
    root        13  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/1]
    root        15  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/1:0H
    
    

    标准格式显示进程unix风格

    ~ ps -ef
    UID        PID  PPID  C STIME TTY          TIME CMD
    root         1     0  0 11月03 ?      00:00:01 /usr/lib/systemd/systemd --syste
    root         2     0  0 11月03 ?      00:00:00 [kthreadd]
    root         3     2  0 11月03 ?      00:00:00 [ksoftirqd/0]
    root         5     2  0 11月03 ?      00:00:00 [kworker/0:0H]
    root         7     2  0 11月03 ?      00:00:00 [migration/0]
    root         8     2  0 11月03 ?      00:00:00 [rcu_bh]
    root         9     2  0 11月03 ?      00:00:05 [rcu_sched]
    root        10     2  0 11月03 ?      00:00:00 [watchdog/0]
    root        11     2  0 11月03 ?      00:00:00 [watchdog/1]
    root        12     2  0 11月03 ?      00:00:00 [migration/1]
    root        13     2  0 11月03 ?      00:00:00 [ksoftirqd/1]
    root        15     2  0 11月03 ?      00:00:00 [kworker/1:0H]
    root        17     2  0 11月03 ?      00:00:00 [kdevtmpfs]
    root        18     2  0 11月03 ?      00:00:00 [netns]
    root        19     2  0 11月03 ?      00:00:00 [khungtaskd]
    root        20     2  0 11月03 ?      00:00:00 [writeback]
    root        21     2  0 11月03 ?      00:00:00 [kintegrityd]
    
    
    属性详解:

    USER:    进程的属主

    PID:    进程的ID

    %CPU:   进程占cpu百分比

    %MEM:   进程占内存的百分比

    VSZ:    进程占用虚拟内存大小

    RSS:    固定内存使用数量

    STAT     进程状态

    R    正在运行可中在队列中可过行的;
    
     S    处于休眠状态;
       
       T    停止或被追踪;
       
       Z    僵尸进程;
       
       N    优先级较低的进程
       
       L    有些页被锁进内存;
       
       s    进程的领导者(在它之下有子进程)
    
    
    
    
    

    START   启动进程的时间;

    TIME  进程消耗CPU的时间;

    COMMAND 命令的名称和参数;

    按照指定属性排序:

    按照cpu从小到大排序。

    ➜  ~ ps aux --sort %cpu
    USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/syst
    root         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]
    root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]
    root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0H
    root         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]
    root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]
    root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]
    root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]
    root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]
    
    

    按照cpu从大到小排序。

    ➜  ~ ps aux --sort -%cpu
    USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root     21342  0.3  0.4 137184 17112 ?        Ssl  03:24   1:16 /usr/local/aegi
    root         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/syst
    root         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]
    root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]
    root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0H
    root         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]
    root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]
    root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]
    root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]
    root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]
    root        12  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/1]
    root        13  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/1]
    
    
    top

    与ps相反的是top命令可以查看进程的动态信息。

    命令:  top

    语法:   top 参数

    常用参数:

    操作:

    ➜  ~ top
    top - 11:38:42 up 13:15,  2 users,  load average: 0.01, 0.03, 0.05
    Tasks:  98 total,   1 running,  97 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.2 us,  0.0 sy,  0.0 ni, 99.8 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :  3881688 total,   229264 free,   543932 used,  3108492 buff/cache
    KiB Swap:  1049596 total,  1049596 free,        0 used.  3026944 avail Mem
    
     PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
       1 root      20   0   43364   3596   2340 S   0.0  0.1   0:01.79 systemd
       2 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kthreadd
       3 root      20   0       0      0      0 S   0.0  0.0   0:00.14 ksoftirqd/0
       5 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/0:+
       7 root      rt   0       0      0      0 S   0.0  0.0   0:00.33 migration/0
       8 root      20   0       0      0      0 S   0.0  0.0   0:00.00 rcu_bh
       9 root      20   0       0      0      0 S   0.0  0.0   0:05.73 rcu_sched
    
    
    属性解释:

    前五行是数据的整理统计信息。

    第一行:

    11:38:42     当前时间
         
          up 13:15     系统运行时间,格式为时:分
          
          2 user         当前登陆用户数量
          
          load average: 0.01, 0.03, 0.05  系统负载,任务队列平均长度 1分钟,5分钟,15分钟前到现在的平均值。
    
    

    第二三行:

    98 total  进程总数量
     1 running 正在运行的进程数量
     97 sleeping 睡眠的进程数量
     0 stopped  停止的进程数量
     0 zombie   僵尸进程数量
     %Cpu(s):
     0.2 us 系统用户进程使用cpu百分比
     0.0 sy 内核进程占用cpu百分比
     0.0 ni 用户进程空间内改变过优先级的进程占用cpu百分比
         99.8 id 空闲cpu百分比
           0.0 wa 等待输入输出的cpu时间百分比
           0.0 hi   硬件cpu中断占用百分比
           0.0  si   软中断占用百分比
           0.0  st  虚拟机占用百分比
    
    

    第四五行:

    Mem :  (单位K)

    3881688 total  物理内存总量
    229264 free    空闲内存总量
    543932 used    使用的物理内存总量
    3108492 buff/cache 内核缓存的内存量
    
    

    Swap: (单位K)

    1049596 total      交换区总量
     1049596 free       空闲交换区总量
     0 used             使用的交换区总量
     3026944 avail Mem  可利用的内存量
    
    

    标题行:

    PID:  进程id

    USER: 进程所有者用户名

    PR:   优先级

    NI:   进程优先级,nice值,负值 -> 高优先级,正值 -> 低优先级

    VIRT: 虚拟内存总量 virt=swap + res

    RES:  实际使用内存大小

    SHR:  共享内存大小

    S:    进程状态

    d: 不可中断的睡眠状态
       r: 运行
       s: 睡眠
       t: 跟踪
       z: 僵尸进程
    
    

    %CPU: 上次更新到现在cpu时间占用百分比

    %MEM: 进程使用物理内存百分比

    TIME+: 进程使用cpu的时间总计,单位 1/100秒

    COMMAND: 命令行

    kill

    命令: kill

    语法:

    kill [-s signal|-p] [-q sigval] [-a] [--] pid...
          kill -l [signal]
    
    

    常用参数:

    -l 列出所有信号名称
         -s 指定发送信号(默认)
         -u 指定用户
    
    

    操作:列出所有信号名称

    ➜  ~ kill -l
    HUP INT QUIT ILL TRAP ABRT BUS FPE KILL USR1 SEGV USR2 PIPE ALRM TERM STKFLT CHLD CONT STOP TSTP TTIN TTOU URG XCPU XFSZ VTALRM PROF WINCH POLL PWR SYS
    
    

    强制终止

    ➜  ~ kill -9 23423
    
    
    终止
    ➜  ~ kill -15 22323
    
    

    杀死指定用户的所有进程

    ➜  ~ kill -u superh
    
    
    proc目录

    这个目录中有内核,进程运行状态的信息。

    ➜  /proc ls
    1      21320  21628  240   392   7          diskstats    loadavg       swaps
    10     21342  21976  242   42    722        dma          locks         sys
    10353  21465  21977  243   44    7561       driver       mdstat        sysrq-trigger
    10509  21613  21978  244   442   8          execdomains  meminfo       sysvipc
    107    21614  22     249   45    803        fb           misc          timer_list
    11     21615  220    26    46    8179       filesystems  modules       timer_stats
    11010  21616  22285  261   466   8307       fs           mounts        tty
    11102  21617  22287  262   467   8327       interrupts   mtrr          uptime
    12     21618  22361  267   469   9          iomem        net           version
    13     21619  22363  268   476   acpi       ioports      pagetypeinfo  vmallocinfo
    14461  21620  22396  3     477   buddyinfo  irq          partitions    vmstat
    15     21621  22467  31    485   bus        kallsyms     sched_debug   zoneinfo
    17     21622  225    3198  5     cgroups    kcore        schedstat
    18     21623  229    32    505   cmdline    keys         scsi
    19     21624  23     33    506   consoles   key-users    self
    2      21625  23884  336   5217  cpuinfo    kmsg         slabinfo
    20     21626  23885  34    5515  crypto     kpagecount   softirqs
    21     21627  24     357   65    devices    kpageflags   stat
    
    

    上面的每个标号即是用我们当前进程的pid所命名的目录名。

    free

    查看系统使用和空闲的内存情况。

    命令:  free

    语法:  free 参数

    常用参数:

    -b, --bytes        byte为单位展示
     -k, --kilo            k为单位展示
     -m, --mega       m为单位展示
     -g, --giga           g为单位展示
    
    

    操作:

    ➜  ~ free -m
                 total        used        free      shared  buff/cache   available
    Mem:           3790         536         210           2        3043        2950
    Swap:          1024           0        1024
    
    

    单位为g显示。

    ➜  ~ free -h
                total        used        free      shared  buff/cache   available
    Mem:           3.7G        538M        207M        2.4M        3.0G        2.9G
    Swap:          1.0G          0B        1.0G
    
    

    文件查找

    在做运维相关的事情时,我们少不了要查这样那样的文件,一般来说我们可能会查比如带xxx.conf名字的文件在哪呢,查日志啊,某个可执行文件的位置啊。

    概览
    which : 查看执行文件的位置。
    
    whereis : 查看可执行文件位置和相关文件。
    
    locate : 配合数据库缓存,快速查看文件的位置。
    
    grep : 过滤匹配,他是一个文件搜索工具。
    
    find  :  可以根据条件查看文件。
    
    
    which

    命令:which

    语法:    which 参数  查询目标

    常用命令:一般不加参数使用

    --all, -a      显示所有的匹配路径
    
    

    操作:

    ➜  ~ which pwd
    /usr/bin/pwd
    
    


    whereis

    命令:   whereis

    语法:   whereis 参数 查询目标

    常用命令:

    一般不加参数使用
             -b         只搜索二进制文件
             -B <目录>  定义二进制文件查找路径
             -m         只搜索 man 手册
             -M <目录>  定义 man 手册查找路径
             -s         只搜索源代码
             -S <目录>  定义源代码查找路径
    
    

    操作:

    ➜  ~ whereis ls
    ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz
    
    
    locate

    命令:   locate

    语法:   locate  文件名

    常用参数:无

    操作:locate和find命令功能差不多,但是搜索效率更高,因为locate查的是数据库而find查找的是目录文件。

    数据库:

    ➜  ~ ls /var/lib/mlocate/mlocate.db
    /var/lib/mlocate/mlocate.db
    
    

    相关配置文件:

    ➜  ~ ls /etc/updatedb.conf
    /etc/updatedb.conf
    
    

    相关定时任务:

    ➜  ~ ls /etc/cron.daily/mlocate
    /etc/cron.daily/mlocate
    
    

    举例:

    ➜  ~ touch shafa
    ➜  ~ locate shafa
    ➜  ~ updatedb
    ➜  ~ locate shafa
    /root/shafa
    
    

    注:如果我们当天新建的文件查找,需要手动updatedb。

    grep

    命令:grep

    语法:grep 参数  目标值  文件

    常用参数:

    -v       取反
                -i        忽略大小写
                -n        输出的同时打印行号
                ^*        以*开头
                *$         以*结尾
                ^$         空行
    
    

    操作:

    查 /etc/passwd有root的行

    ➜  ~ grep root /etc/passwd
    root:x:0:0:root:/root:/bin/zsh
    operator:x:11:0:operator:/root:/sbin/nologin
    
    

    查 /etc/passwd 没有root的行(内容较多,禁展示几行)

    ➜  ~ grep -v root /etc/passwd
    bin:x:1:1:bin:/bin:/sbin/nologin
    daemon:x:2:2:daemon:/sbin:/sbin/nologin
    adm:x:3:4:adm:/var/adm:/sbin/nologin
    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
    sync:x:5:0:sync:/sbin:/bin/sync
    
    

    查 /etc/passwd 有www的行并显示行号

    ➜  ~ grep -n www /etc/passwd
    23:www:x:1000:1000::/home/www:/sbin/nologin
    
    
    find

    命令:find

    语法:find 路径  参数 输出

    常用参数:

    路径: 例如用 . 来表示当前目录,用 / 来表示系统根目录。
               -print:显示的时候”\n”做为定界符, 换行
              -print0:与xargs配套使用,以“\0”做为定界符
    
    

    find常用命令选项:

    -name   按照文件名查找文件。“名称”
    -perm   按照文件权限来查找文件。666 777 等
    -depth  在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找
    -user   按照文件属主来查找文件
     -atime  -ctime (单位是天)
     -mmin -cmin  -amin(单位是分钟)
     -size n [c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计
     -follow  如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
    
    

    操作:

    查看当前目录下test.开头的文件

    ➜  ~ find . -name "test*"
    ./test.txt
    ./autojump/tests
    ./test.1
    
    

    查看当前目录下test.开头的文件,输出结果换行显示(默认)

    ➜  ~ find . -name "test*" -print
    ./test.txt
    ./autojump/tests
    ./test.1
    
    

    查看当前目录下test.开头的文件,输出结果不换行显示

    ➜  ~ find . -name "test*" -print0
    ./test.txt./autojump/tests./test.1
    
    

    对查找的内容执行相应命令

    默认执行动作 : -print

    常用动作:

    -exec  这个参数后可以跟自定义shell命令
    
    

    操作:

    查询.txt结尾的文件并用ls查询其更多属性

    ➜  test find . -name "*.txt" -exec ls -l {} \;
    -rw-r--r-- 1 root root 0 11月  4 14:56 ./xq1.txt
    -rw-r--r-- 1 root root 0 11月  4 14:56 ./xq.txt
    -rw-r--r-- 1 root root 0 11月  4 14:56 ./xq2.txt
    
    

    查询.txt结尾的文件并变成.bak结尾的文件

    ➜  test find . -name "*.txt" -exec mv {} {}.bak \;
    ➜  test ls
    xq1.txt.bak  xq2.txt.bak  xq.txt.bak
    
    

    逻辑查询:

    -a  并且
            -o  或者
             +  高于
             -   低于
    
    

    操作:查看 .sh或者.q结尾的文件。

    ➜  test find . -name "*.sh" -o -name "*.q"
    ./book.q
    ./stop.sh
    ./start.sh
    
    

    查看.sh结尾并且s开头的文件。

    ➜  test find . -name "*.sh" -a -name "s*"
    ./stop.sh
    ./start.sh
    
    

    在文件中插入内容后查看。

    ➜  test ll
    总用量 12K
    -rw-r--r-- 1 root root  9 11月  4 15:10 book.q
    -rw-r--r-- 1 root root 13 11月  4 15:10 start.sh
    -rw-r--r-- 1 root root  4 11月  4 15:10 stop.sh
    -rw-r--r-- 1 root root  0 11月  4 14:56 xq1.txt.bak
    -rw-r--r-- 1 root root  0 11月  4 14:56 xq2.txt.bak
    -rw-r--r-- 1 root root  0 11月  4 14:56 xq.txt.bak
    
    

    查看/etc 大于40k小于50k的文件

    ➜  test find /etc/ -size +40k -a -size  -50k
    /etc/selinux/targeted/active/modules/100/sysadm/hll
    /etc/selinux/targeted/contexts/files/file_contexts.homedirs.bin
    
    


    计划任务

    说到计划,联想到的是时间,说到任务,联想到的就是做什么。连起来就是什么时间做什么。每天几点上班几点下班。每年的国庆,元旦都在固定的时间节点发生。类似这些,我们可以称之为定时任务。

    再比如,有的时候。快下班了,领导来个紧急任务,小王啊,加个班。明天心情好,请个假去面试。这种的属于临时任务。

    那么在linux中我们怎么来做这两件事呢。

    任务类型

    定时:   按照一定的周期重复持续的做某个事。

    临时:   执行一次以后任务就结束了,只一次。

    任务类型对应的命令

    crontab( 定时任务): 按照你 你规定的周期 循环窒息感。

    at (临时任务): 执行一次就结束的任务。

    at的使用

    命令:at

    语法:    at 时间

    常用参数:

    -l    查看任务列表
             -c   查看任务详情
    
    

    操作:查看服务是否开启

    [root@iz2ze0ajic0vbv28hcdctpz ~]# systemctl status atd
    ● atd.service - Job spooling tools
      Loaded: loaded (/usr/lib/systemd/system/atd.service; enabled; vendor preset: enabled)
      Active: active (running) since 二 2018-11-13 11:50:47 CST; 1 day 9h ago
    Main PID: 491 (atd)
      CGroup: /system.slice/atd.service
              └─491 /usr/sbin/atd -f
    
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Started Job spooling tools.
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Starting Job spooling tools...
    
    

    几种设定任务的方法:创建一个任务(默认是今天,如果时间大于当前时间会创建在下一天 )

    [root@iz2ze0ajic0vbv28hcdctpz ~]# ls
    soft
    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 21:17
    at> mkdir sk
    at> <EOT>
    job 6 at Wed Nov 14 21:17:00 2018
    
    

    指定时间创建:

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 20:00 2018-11-19
    at> mkdir happy
    at> <EOT>
    job 7 at Mon Nov 19 20:00:00 2018
    
    

    从现在开始加时间:

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at now + 3min
    at> mkdir hello
    at> <EOT>
    job 8 at Wed Nov 14 21:41:00 2018
    
    

    明天11:11 执行

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 11:11 tomorrow
    at> mkdir world
    at> <EOT>
    job 9 at Thu Nov 15 11:11:00 2018
    
    

    2天后的下午3.24执行

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 3:24 pm +2 days
    at> mkdir new
    at> <EOT>
    job 11 at Fri Nov 16 15:24:00 2018
    
    

    查看任务列表(显示还未执行的任务 )

    [root@iz2ze0ajic0vbv28hcdctpz ~]# atq
    5  Thu Nov 15 21:11:00 2018 a root
    
    

    查看一个单个的任务信息:(由于内容较多去掉部分信息)

    [root@iz2ze0ajic0vbv28hcdctpz /]# at -c 7
    #!/bin/sh
    # atrun uid=0 gid=0
    # mail root 0
    umask 22
    XDG_SESSION_ID=243; export XDG_SESSION_ID
    HOSTNAME=iz2ze0ajic0vbv28hcdctpz; export HOSTNAME
    SHELL=/bin/bash; export SHELL
    HISTSIZE=1000; export HISTSIZE
    SSH_CLIENT=113.46.167.195\ 17211\ 22; export SSH_CLIENT
    SSH_TTY=/dev/pts/0; export SSH_TTY
    USER=root; export USER
    MAVEN_HOME=/usr/local/apache-maven-3.6.0; export MAVEN_HOME
    MAIL=/var/spool/mail/root; export MAIL
    PATH=/usr/local/apache-maven-3.6.0/bin:/usr/local/jdk1.8.0_191/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin; export PATH
    PWD=/root; export PWD
    JAVA_HOME=/usr/local/jdk1.8.0_191; export JAVA_HOME
    LANG=zh_CN.UTF-8; export LANG
    HISTCONTROL=ignoredups; export HISTCONTROL
    SHLVL=1; export SHLVL
    HOME=/root; export HOME
    LOGNAME=root; export LOGNAME
    CLASSPATH=.:/lib/dt.jar:/lib/tools.jar; export CLASSPATH
    SSH_CONNECTION=113.46.167.195\ 17211\ 172.17.187.244\ 22; export SSH_CONNECTION
    LC_CTYPE=zh_CN.UTF-8; export LC_CTYPE
    LESSOPEN=\|\|/usr/bin/lesspipe.sh\ %s; export LESSOPEN
    XDG_RUNTIME_DIR=/run/user/0; export XDG_RUNTIME_DIR
    cd /root || {
      echo 'Execution directory inaccessible' >&2
      exit 1
    }
    ${SHELL:-/bin/sh} << 'marcinDELIMITER550b4fbb'
    mkdir happy
    
    marcinDELIMITER550b4fbb
    
    

    参数解释:

    5 : 任务编号

    Thu Nov 15 21:11:00 2018 : 时间

    a : 队列

    root : 执行用户

    删除任务:

    先来查看一下有哪些任务

    [root@iz2ze0ajic0vbv28hcdctpz /]# atq
    7  Mon Nov 19 20:00:00 2018 a root
    5  Thu Nov 15 21:11:00 2018 a root
    11  Fri Nov 16 15:24:00 2018 a root
    9  Thu Nov 15 11:11:00 2018 a root
    12  Wed Nov 14 22:11:00 2018 a root
    
    

    删除任务编号为12的任务

    [root@iz2ze0ajic0vbv28hcdctpz /]# atrm 12
    [root@iz2ze0ajic0vbv28hcdctpz /]# atq
    7  Mon Nov 19 20:00:00 2018 a root
    5  Thu Nov 15 21:11:00 2018 a root
    11  Fri Nov 16 15:24:00 2018 a root
    9  Thu Nov 15 11:11:00 2018 a root
    
    

    定时任务处理

    cron是linux的一个定时任务执行工具,而crondtab是周期性执行命令,crond则是定时任务的守护进程。

    服务启动
    查看服务是否启动
    
    
    [root@iz2ze0ajic0vbv28hcdctpz ~]# systemctl status crond
    ● crond.service - Command Scheduler
      Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)
      Active: active (running) since 二 2018-11-13 11:50:47 CST; 1 day 10h ago
    Main PID: 489 (crond)
      CGroup: /system.slice/crond.service
              └─489 /usr/sbin/crond -n
    
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Started Command Scheduler.
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Starting Command Scheduler...
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz crond[489]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 7...ed.)
    11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz crond[489]: (CRON) INFO (running with inotify support)
    Hint: Some lines were ellipsized, use -l to show in full.
    
    
    如果没有启动,执行
    systemctl start crond
    systemctl enable crond
    
    
    crontab命令

    语法 :  crontab  参数

    常用参数  :

    crontab -u   #指定用户的cron信息
            crontab -l   #列出当前用户下的cron服务的信息
            crontab -u user -l   #列出指定用户的cron服务的信息
            crontab -r   #删除cron服务
            crontab -e   #编辑cron服务
            crontab -r -u user   #删除指定用户的定时任务
    
    

    操作:

    编辑cron服务

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -e
    crontab: installing new crontab
    
    

    查看当前用户下任务内容

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -l
    22 22 22 * * mkdir /linux/test
    
    

    删除任务

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -r
    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -l
    no crontab for root
    
    

    查看qa这个用户下的任务内容

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -l
    22 22 22 * * mkdir /linux/test
    
    

    删除qa这个用户下的定时任务

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -r
    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -l
    no crontab for qa
    
    
    系统任务

    系统的任务调度配置文件在/etc/crontab下

    [root@iz2ze0ajic0vbv28hcdctpz ~]# ll /etc/crontab
    -rw-r--r-- 1 root root 451 Nov 15 07:49 /etc/crontab
    
    

    可以直接在/etc/crontab下添加系统任务(不建议)

    [root@iz2ze0ajic0vbv28hcdctpz ~]# cat /etc/crontab
    SHELL=/bin/bash
    PATH=/sbin:/bin:/usr/sbin:/usr/bin
    MAILTO=root
    
    # For details see man 4 crontabs
    
    # Example of job definition:
    # .---------------- minute (0 - 59)
    # |  .------------- hour (0 - 23)
    # |  |  .---------- day of month (1 - 31)
    # |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
    # |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
    # |  |  |  |  |
    # *  *  *  *  * user-name  command to be executed
    
    

    定时任务相关的目录

    [root@iz2ze0ajic0vbv28hcdctpz etc]# ll cr
    cron.d/       cron.deny     cron.monthly/ cron.weekly/
    cron.daily/   cron.hourly/  crontab       crypttab
    
    

    目录作用解释:

    cron.d/       是系统自动定期需要做的任务(不是按照时,分,秒等时间周期执行的)
    cron.deny   在该文件内的用户无法做计划任务
    其他文件为不同周期的执行脚本。
    
    
    定时任务规则

    首先来看下任务的格式(如图):

    时间的一些特殊符号:

    下面我们来举一些例子:

    #每晚的20:30重加载nginx
    30 20 * * * /usr/local/nginx/sbin/nginx -s reload
    
    #每月1、10、15日的5:30重加载nginx
    30 5 1,10,15 * * /usr/local/nginx/sbin/nginx  -s reload
    
    #每天20: 00至22 : 00之间每隔30分钟重加载nginx
    0,30 20-22 * * * /usr/local/nginx/sbin/nginx -s reload
    
    每星期六的10 : 00 pm 重加载nginx
    0 22* * 6 /usr/local/nginx/sbin/nginx  -s reload
    
    #每一小时重加载一次nginx
    0 */1 * * * /usr/local/nginx/sbin/nginx -s reload
    
    

    expect

    很多时候我们和linux的操作交互需要人工干预,有时候我们可能需要一种工具可以不需要人工干预的和linux交互,这里引入了一个工具expect,本小结我们主要来讲如何使用expect。

    expect介绍

    TCL(tool command language)是一种类似shell脚本的语言,你可以使用他来完成许多操作,expect是在它的基础上发展而来的,expect还提供了一些tcl没有的命令。如果你要写一个自动处理输入输出的脚本,我建议选择expect。

    expect安装

    yum install -y expect

    expect使用
    
    1.定义脚本执行使用的shell。
    
         #!/usr/bin/expect
    
    
    2.设置超时时间,单位为秒,timeout -1 为永不超时。
    
            set timeout 2
    
    3.壳子
    
           spawn需要在expect环境下运行,用来传递交互指令。
    
     4.expect命令
    
           判断输出结果是否包含某字符串,没有立即返回,否则就等一段时间后返回,用timeout设置等待时间。
    
    5.send
    
            执行交互动作,将交互要执行的动作进行输入给交互指令。命令字符串结尾要加上"\r",如果出现异常等待的状态可以进行核查。
    
    6.exp_continue
    
             继续执行接下来的交互操作。
    
    7.interact
    
            执行后保持交互状态,把控制权交给控制台,如不加interact,交互完成会自动退出。
    
    
    免密码通过ssh登陆服务器

    操作脚本

    ➜  batch cat sf
    #!/usr/bin/expect -f
    spawn ssh  root@ip
    expect {
    "yes/no" { send "yes\r";exp_continue}
    "*password:" { send "passwordstr\r" }
    }
    interact
    
    

    执行查看结果,登陆成功

    ➜  batch ./35
    spawn ssh root@ip
    root@ip's password:
    Last login: Sat Jan  5 10:15:56 2019 from 113.46.187.213
    
    Welcome to Alibaba Cloud Elastic Compute Service !
    
    

    这些只是Linux的冰上一角,小编还在路上,持续更新。。。⛽️

    -END-猜你喜欢STM32好找工作,所以学linux错了吗?
    Linux 自学大全,16张思维导图!
    盘点多款国产Linux桌面操作系统
     最 后 若觉得文章不错,转发分享,也是我们继续更新的动力。5T资源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、单片机、等等!在公众号内回复「更多资源」,即可免费获取,期待你的关注~长按识别图中二维码关注
    
    展开全文
  • Linux其实是前后端都必会的技能,前端目前很多童鞋都再走大前端路线,后端就更不用说了,小编给大家盘了Linux的实战基础命令,可以说这些都是必须掌握的,当然这些也是不够的,后面小编还会保持持续更新…⛽️ ...
  • 今天这篇文章中简单介绍一下一个 Java 程序员必知的 Linux 的一些概念以及常见命令。 如果文章有任何需要改善和完善的地方,欢迎在评论区指出,共同进步!笔芯! 1. 从认识操作系统开始 正式开始 Linux 之前,简单...
  • Linux其实是前后端都必会的技能,前端目前很多童鞋都再走大前端路线,后端就更不用说了,给大家盘了上万字(由于字数限制本文已删减)关于Linux的实战基础命令,可以说这些都是必须掌握的,...
  • 最高使用频率的命令之一。 命令格式: ls [OPTION]… [FILE]… 单纯的输入: [root@iz2ze76ybn73dvwmdij06zz /]# ls bin dev home lib64 media opt proc run srv tmp var boot etc lib lost+found mnt patch root sbin...
  • Linux常用命令

    万次阅读 多人点赞 2019-05-29 11:27:39
    Linux常用命令 1.查看目录结构命令 ls(list)功能:列出目录内容 格式:ls[参数][文件或目录] -a或--all 所有文件和目录。注意隐藏文件、特殊目录、以“.”开头的和以“..”开头的 -l 使用详细格式列表 -t 用...
  • 【Linux】linux常用基本命令

    万次阅读 多人点赞 2017-09-29 16:00:45
    Linux中许多常用命令是必须掌握的,这里将我学linux入门时学的一些常用的基本命令分享给大家一下,希望可以帮助你们。
  • linux 常用命令 自学篇(一)

    千次阅读 2020-02-11 17:31:13
    我昨天发布了关于 技能树的问题,那个还只是基础的,我接下将发布linux常用命令,作为昨天测试工程师,必定会使用kali 而linux命令也很重要。 如果你不会,不懂命令。你使用kali的时候,也只能看着别人,漏洞复现也...
  • Linux常用命令大全

    万次阅读 多人点赞 2018-07-05 11:06:09
    Linux常用命令大全1.Linux管理文件和目录的命令命令 功能 命令 功能 pwd 显示当前目录 ls 查看目录下的内容 cd 改变所在目录 cat 显示文件的内容 grep 在文件中查找某字符 cp 复制文件 touch 创建文件 mv 移动文件 ...
  • Linux常用命令(面试题)

    万次阅读 多人点赞 2020-05-23 16:09:33
    Linux常用命令 因为热爱,所以拼搏。 –RuiDer 常用指令 ls 显示文件或目录 -l 列出文件详细信息l(list) -a 列出当前目录下所有文件及目录,包括隐藏的a(all) mkdir 创建目录 -p 创建目录,若...
  • linux系列之常用运维命令整理笔录

    万次阅读 多人点赞 2020-10-10 14:21:26
    本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些...
  • 这绝对是整理的最全面最详细最认真最适合用来当笔记的Linux终端命令汇总的文章了
  • linux常用命令大全,linux常见命令(指令)介绍

    万次阅读 多人点赞 2017-09-28 18:07:22
    linux常用命令大全,linux常见命令介绍
  • Python全栈 Linux基础之3.Linux常用命令

    万次阅读 多人点赞 2020-01-23 21:20:47
    Linux对文件(包括目录)有很多常用命令,可以加快开发效率:ls是列出当前目录下的文件列表,选项有-a、-l、-h,还可以使用通配符;c功能是跳转目录,可以使用相对路径和绝对路径;mkdir命令创建一个新的目录,有-p...
  • Linux常用命令全集

    千次阅读 2019-07-01 16:47:27
    Linux常用命令 ...
  • Linux常用命令汇总及示例

    千次阅读 多人点赞 2020-04-06 15:29:57
    一、认识Linux系统及基础命令 1 构成 2 重要的二级目录 3 基础命令 二、文件管理命令Linux中没有后缀之分 1 增:mkdir touch 2 删、清空 3 改:vim 3.1 命令模式:刚刚打开时进入命令模式 3.2 插入...
1 2 3 4 5 ... 20
收藏数 480,986
精华内容 192,394
关键字:

linux常用命令