• Linux常用命令


    一、
    1、cd命令:这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:

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


    2、ls命令:这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:

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

    # 这些参数也可以组合使用,例如:
    ls -l #以长数据串的形式列出当前目录下的数据文件和目录
    ls -lR #以长数据串的形式列出当前目录下的所有文件


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

    grep [-acinv] [--color=auto] '查找字符串' filename
    它的常用参数如下:

    -a :将binary文件以text文件的方式查找数据
    -c :计算找到‘查找字符串’的次数
    -i :忽略大小写的区别,即把大小写视为相同
    -v :反向选择,即显示出没有‘查找字符串’内容的那一行
    # 例如:
    # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色
    grep --color=auto 'MANPATH' /etc/man.config
    # 把ls -l的输出中包含字母file(不区分大小写)的内容输出
    ls -l | grep -i file


    4、find命令: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
    find . -name "*.log" | xargs grep "err" # 查找当前目录下文件以".log"结尾,内容包含"err"的文件路径

     


    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 :递归删除,最常用于目录删除,它是一个非常危险的参数
    注:在重要or唯一的机器上尽量不要用该命令,除非你想跑路

    # 例如:
    rm -i file # 删除文件file,在删除之前会询问是否进行该操作
    rm -fr dir # 强制删除目录dir中的所有文件

    8、ps命令:该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:

    -A :所有的进程均显示出来
    -a :不与terminal有关的所有进程
    -u :有效用户的相关进程
    -x :一般与a参数一起使用,可列出较完整的信息
    -l :较长,较详细地将PID的信息列出

    # 其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,例如:
    ps aux # 查看系统所有的进程数据
    ps ax # 查看不与terminal有关的所有进程
    ps -lA # 查看系统所有的进程数据
    ps axjf # 查看连同一部分进程树状态
    ps -ef | grep filebeat # 查看启动filebeat信息


    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 -czvf filename.tar.gz * --excexclude /home/log # "*"表示当前目录下所有文件,排除目录或文件(文件需要带路径)
    查询:tar -jtv -f filename.tar.bz2
    解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
      tar zxvf filename.tar.gz # 文件解压到当前目录
    注:文件名并不定要以后缀tar.bz2结尾(如上:.gz;如果是tar,表明只打包不压缩),这里主要是为了说明使用的压缩程序为bzip2(压缩程序为gzip)

    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 0755 file # 把file的文件权限改变为:-rxwr-xr-x,一共十个字符,分成四段。
      第一个字符“-”表示普通文件;这个位置还可能会出现“l”链接;“d”表示目录
      第二三四个字符“rxw”表示当前所属用户的权限。 所以用数值表示为4+1+2=7
      第五六七个字符“r-x”表示当前所属组的权限。 所以用数值表示为4+0+1=5
      第八九十个字符“r-x”表示其他用户权限。 所以用数值表示为4+0+1=5
    chmod g+w file # 向file的文件权限中加入用户组可写权限


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

    vim三种模式:命令模式、插入模式、编辑模式。使用ESC或i或:来切换模式。
    命令模式下:
    :q                      # 退出
    :q!                     # 强制退出
    :wq                   # 保存并退出
    :set number      # 显示行号
    :set nonumber  # 隐藏行号
    /apache            # 在文档中查找apache 按n跳到下一个,shift+n上一个
    yyp                   # 复制光标所在行,并粘贴
    h(左移一个字符←)、j(下一行↓)、k(上一行↑)、l(右移一个字符→)

     

    19、gcc命令:对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:

    -o :output之意,用于指定生成一个可执行文件的文件名
    -c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序
    -I :增加编译时搜索头文件的路径
    -L :增加编译时搜索静态连接库的路径
    -S :把源文件生成汇编代码文件
    -lm:表示标准库的目录中名为libm.a的函数库
    -lpthread :连接NPTL实现的线程库
    -std= :用于指定把使用的C语言的版本
    # 例如:
    # 把源文件test.c按照c99标准编译成可执行程序test
    gcc -o test test.c -lm -std=c99
    #把源文件test.c转换为相应的汇编程序源文件test.s
    gcc -S test.c


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

    time ./process
    time ps aux
    在程序或命令运行结束后,在最后输出了三个时间,它们分别是:

    user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;

    system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;

    real:实际时间,从command命令行开始执行到运行终止的消逝时间;

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

    二、

    21、关机/重启机器

    shutdown
         -r           #  关机重启
         -h          #   关机不重启
         now       #   立刻关机
    halt            #   关机
    reboot        #  重启

    22、查看分区空间使用:可以查看各分区大小、已使用、可用、已使用百分比、挂载情况

    df # 默认单位为K
    df -h # 可读性更好的显示,如单位M、G等

    23、查看内存信息

    1)使用free命令
    默认单位为K,可通过结合参数-b、-k、-m分别以单位B、K、M进行显示
    # free
    # free -b
    # free -k
    # free -m
    2)查看/proc/meminfo文件,可以获得比free命令更详细内存信息
    # cat /proc/meminfo

     

    24、CPU信息

    1)查询CPU基本信息
    # more /proc/cpuinfo
    # more /proc/cpuinfo | grep "model name" | sort | uniq
    2)查询有多少个CPU(相同physical id为同一个CPU)
    # more /proc/cpuinfo | grep "physical id" | sort | uniq
    3)查询单个CPU核数
    # more /proc/cpuinfo | grep "cpu cores" | sort | uniq
    4)查询单个CPU线程数(逻辑处理器)
    # more /proc/cpuinfo | grep siblings | sort | uniq

    25、查看系统信息

    1)查看内核名称
    # uname
    相当于
    # uname -s
    2)查看完整的系统信息,包括内核名称、主机名、内核版本、处理器架构等
    # uname -a

    26、查看redhat发行版本信息

      # more /etc/redhat-release

    27、查看主机名

    # hostname
    # uname -n
    hostname对应的配置文件是/etc/sysconfig/network,如果配置文件中HOSTNAME为空、(none)、localhost或localhost.localdomain,就会尝试根据实际IP从/etc/hosts中查找映射的主机名,如果存在则使用该主机名,否则使用原来的HOSTNAME。


    28、查看网络服务的状态、启动、停止或重启网络服务

    # service network status|start|stop|restart

    29、显示、设置网络设备

    1)查看已启用的网络接口信息
    # ifconfig
    2)查看所有网络接口配置
    # ifconfig -a
    3)查看eth0网络接口配置
    # ifconfig eth0
    4)启用eth0网络接口
    # ifconfig eth0 up
    # ifup eth0
    5)关闭eth0网络接口
    # ifconfig eth0 down
    # ifdown eth0
    6)实时(临时)修改eth0的IP地址
    # ifconfig eth0 IP地址
    7)实时(临时)修改eth0的IP地址、子网掩码
    # ifconfig eth0 IP地址 netmask 子网掩码

    实时地手动修改一些网络接口参数,可以利用ifconfig来实现,如果是要直接以配置文件,亦即是在 /etc/sysconfig/network-scripts里面的ifcfg-ethx等文件的设置参数来启动的话,那就得要通过ifdown或ifup来实现了。
    ifconfig是一个命令。
    ifup、ifdown是脚本,它会直接到/etc/sysconfig/network-scripts目录下搜索对应的配置文件,例如ifup eth0,它会找出ifcfg-eth0这个文件的内容,然后加以设置。
    不过,由于这两个程序主要是搜索设置文件(ifcfg-ethx)来进行启动与关闭的,所以在使用前请确定ifcfg-ethx是否真的存在于正确的目录内,否则会启动失败。另外,如果以ifconfig eth0来设置或者是修改了网络接口后,就无法再以ifdown eth0的方式来关闭了。因为ifdown会分析比较目前的网络参数与ifcfg-eth0是否相符,不符的话,就会放弃这次操作。因此,使用ifconfig修改完毕后,应该要以ifconfig eth0 down才能够关闭该接口。

    30、查看网卡配置文件,网络接口配置文件目录:/etc/sysconfig/network-scripts,其中,ifcfg-eth0是默认的第一个网络接口,如果机器中有多个网络接口,那么名字依此类推ifcfg-eth1、ifcfg-eth2...

    # more /etc/sysconfig/network-scripts/ifcfg-eth0

    31、查看所有系统服务的运行状态

    # service --status-all

    32、查询、更新系统服务的运行级别信息

    1)查看系统服务列表,以及每个服务的运行级别
    # chkconfig --list
    2)添加服务
    # chkconfig --add 服务名
    3)删除服务
    # chkconfig --del 服务名
    4)开启、关闭或重置在某运行级别的开启情况
    # chkconfig --level 2345 name <on|off|reset>

    33、显示网络状态

    1)查看监听中的sockets
    # netstat -l
    2)查看TCP传输协议的连接情况
    # netstat -t
    3)查看UDP传输协议的连接情况
    # netstat -u
    4)查看当前连接中的所有socket
    # netstat -a
    5)显示网络连接状态,显示IP地址而不使用域名
    # netstat -n
    6)查看监听中的TCP端口
    # netstat -tnlp
    7)查看监听中的UDP端口
    # netstat -unlp
    8)分页显示结果
    # netstat -anp|more
    9)查看端口是否被使用
    # netstat -nlp | grep 端口号

    34、实时监控CPU、内存、进程等使用情况

    # top
    输入大写P:按CPU使用率降序排序
    输入大写M:按内存使用率降序排序

    35、文件&文件夹上传、下载

       1)上传到的服务器
      # scp path/filename userName@sseverName:path

      例如:scp /home/testt.txt root@127.0.0.1:/home/testt.txt
      2)下载服务器的文件到本地

      # scp userName@sseverName:path path/filename

      例如:scp root@127.0.0.1:/home/testt.txt /home/testt.txt

      2)文件夹上传、下载需要加上 -r 参数, 使用递归上传或者下载

      例如:scp -r root@127.0.0.1:/home/testt.txt /home/testt.txt

    36、sed命令,linux下转换windows文件格式为unix

      sed -i 's/ $//' adduser.sh

    (待续......)

    注:非本人原创,如侵立删,根据本人使用做了修改以及补充,以上命令多数亲测有效,如有错误,希望可以评论。

  • 相关阅读:
    TCP心跳 | TCP keepAlive(转)
    闲说HeartBeat心跳包和TCP协议的KeepAlive机制
    一个DNS统计,RCFs,工具站点
    JMX
    【转】如何实现一个配置中心
    用Netty开发中间件:高并发性能优化
    UDP server & client
    DNS缓存
    C正则库做DNS域名验证时的性能对比
    DNS压力测试工具dnsperf简介
  • 原文地址:https://www.cnblogs.com/ZhaoHS/p/11465715.html
Copyright © 2020-2023  润新知