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

    ls
     
    常用参数
     
    -l :列出长数据串,包含文件的属性与权限数据等
     
    -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
     
    -d :仅列出目录本身,而不是列出目录的文件数据
     
    -h :将文件容量以较易读的方式(GB,kB等)列出来
     
    -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
     
    注:这些参数也可以组合使用,下面举两个例子:
     
    ls -l #以长数据串的形式列出当前目录下的数据文件和目录
     
    ls -lR #以长数据串的形式列出当前目录下的所有文件
     
    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
     
    wc
     
    wc(word count)功能为统计指定的文件中字节数、字数、行数,并将统计结果输出
     
    命令格式:
     
    wc [option] file..
     
    命令参数:
     
    -c 统计字节数
     
    -l 统计行数
     
    -m 统计字符数
     
    -w 统计词数,一个字被定义为由空白、跳格或换行字符分隔的字符串
     
    实例:
     
    (1)查找文件的 行数 单词数 字节数 文件名
     
    wc text.txt
     
    结果:7 8 70 test.txt
     
    (2)统计输出结果的行数
     
    cat test.txt | wc -l
     
    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/test -user tom # 在目录/home/test中找出所有者为tom的文件
     
    与文件权限及名称有关的参数:
     
    -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
     
    find . -perm 0755 # 查找当前目录中文件权限的0755的文件
     
    find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte
     
    cp
     
    该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,常用参数:
     
    -a :将文件的特性一起复制
     
    -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
     
    -i :若目标文件已经存在时,在覆盖时会先询问操作的进行
     
    -r :递归持续复制,用于目录的复制行为
     
    -u :目标文件与源文件有差异时才会复制
     
    例如
     
    cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2
     
    cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中
     
    scp
     
    常用于不同机器之间传文件和目录
     
    scp [可选参数] file_source file_target
     
    从 本地 复制到 远程
     
    命令格式:
     
    scp local_file remote_username@remote_ip:remote_folder
     
    scp local_file remote_ip:remote_folder
     
    第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名;
     
    第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名;
     
    例子:
     
    scp /home/space/music/1.mp3 root@www.test.com:/home/root/others/music
     
    scp /home/space/music/1.mp3 www.test.com:/home/root/others/music
     
    复制目录:
     
    scp -r local_folder remote_username@remote_ip:remote_folder
     
    scp -r local_folder remote_ip:remote_folder
     
    scp -r /home/space/music/ root@www.test.com:/home/root/others/
     
    scp -r /home/space/music/ www.test.com:/home/root/others/
     
    从 远程 复制到 本地,只要将 从 本地 复制到 远程 的命令 的 后2个参数 调换顺序 即可;
     
    例如:
     
    scp root@www.test.com:/home/root/others/music /home/space/music/1.mp3
     
    scp -r www.test.com:/home/root/others/ /home/space/music/
     
    参数 :
     
    -v 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 .
     
    -C 使能压缩选项 .
     
    -P 选择端口 . 注意 -p 已经被 rcp 使用 .
     
    -4 强行使用 IPV4 地址 .
     
    -6 强行使用 IPV6 地址 .
     
    注意两点:
     
    1.如果远程服务器防火墙有特殊限制,scp便要走特殊端口:
     
    scp -p 9997 remote@www.test.com:/usr/local/sin.sh /home/tom
     
    2.使用scp要注意所使用的用户是否具有可读取远程服务器相应文件的权限。
     
    mv
     
    该命令用于移动文件、目录或更名,move之意,它的常用参数如下:
     
    -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
     
    -i :若目标文件已经存在,就会询问是否覆盖
     
    -u :若目标文件已经存在,且比目标文件新,才会更新
     
    注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。
     
    例如:
     
    mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中
     
    mv file1 file2 # 把文件file1重命名为file2
     
    rm
     
    该命令用于删除文件或目录,remove之间,常用参数如下:
     
    -f :就是force的意思,忽略不存在的文件,不会出现警告消息
     
    -i :互动模式,在删除前会询问用户是否操作
     
    -r :递归删除,最常用于目录删除,它是一个非常危险的参数
     
    例如:
     
    rm -i file # 删除文件file,在删除之前会询问是否进行该操作
     
    rm -fr dir # 强制删除目录dir中的所有文件
     
    ps
     
    该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
     
    -A :所有的进程均显示出来
     
    -a :不与terminal有关的所有进程
     
    -u :有效用户的相关进程
     
    -x :一般与a参数一起使用,可列出较完整的信息
     
    -l :较长,较详细地将PID的信息列出
     
    其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:
     
    ps aux # 查看系统所有的进程数据
     
    ps ax # 查看不与terminal有关的所有进程
     
    ps -lA # 查看系统所有的进程数据
     
    ps axjf # 查看连同一部分进程树状态
     
    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
     
    killall
     
    该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
     
    killall [-iIe] [command name]
     
    它的参数如下:
     
    -i :交互式的意思,若需要删除时,会询问用户
     
    -e :表示后面接的command name要一致,但command name不能超过15个字符
     
    -I :命令名称忽略大小写
     
    例如:
     
    killall -SIGHUP syslogd # 重新启动syslogd
     
    tar
     
    该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
     
    -c :新建打包文件
     
    -t :查看打包文件的内容含有哪些文件名
     
    -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
     
    -j :通过bzip2的支持进行压缩/解压缩
     
    -z :通过gzip的支持进行压缩/解压缩
     
    -v :在压缩/解压缩过程中,将正在处理的文件名显示出来
     
    -f filename :filename为要处理的文件
     
    -C dir :指定压缩/解压缩的目录dir
     
    常用命令前两条
     
    压缩:tar -zcvf /tmp/etc.tar.gz /etc  <==打包后,以 gzip 压缩
     
    解压:tar -zxvf /tmp/etc.tar.gz 欲解压缩的目录
     
    查询:tar -ztvf /tmp/etc.tar.gz
     
    打包:tar -cvf /tmp/etc.tar /etc    <==仅打包,不压缩!
     
    cat
     
    该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:
     
    cat text | less # 查看text文件中的内容
     
    注:这条命令也可以使用less text来代替
     
    chgrp
     
    该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:
     
    chgrp [-R] dirname/filename
     
    -R :进行递归的持续对所有文件和子目录更改
     
    例如:
     
    chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
     
    chown
     
    该命令用于改变文件的所有者
     
    chown [选项]… [所有者][:[组]] 文件…
     
    必要参数:
     
    -c 显示更改的部分的信息
     
    -f 忽略错误信息
     
    -h 修复符号链接
     
    -R 处理指定目录以及其子目录下的所有文件
     
    -v 显示详细的处理信息
     
    chown mail:mail log2016.log
     
    groups
     
    查看当前登录用户的组内成员
     
    groups
     
    groups root 查看root组的用户
     
    whoami 查看当前用户名
     
    /etc/group文件包含所有组
     
    /etc/shadow和/etc/passwd系统存在的所有用户名
     
    chmod
     
    该命令用于改变文件的权限,一般的用法如下:
     
    chmod [-R] xyz 文件或目录
     
    -R:进行递归的持续更改,即连同子目录下的所有文件都会更改
     
    同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改
     
    例如:
     
    chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x
     
    chmod g+w file # 向file的文件权限中加入用户组可写权限
     
    df
     
    显示磁盘空间使用情况。获取硬盘被占用了多少空间,目前还剩下多少空间等信息
     
    -a 全部文件系统列表
     
    -h 以方便阅读的方式显示信息
     
    -i 显示inode信息
     
    -k 区块为1024字节
     
    -l 只显示本地磁盘
     
    -T 列出文件系统类型
     
    df -haT
     
    du
     
    -a 显示目录中所有文件大小
     
    -k 以KB为单位显示文件大小
     
    -m 以MB为单位显示文件大小
     
    -g 以GB为单位显示文件大小
     
    -h 以易读方式显示文件大小
     
    -s 仅显示总计
     
    -c或--total 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和
     
    du -ah filedir/
     
    ln
     
    功能是为文件在另外一个位置建立一个同步的链接,当在不同目录需要该问题时,就不需要为每一个目录创建同样的文件,通过ln创建的链接(link)减少磁盘占用量。
     
    链接分类:软件链接及硬链接
     
    软链接:
     
    1.软链接,以路径的形式存在。类似于Windows操作系统中的快捷方式
     
    2.软链接可以 跨文件系统 ,硬链接不可以
     
    3.软链接可以对一个不存在的文件名进行链接
     
    4.软链接可以对目录进行链接
     
    硬链接:
     
    1.硬链接,以文件副本的形式存在。但不占用实际空间。
     
    2.不允许给目录创建硬链接
     
    3.硬链接只有在同一个文件系统中才能创建
     
    需要注意:
     
    第一:ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化;
     
    第二:ln的链接又分软链接和硬链接两种,软链接就是ln –s 源文件 目标文件,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间,硬链接 ln 源文件 目标文件,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。
     
    第三:ln指令用在链接文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则会把前面指定的所有文件或目录复制到该目录中。若同时指定多个文件或目录,且最后的目的地并非是一个已存在的目录,则会出现错误信息。
     
    常用参数:
     
    -b 删除,覆盖以前建立的链接
     
    -s 软链接(符号链接)
     
    -v 显示详细处理过程
     
    实例:
     
    (1)给文件创建软链接,并显示操作信息
     
    ln -sv source.log link.log
     
    (2)给文件创建硬链接,并显示操作信息
     
    ln -v source.log link1.log
     
    (3)给目录创建软链接
     
    ln -sv /opt/soft/test/test3 /opt/soft/test/test5
     
    lsof
     
    查找哪些程序使用了那些文件
     
    lsof -i :port_number |grep “(LISTEN)”
     
    -i是用来查找和网络相关的文件,”:”号是必须的,它是标志你查找的是一个端口 port_number就是你要查找的端口号,譬如你要查找是否 有程序占用了oracle的监听端口1521,就可以使用lsof -i :1521 |grep “(LISTEN)”。如果有程序已经占用了,那么下面打印的第二个字段就是该程序的进程id,第一个字段是进程的名字。
     
    如果只有losf -i :port_number可能会查到很多应用程序,但这些程序实际并没有占用你指定的端口,这些端口只是连接到本机器或者别的机器的该端口。所以要grep “(LISTEN)“,因为一个端口只可能被一个程序占用的,所以这种方法是可靠的
     
    netstat
     
    查看端口是否已经打开:
     
    netstat -ann|grep 80
     
    查看 某个端口是被什么程序占用了
     
    使用netstat -anp|grep 80
     
    netstat -lnp|awk ‘BEGIN{prt=”:1521$”}{if ($4 ~ prt) print $0}’
     
    Netstat后面的意思
     
    ·Proto显示连接使用的协议。
     
    ·RefCnt表示连接到本套接口上的进程号。
     
    ·Types显示套接口的类型。
     
    ·State显示套接口当前的状态。
     
    ·Path表示连接到套接口的其它进程使用的路径名
     
    Netstat -tln 命令是用来查看linux的端口使用情况,
     
    netstat -a 查看所有的服务端口
     
    netstat -an | grep 端口号 来检验下是不是已经打开了某某端口
     
    service xxx start 或者 /etc/init.d/xxx start是开启xxx某端口
     
    iptables -A INPUT –dport xxx -j DROP
     
    iptables -A OUTPUT –dport xxx -j DROP是关闭xxx端口
  • 相关阅读:
    [LintCode] Flatten Nested List Iterator 压平嵌套链表迭代器
    [LintCode] Reverse Pairs 翻转对
    [CareerCup] 17.9 Word Frequency in a Book 书中单词频率
    [CareerCup] 17.8 Contiguous Sequence with Largest Sum 连续子序列之和最大
    [CareerCup] 17.7 English Phrase Describe Integer 英文单词表示数字
    [LeetCode] Reverse Vowels of a String 翻转字符串中的元音字母
    [CareerCup] 17.6 Sort Array 排列数组
    [LeetCode] 344. Reverse String 翻转字符串
    [CareerCup] 17.5 Game of Master Mind 猜字游戏
    [CareerCup] 17.4 Maximum of Two Numbers 两数中的较大值
  • 原文地址:https://www.cnblogs.com/mountain2011/p/13199970.html
Copyright © 2011-2022 走看看