linux的常用命令以及常用工具

作者: 慕久久 | 来源:发表于2018-02-01 18:57 被阅读108次

    linux的常用命令以及常用工具

    大数据的学习难免要做集群,集群难免用到linux,所以总结常用的linux命令,以备后期使用。

    1. ls

      基本命令,list的缩写,展示所有目录,常用参数

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

      切换当前目录,可以是绝对路径也可以是相对路径:

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

      该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的常用参数为:

      -a :将binary文件以text文件的方式查找数据  
      -c :计算找到‘查找字符串’的次数  
      -i :忽略大小写的区别,即把大小写视为相同  
      -v :反向选择,即显示出没有‘查找字符串’内容的那一行  
      # 把ls -l的输出中包含字母file(不区分大小写)的内容输出  
      ls -l | grep -i file  
      
    4. find

      用于查找,相对比较复杂参数较多,参数与语法如下:

      find [PATH] [option] [action]  
        
      # 与时间相关的参数:  
      -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;  
      -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;  
      -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;  
      -newer file : 列出比file还要新的文件名  
      # 例如:  
      find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件  
        
      # 与用户或用户组名有关的参数:  
      -user name : 列出文件所有者为name的文件  
      -group name : 列出文件所属用户组为name的文件  
      -uid n : 列出文件所有者为用户ID为n的文件  
      -gid n : 列出文件所属用户组为用户组ID为n的文件  
      # 例如:  
      find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件  
        
      # 与文件权限及名称有关的参数:  
      -name filename :找出文件名为filename的文件  
      -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件  
      -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、  
                   目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);  
      -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;  
      -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示  
      -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示  
      # 例如:  
      find / -name passwd # 查找文件名为passwd的文件  
      find . -perm 0755 # 查找当前目录中文件权限的0755的文件  
      find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte  
      
    5. cp

      用于复制文件(只能复制文件),copy缩写,当然可以一次复制多个文件,参数如下:

      -a :将文件的特性一起复制  
      -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  
      -i :若目标文件已经存在时,在覆盖时会先询问操作的进行  
      -r :递归持续复制,用于目录的复制行为  
      -u :目标文件与源文件有差异时才会复制 
      
      # cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  
      # cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  
      
    6. mv

      用于移动文件、目录或更名,move缩写,参数以及语法如下:

      -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  
      -i :若目标文件已经存在,就会询问是否覆盖  
      -u :若目标文件已经存在,且比目标文件新,才会更新  
      
      # 注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。
      # mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  
      # mv file1 file2 # 把文件file1重命名为file2  
      
    7. rm

      用于删除文件或者文件夹,remove缩写(慎用 一定要确定删除的东西,不然系统都可能被你删除掉 )参数以及语法如下:

      -f :就是force的意思,忽略不存在的文件,不会出现警告消息  
      -i :互动模式,在删除前会询问用户是否操作  
      -r :递归删除,最常用于目录删除,它是一个非常危险的参数  
      
      # rm -i file # 删除文件file,在删除之前会询问是否进行该操作  
      # rm -fr dir # 强制删除目录dir中的所有文件  
      
    8. ps

      用于将某个时间点的进程运行情况选取下来并输出,process的缩写,它的常用参数以及语法:

      -A :所有的进程均显示出来  
      -a :不与terminal有关的所有进程  
      -u :有效用户的相关进程  
      -x :一般与a参数一起使用,可列出较完整的信息  
      -l :较长,较详细地将PID的信息列出  
      
      # ps aux # 查看系统所有的进程数据  
      # ps ax # 查看不与terminal有关的所有进程  
      # ps -lA # 查看系统所有的进程数据  
      # ps axjf # 查看连同一部分进程树状态  
      
    9. kill

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

      # kill -signal PID  
      signal:
       1:SIGHUP,启动被终止的进程  
       2:SIGINT,相当于输入ctrl+c,中断一个程序的进行  
       9:SIGKILL,强制中断一个进程的进行  
       15:SIGTERM,以正常的结束进程方式来终止进程  
       17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行
       
      # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程  
      # kill -SIGTERM %1   
      # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得  
      # kill -SIGHUP PID  
      
    10. killall

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

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

      用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令很有用了,它的用法非常简单,基本语法如下:

      file filename  
      
      # file ./test 
      
    12. tar

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

      -c :新建打包文件  
      -t :查看打包文件的内容含有哪些文件名  
      -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  
      -j :通过bzip2的支持进行压缩/解压缩  
      -z :通过gzip的支持进行压缩/解压缩  
      -v :在压缩/解压缩过程中,将正在处理的文件名显示出来  
      -f filename :filename为要处理的文件  
      -C dir :指定压缩/解压缩的目录dir  
      
      # 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  
      # 查询:tar -jtv -f filename.tar.bz2  
      # 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录  
      
    13. cat

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

      cat text | less # 查看text文件中的内容  
      # 注:这条命令也可以使用less text来代替  
      
    14. chgrp

      用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:

      chgrp [-R] dirname/filename  
      -R :进行递归的持续对所有文件和子目录更改  
      # chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users  
      
    15. chown

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

    16. chmod

      用于改变文件的权限,一般的用法如下:

      # chmod [-R] xyz 文件或目录  
      -R:进行递归的持续更改,即连同子目录下的所有文件都会更改  
      # chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭# 配来对文件的权限进行更改。
      
      # chmod 755 file # 把file的文件权限改变为-rxwr-xr-x  
      # chmod g+w file # 向file的文件权限中加入用户组可写权限  
      # r:可读 w:可写 x:可执行
      # 也可以用二进制表示 1与0,111 = 7,rwx可读可写可执行,101,可读可执行
      
    17. vim

      用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。

    18. Time

      用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:

      # time ./process  
      # time ps aux 
      
      在程序或命令运行结束后,在最后输出了三个时间,它们分别是:
      user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;
      system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;
      real:实际时间,从command命令行开始执行到运行终止的消逝时间;
      
    19. ssh
      用于远程登录的安全外壳协议,想要登录别的linux,可以用此命令,例如:

          ssh root@ip 
      

    相关文章

      网友评论

      • 阿群1986:vi是个坑货,谁用谁知道,emacs的快捷键设计更加反人类,Unix的设计哲学之一就是保留现有的非常难用的终端窗口来确保系统管理员初学者尽快从入门到放弃
        慕久久:@阿群1986 哈哈哈 点题
      • 阿群1986:区分time和date
        区分echo和cat
        区分man和help

      本文标题:linux的常用命令以及常用工具

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