zoukankan      html  css  js  c++  java
  • Linux常用命令

    参考:http://man.linuxde.net/

    常见执行Linux命令的格式是这样的:命令名称 [命令参数] [命令对象]

    注意,命令名称、命令参数、命令对象之间请用空格键分隔。

    命令对象一般是指要处理的文件、目录、用户等资源,而命令参数可以用长格式(完整的选项名称),也可以用短格式(单个字母的缩写),两者分别用--与-作为前缀。

    命令参数的长格式与短格式示例

    一、常用系统工作命令

    wget命令

    用来从指定的URL下载文件。wget非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性,如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕。如果是服务器打断下载过程,它会再次联到服务器上从停止的地方继续下载。这对从那些限定了链接时间的服务器上下载大文件非常有用

    wget(选项)(参数)

    使用wget下载单个文件

    wget http://www.linuxde.net/testfile.zip    //从网络下载一个文件并保存在当前目录,在下载的过程中会显示进度条,包含(下载完成百分比,已经下载的字节,当前下载速度,剩余下载时间)

    下载并以不同的文件名保存

    wget -O wordpress.zip http://www.linuxde.net/download.aspx?id=1080     //wget默认会以最后一个符合/的后面的字符来命令,对于动态链接的下载通常文件名会不正确。

    wget限速下载

    wget --limit-rate=300k http://www.linuxde.net/testfile.zip    //当你执行wget的时候,它默认会占用全部可能的宽带下载。但是当你准备下载一个大文件,而你还需要下载其它文件时就有必要限速了

    使用wget断点续传

    wget -c http://www.linuxde.net/testfile.zip
    //使用wget -c重新启动下载中断的文件,对于我们下载大文件时突然由于网络等原因中断非常有帮助,我们可以继续接着下载而不是重新下载一个文件。需要继续中断的下载时可以使用-c参数

    使用wget后台下载

    wget -b http://www.linuxde.net/testfile.zip
    
    Continuing in background, pid
    1840. Output will be written to `wget-log'.
    //对于下载非常大的文件的时候,我们可以使用参数-b进行后台下载,你可以使用以下命令来察看下载进度: tail -f wget-log

    伪装代理名称下载

    wget --user-agent="Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.16 (KHTML, like Gecko) Chrome/10.0.648.204 Safari/534.16" http://www.linuxde.net/testfile.zip
    //有些网站能通过根据判断代理名称不是浏览器而拒绝你的下载请求。不过你可以通过--user-agent参数伪装。

     测试下载链接

    //当你打算进行定时下载,你应该在预定时间测试下载链接是否有效。我们可以增加--spider参数进行检查
    wget --spider URL
    
    //如果下载链接正确,将会显示:
    Spider mode enabled. Check if remote file exists.
    HTTP request sent, awaiting response... 200 OK
    Length: unspecified [text/html]
    Remote file exists and could contain further links,
    but recursion is disabled -- not retrieving.
    
    //这保证了下载能在预定的时间进行,但当你给错了一个链接,将会显示如下错误:
    wget --spider url
    Spider mode enabled. Check if remote file exists.
    HTTP request sent, awaiting response... 404 Not Found
    Remote file does not exist -- broken link!!!

    你可以在以下几种情况下使用--spider参数:

      • 定时下载之前进行检查
      • 间隔检测网站是否可用
      • 检查网站页面的死链接

    增加重试次数

    wget --tries=40 URL
    //如果网络有问题或下载一个大文件也有可能失败。wget默认重试20次连接下载文件。如果需要,你可以使用--tries增加重试次数。

     下载多个文件

    //首先,保存一份下载链接文件:
    cat > filelist.txt
    url1
    url2
    url3
    url4
    //接着使用这个文件和参数-i下载
    wget -i filelist.txt

     镜像网站

    wget --mirror -p --convert-links -P ./LOCAL URL

     下载整个网站到本地。

      • --miror开户镜像下载。
      • -p下载所有为了html页面显示正常的文件。
      • --convert-links下载后,转换成本地的链接。
      • -P ./LOCAL保存所有文件和目录到本地指定目录。

    过滤指定格式下载

    wget --reject=gif url
    //下载一个网站,但你不希望下载图片,可以使用这条命令。

     下载指定格式文件

    wget -r -A.pdf url

     可以在以下情况使用该功能:

      • 下载一个网站的所有图片。
      • 下载一个网站的所有视频。
      • 下载一个网站的所有PDF文件。

    ps命令

    用于报告当前系统的进程状态。可以搭配kill指令随时中断、删除不必要的程序。ps命令是最基本同时也是非常强大的进程查看命令,使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等,总之大部分信息都是可以通过执行该命令得到的。

    kill命令

    用来删除执行中的程序或工作。kill可将指定的信息送至程序。预设的信息为SIGTERM(15),可将指定程序终止。若仍无法终止该程序,可使用SIGKILL(9)信息尝试强制删除程序。程序或工作的编号可利用ps指令或job指令查看。kill(选项)(参数)

    选项

    -a:当处理当前进程时,不限制命令名和进程号的对应关系;

    -l <信息编号>:若不加<信息编号>选项,则-l参数会列出全部的信息名称;

    -p:指定kill 命令只打印相关进程的进程号,而不发送任何信号;

    -s <信息名称或编号>:指定要送出的信息;

    -u:指定用户。

    参数进程或作业识别号:指定要删除的进程或作业。

    //先用ps查找进程,然后用kill杀掉:
    ps -ef | grep vim
    root      3268  2884  0 16:21 pts/1    00:00:00 vim install.log
    root      3370  2822  0 16:21 pts/0    00:00:00 grep vim
    
    kill 3268
    kill 3268
    -bash: kill: (3268) - 没有那个进程
    二、系统状态检测命令

    history命令

    用于显示指定数目的指令命令,读取历史命令文件中的目录到历史命令缓冲区和将历史命令缓冲区中的目录写入命令文件。

    该命令单独使用时,仅显示历史命令,在命令行中,可以使用符号!执行指定序号的历史命令。例如,要执行第2个历史命令,则输入!2

    历史命令是被保存在内存中的,当退出或者登录shell时,会自动保存或读取。在内存中,历史命令仅能够存储1000条历史命令,该数量是由环境变量HISTSIZE进行控制。

    //使用history命令显示最近使用的10条历史命令,输入如下命令:
    [root@localhost ~]# history 10
       92  ls
       93  cd ..
       94  ls
       95  exit
       96  ls -a
       97  cd .ssh/
       98  ls
       99  cat known_hosts
      100  exit
      101  history 10
    三、工作目录切换命令

    pwd命令

    以绝对路径的方式显示用户当前工作目录。命令将当前目录的全路径名称(从根目录)写入标准输出。全部目录使用/分隔。第一个/表示根目录,最后一个目录是当前目录。执行pwd命令可立刻得知您目前所在的工作目录的绝对路径名称。pwd(选项)

    pwd --help:显示帮助信息
    pwd --version:显示版本信息

    cd命令

    用来切换工作目录至dirname。 其中dirName表示法可为绝对路径或相对路径。若目录名称省略,则变换至使用者的home directory(也就是刚login时所在的目录)。另外,~也表示为home directory的意思,.则是表示目前所在的目录,..则表示目前目录位置的上一层目录。

    cd        进入用户主目录;
    cd ~      进入用户主目录;
    cd -      返回进入此目录之前所在的目录;
    cd ..     返回上级目录(若当前目录为“/“,则执行完后还在“/";".."为上级目录的意思);
    cd ../..  返回上两级目录;
    cd !$     把上个命令的参数作为cd参数使用。

    ls命令

    用来显示目标列表,在Linux中是使用率较高的命令。ls命令的输出信息可以进行彩色加亮显示,以分区不同类型的文件。

    显示当前目录下非影藏文件与目录

    [root@localhost ~]# ls
    anaconda-ks.cfg  install.log  install.log.syslog  satools

     显示当前目录下包括影藏文件在内的所有文件列表

    [root@localhost ~]# ls -a
    .   anaconda-ks.cfg  .bash_logout   .bashrc  install.log         .mysql_history  satools  .tcshrc   .vimrc
    ..  .bash_history    .bash_profile  .cshrc   install.log.syslog  .rnd            .ssh     .viminfo

     输出长格式列表

    [root@localhost ~]# ls -1
    
    anaconda-ks.cfg
    install.log
    install.log.syslog
    satools

     水平输出文件列表

    [root@localhost /]# ls -m
    bin, boot, data, dev, etc, home, lib, lost+found, media, misc, mnt, opt, proc, root, sbin, selinux, srv, sys, tmp, usr, var

     最近修改的文件显示在最上面(用文件和目录的更改时间排序

    [root@localhost /]# ls -t
    tmp  root  etc  dev  lib  boot  sys  proc  data  home  bin  sbin  usr  var  lost+found  media  mnt  opt  selinux  srv  misc
    四、文档编辑命令

    cat命令

    连接文件并打印到标准输出设备上,cat经常用来显示文件的内容,类似于下的type命令。

    注意:当文件较大时,文本在屏幕上迅速闪过(滚屏),用户往往看不清所显示的内容。因此,一般用more等命令分屏显示。为了控制滚屏,可以按Ctrl+S键,停止滚屏;按Ctrl+Q键可以恢复滚屏。按Ctrl+C(中断)键可以终止该命令的执行,并且返回Shell提示符状态。

    //设ml和m2是当前目录下的两个文件
    cat m1           (在屏幕上显示文件ml的内容)
    cat m1 m2        (同时显示文件ml和m2的内容)
    cat m1 m2 > file (将文件ml和m2合并后放入文件file中)

     more命令

    是一个基于vi编辑器文本过滤器,它以全屏幕的方式按页显示文本文件的内容,支持vi中的关键字定位操作。more名单中内置了若干快捷键,常用的有H(获得帮助信息),Enter(向下翻滚一行),空格(向下滚动一屏),Q(退出命令)。

    该命令一次显示一屏文本,满屏后停下来,并且在屏幕的底部出现一个提示信息,给出至今己显示的该文件的百分比:--More--(XX%)可以用下列不同的方法对提示做出回答:

      • 按Space键:显示文本的下一屏内容。
      • 按Enier键:只显示文本的下一行内容。
      • 按斜线符|:接着输入一个模式,可以在文本中寻找下一个相匹配的模式。
      • 按H键:显示帮助屏,该屏上有相关的帮助信息。
      • 按B键:显示上一屏内容。
      • 按Q键:退出rnore命令。

    显示文件file的内容,但在显示之前先清屏,并且在屏幕的最下方显示完核的百分比。

    more -dc file

     显示文件file的内容,每10行显示一次,而且在显示之前先清屏。

    more -c -10 file

     tail命令

    用于输入文件中的尾部内容。tail命令默认在屏幕上显示指定文件的末尾10行。如果给定的文件不止一个,则在显示的每个文件前面加一个文件名标题。如果没有指定文件或者文件名为“-”,则读取标准输入。

    注意:如果表示字节或行数的N值之前有一个”+”号,则从文件开头的第N项开始显示,而不是显示文件的最后N项。N值后面可以有后缀:b表示512,k表示1024,m表示1 048576(1M)。

    tail file       (显示文件file的最后10行)
    tail +20 file   (显示文件file的内容,从第20行至文件末尾)
    tail -c 10 file (显示文件file的最后10个字符)

    grep

    (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。

    在多个文件中搜索一个单词,命令会返回一个包含“match_pattern”的文本行:

    grep match_pattern file_1 file_2 file_3 ...
    grep "match_pattern" file_1 file_2 file_3 ...

     输出除之外的所有行 -v 选项:

    grep -v "match_pattern" file_name

     标记匹配颜色 --color=auto 选项:

    grep "match_pattern" file_name --color=auto

     使用正则表达式 -E 选项:

    grep -E "[1-9]+"    或    egrep "[1-9]+"

     统计文件或者文本中包含匹配字符串的行数 -c 选项:

    grep -c "text" file_name

     输出包含匹配字符串的行数 -n 选项:

    grep "text" -n file_name  或  cat file_name | grep "text" -n
    
    //多个文件
    grep "text" -n file_1 file_2

     在grep搜索结果中包括或者排除指定文件:

    //只在目录中所有的.php和.html文件中递归搜索字符"main()"
    grep "main()" . -r --include *.{php,html}
    
    //在搜索结果中排除所有README文件
    grep "main()" . -r --exclude "README"
    
    //在搜索结果中排除filelist文件列表里的文件
    grep "main()" . -r --exclude-from filelist
    五、文本目录管理命令

    mkdir命令

    用来创建目录。该命令创建由dirname命名的目录。如果在目录名的前面没有加任何路径名,则在当前目录下创建由dirname指定的目录;如果给出了一个已经存在的路径,将会在该目录下创建一个指定的目录。在创建目录时,应保证新建的目录与它所在目录下的文件没有重名。 

    注意:在创建文件时,不要把所有的文件都存放在主目录中,可以创建子目录,通过它们来更有效地组织文件。最好采用前后一致的命名方式来区分文件和目录。例如,目录名可以以大写字母开头,这样,在目录列表中目录名就出现在前面。

    在一个子目录中应包含类型相似或用途相近的文件。例如,应建立一个子目录,它包含所有的数据库文件,另有一个子目录应包含电子表格文件,还有一个子目录应包含文字处理文档,等等。目录也是文件,它们和普通文件一样遵循相同的命名规则,并且利用全路径可以唯一地指定一个目录。

    在目录/usr/meng下建立子目录test,并且只有文件主有读、写和执行权限,其他人无权访问

    mkdir -m 700 /usr/meng/test

     在当前目录中建立bin和bin下的os_1目录,权限设置为文件主可读、写、执行,同组用户可读和执行,其他用户无权访问

    mkdir -p-m 750 bin/os_1

    cp命令

    用来将一个或多个源文件或者目录复制到指定的目的文件或目录。它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下。cp命令还支持同时复制多个文件,当一次复制多个文件时,目标文件参数必须是一个已经存在的目录,否则将出现错误。所有目标文件指定的目录必须是己经存在的,cp命令不能创建目录。如果没有文件复制的权限,则系统会显示出错信息。

    如果把一个文件复制到一个目标文件中,而目标文件已经存在,那么,该目标文件的内容将被破坏。此命令中所有参数既可以是绝对路径名,也可以是相对路径名。通常会用到点.或点点..的形式。例如,下面的命令将指定文件复制到当前目录下:

    cp ../mary/homework/assign .

     将文件file复制到目录/usr/men/tmp下,并改名为file1

    cp file /usr/men/tmp/file1

     将目录/usr/men下的所有文件及其子目录复制到目录/usr/zh

    cp -r /usr/men /usr/zh

     交互式地将目录/usr/men中的以m打头的所有.c文件复制到目录/usr/zh

    cp -i /usr/men m*.c /usr/zh

    rm命令

    可以删除一个目录中的一个或多个文件或目录,也可以将某个目录及其下属的所有文件及其子目录均删除掉。对于链接文件,只是删除整个链接文件,而原有文件保持不变。

    rm (选项)(参数)  如果参数中含有目录,则必须加上-r或者-R选项。

    注意:使用rm命令要格外小心。因为一旦删除了一个文件,就无法再恢复它。所以,在删除文件之前,最好再看一下文件的内容,确定是否真要删除。rm命令可以用-i选项,这个选项在使用文件扩展名字符删除多个文件时特别有用。使用这个选项,系统会要求你逐一确定是否要删除。这时,必须输入y并按Enter键,才能删除文件。如果仅按Enter键或其他字符,文件不会被删除。

    //交互式删除当前目录下的文件test和example
    rm -i test example
    六、备份压缩命令

    zip命令

    用于压缩文件。zip是个使用广泛的压缩程序,文件经它压缩后会另外产生具有".zip"扩展名的压缩文件。

    //将 /home/html/ 这个目录下所有文件和文件夹打包为当前目录下的 html.zip:
    zip -q -r html.zip /home/html
    //如果在我们在 /home/html 目录下,可以执行以下命令:
    zip -q -r html.zip *
    //从压缩文件 cp.zip 中删除文件 a.c
    zip -dv cp.zip a.c

    unzip命令

    用于解压缩zip文件。unzip为.zip压缩文件的解压缩程序。

    tar命令

    可以为linux的文件和目录创建档案。利用tar,可以为某一特定文件创建档案(备份文件),也可以在档案中改变文件,或者向档案中加入新的文件。tar最初被用来在磁带上创建档案,现在,用户可以在任何设备上创建档案。利用tar命令,可以把一大堆的文件和目录全部打包成一个文件,这对于备份文件或将几个文件组合成为一个文件以便于网络传输是非常有用的。

    首先要弄清两个概念:打包和压缩。打包是指将一大堆文件或目录变成一个总的文件;压缩则是将一个大的文件通过一些压缩算法变成一个小文件。

    为什么要区分这两个概念呢?这源于Linux中很多压缩程序只能针对一个文件进行压缩,这样当你想要压缩一大堆文件时,你得先将这一大堆文件先打成一个包(tar命令),然后再用压缩程序进行压缩(gzip bzip2命令)。

    将文件全部打包成tar包

    tar -cvf log.tar log2012.log       仅打包,不压缩! 
    tar -zcvf log.tar.gz log2012.log   打包后,以 gzip 压缩 
    tar -jcvf log.tar.bz2 log2012.log  打包后,以 bzip2 压缩 
    //在选项f之后的文件档名是自己取的,我们习惯上都用 .tar 来作为辨识。 如果加z选项,则以.tar.gz或.tgz来代表gzip压缩过的tar包;如果加j选项,则以.tar.bz2来作为tar包名。

     将tar包解压缩

    tar -zxvf /opt/soft/test/log.tar.gz

     只将tar内的部分文件解压出来

    tar -zxvf /opt/soft/test/log30.tar.gz log2013.log
    七、网络管理

    ip命令

    用来显示或操纵Linux主机的路由、网络设备、策略路由和隧道,是Linux下较新的功能强大的网络配置工具。

    //用ip命令显示网络设备的运行状态
    [root@localhost ~]# ip link list
    //显示更加详细的设备信息
    [root@localhost ~]# ip -s link list
    //显示核心路由表
    [root@localhost ~]# ip route list

    ss命令

    用来显示处于活动状态的套接字信息。ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容。但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。

    当服务器的socket连接数量变得非常大时,无论是使用netstat命令还是直接cat /proc/net/tcp,执行速度都会很慢。可能你不会有切身的感受,但请相信我,当服务器维持的连接达到上万个的时候,使用netstat等于浪费 生命,而用ss才是节省时间。

    天下武功唯快不破。ss快的秘诀在于,它利用到了TCP协议栈中tcp_diag。tcp_diag是一个用于分析统计的模块,可以获得Linux 内核中第一手的信息,这就确保了ss的快捷高效。当然,如果你的系统中没有tcp_diag,ss也可以正常运行,只是效率会变得稍慢。

    //显示ICP连接
    [root@localhost ~]# ss -t -a
    //显示ICP连接
    [root@localhost ~]# ss -t -a
    //列出所有打开的网络连接端口
    [root@localhost ~]# ss -l
    //查看进程使用的socket
    [root@localhost ~]# ss -pl
    //找出打开套接字/端口应用程序
    [root@localhost ~]# ss -pl | grep 3306
    //显示所有UDP Sockets
    [root@localhost ~]# ss -u -a

    telnet命令

    用于登录远程主机,对远程主机进行管理。telnet因为采用明文传送报文,安全性不好,很多Linux服务器都不开放telnet服务,而改用更安全的ssh方式了。但仍然有很多别的系统可能采用了telnet方式来提供远程登录,因此弄清楚telnet客户端的使用方式仍是很有必要的。

    telnet 192.168.2.10
    Trying 192.168.2.10...
    Connected to 192.168.2.10 (192.168.2.10).
    Escape character is '^]'.
    
        localhost (Linux release 2.6.18-274.18.1.el5 #1 SMP Thu Feb 9 12:45:44 EST 2012) (1)
    
    login: root
    Password: 
    Login incorrect

    ssh命令

    openssh套件中的客户端连接工具,可以给予ssh加密协议实现安全的远程登录服务器。

    curl命令

    一个利用URL规则在命令行下工作的文件传输工具。它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称curl为下载工具。作为一款强力工具,curl支持包括HTTP、HTTPS、ftp等众多协议,还支持POST、cookies、认证、从指定偏移处下载部分文件、用户代理字符串、限速、文件大小、进度条等特征。做网页处理流程和数据检索自动化,curl可以祝一臂之力。

    文件下载

    //curl命令可以用来执行下载、发送各种HTTP请求,指定HTTP头部等操作。如果系统没有curl可以使用yum install curl安装,也可以下载安装。
    //curl是将下载文件输出到stdout,将进度信息输出到stderr,不显示进度信息使用--silent选项。
    curl URL --silent//这条命令是将下载文件输出到终端,所有下载的数据都被写入到stdout。 //使用选项-O将下载的数据写入到文件,必须使用文件的绝对地址: curl http://man.linuxde.net/text.iso --silent -O //选项-o将下载数据写入到指定名称的文件中,并使用--progress显示进度条: curl http://man.linuxde.net/test.iso -o filename.iso --progress ######################################### 100.0%

    断点续传

    //curl能够从特定的文件偏移处继续下载,它可以通过指定一个便宜量来下载部分文件:
    curl URL/File -C 偏移量
    
    //偏移量是以字节为单位的整数,如果让curl自动推断出正确的续传位置使用-C -:
    curl -C -URL

    用curl设置cookies

    //使用--cookie "COKKIES"选项来指定cookie,多个cookie使用分号分隔:
    curl http://man.linuxde.net --cookie "user=root;pass=123456"
    //将cookie另存为一个文件,使用--cookie-jar选项:
    curl URL --cookie-jar cookie_file

    curl的带宽控制和下载配额

    //使用--limit-rate限制curl的下载速度:
    curl URL --limit-rate 50k  //命令中用k(千字节)和m(兆字节)指定下载速度限制。
    
    //使用--max-filesize指定可下载的最大文件大小:
    curl URL --max-filesize bytes  //如果文件大小超出限制,命令则返回一个非0退出码,如果命令正常则返回0。
  • 相关阅读:
    leetcode 122. Best Time to Buy and Sell Stock II
    leetcode 121. Best Time to Buy and Sell Stock
    python 集合(set)和字典(dictionary)的用法解析
    leetcode 53. Maximum Subarray
    leetcode 202. Happy Number
    leetcode 136.Single Number
    leetcode 703. Kth Largest Element in a Stream & c++ priority_queue & minHeap/maxHeap
    [leetcode]1379. Find a Corresponding Node of a Binary Tree in a Clone of That Tree
    正则表达式
    十种排序算法
  • 原文地址:https://www.cnblogs.com/whatarewords/p/10930782.html
Copyright © 2011-2022 走看看