zoukankan      html  css  js  c++  java
  • 开发人员需要掌握的日常Linux命令集

    本文整理了开发人员日常用到的linux相关命令,供参考。

    文件相关

    cd # 进入某个目录,不接参数进入当前用户目录(等同于cd ~)如/home/devuser,可接绝对路径或相对路径(../..表示上上级目录),也可以接 “-” 回到上次所在目录

    pwd # 显示当前所在目录

    ls -la # 列出当前目录所有对象,-a表示包含以.开头的隐藏文件或目录
    ll -h # ll 等同于 ls -l, -h表示按K M G 显示文件大小

    df -h # 显示系统各盘符的空间使用情况
    du -h --max-depth=1 # 显示当前目录下各文件大小,–max-depth=1只列出当前目录下的文件或目录,不会列出子目录下的文件

    mv test.log /home/devuser/ # 移动文件(夹) 或重命名

    cp [-r] test test.bak # 复制文件,如果是文件夹则加 -r,表示复制文件夹下所有子文件夹内容

    rm -[r]f /home/devuser/ # 删除文件,如果删除文件夹则加 -r

    find / -name test.log # 在根目录下查找文件名为test.log的文件
    find /var/log/ -size +50M -exec rm -f {} ; # 在/var/log/目录下查找大于50M的文件并删除,建议先将rm改为ls确认
    find /var/log/ -type f -atime +10 # 搜索在过去10天内未被使用过的文件
    find /var/log/ -type f -mtime -10 # 搜索在10天内被创建或者修改过的文件
    find /var/log/ -type f -atime +10|xargs rm -f # |xargs 作用与 -exec类似
    find ./ -name "*.log" -exec 'cat' {} ; > test.log # 将当前目录下所有.log文件内容合并到一个文件test.log

    which java # 在系统PATH路径下查找java可执行文件
    whereis java # 查找二进制、源文件、man文件,从文件索引中查找,而不仅仅从PATH路径下查找

    zip test.zip test.log test2.log # 创建一个zip格式的压缩包,可以接多个文件或文件夹
    zip -r file.zip file1 file2 dir1 # 将几个文件和目录同时压缩成一个zip格式的压缩包
    unzip test.zip # 解压一个zip格式压缩包

    tar -zcvf test.tar.gz 要被压缩的文件名或目录 # 以gzip进行压缩 -z 按gzip,-c 压缩,-v 显示内容 -f 指定文件名
    tar -zxvf test.tar.gz -C 解压缩到的目录 # 解压到指定目录 -x 解压
    tar -ztvf test.tar.gz # 不解压,只查看内容

    tar -jcvf test.tar.bz2 要被压缩的文件名或目录 # 以bzip2进行压缩
    tar -jxvf test.tar.bz2 -C 解压缩到的目录 # 解压到指定目录

     

    文本相关

    touch test.log # 创建空文件

    echo -e 'abc cba'> test.log # 覆盖的形式往文件写入内容 -e 解析转移字符,不然当成字符串
    echo 'aaa' >> test.log # 追加的形式往文件写入内容

    cat [-n] test.log |grep [-v] abc # 过滤文件中包含 abc 的行, 加-v表示不包含, -n表示打印行号
    cat test.log |grep abc|wc -l # 计算文件中包含 abc 的行数

    head -n 2 test.log # 查看一个文件的前两行
    tail -n 2 test.log # 查看一个文件的最后两行
    tail -n +1000 test.log # 从1000行开始显示,显示1000行以后的
    cat test.log | head -n 2000 | tail -n +1000 # 显示1000行到2000行的
    cat test.log | tail -n +1000 | head -n 1000 # 从第1000行开始,显示1000行

    more test.log # 一页一页地查看文件内容,空格键往后一页,B键往前一页,不能通过上下键控制翻滚,会一次加载整个文件
    less test.log # 一页一页地显示文件内容,可以通过上下键控制往前往后翻,可以向上向下搜,不需一次加载整个文件,所以速度比more快,“less is more”, less比more更强大

    tail -200f test.log # 查看最后200行,根据文件描述符进行追踪,当文件改名或被删除,追踪停止
    tail -F test.log # 查看最后10行,只要对应文件名存在,就保持监视,即使文件被删除或改名后,如果再次创建相同的文件名,也会继续追踪

    grep abc test.log # 在文件中查找关键词”abc”,类似于 cat test.log|grep abc
    grep ^abc test.log # 在文件中查找以”abc”开始的词汇
    grep [0-9] test.log # 选择文件中所有包含数字的行
    grep abc -R /var/log/* # 在目录 ‘/var/log’ 及随后的目录中搜索字符串”abc”

    sed 's/abc/ccc/g' test.log # 将test.log文件中的 “abc” 替换成 “ccc”并打印,不改变原有文件
    sed '/^$/d' test.log # 从文件中删除所有空白行并打印,不改变原有文件

    paste test.log test2.log # 按两列合并两个文件每行的内容并打印,test.log在左边,test2.log在右边
    paste -d '+' file1 file2 # 合并两个文件每行的内容并打印,中间用”+”拼接

    sort test.log # 对文件内容进行排序,每行首字母排序
    sort test.log test2.log # 排序两个文件的内容
    sort test.log test2.log | uniq # 取出两个文件的并集(重复的行只保留一份)
    sort test.log test2.log | uniq -u # 删除交集,留下其他的行
    sort test.log test2.log | uniq -d # 取出两个文件的交集(同时存在于两个文件中的行)

    # comm 类似于集合的差集运算,需要两个文件都是排序的
    comm -1 test.log test2.log # 比较两个文件的内容只删除test.log所包含的内容
    comm -2 test.log test2.log # 比较两个文件的内容只删除test2.log所包含的内容
    comm -3 test.log test2.log # 比较两个文件的内容删除两个文件共有的内容

    权限相关

    chmod +x test.sh # 为一个文件增加可执行权限
    chmod ugo+rwx test.sh # 设置文件的所有者(u)、群组(g)以及其他人(o)读(r,4 )、写(w,2)和执行(x,1)的权限,+ 改为 - 即删除权限
    chmod 755 test.sh # 对文件所有者,群组,其他人分别设置7(rwx=4+2+1),5(rx=4+1),5(rx=4+1)的权限

    chown [-R] 用户名:群组名 test.log #改变一个文件的所有者和群组,如果是作用于文件夹下所有文件或目录,则加 -R
    chgrp 群组名 test.log # 改变文件的群组

     

    进程相关

    top # 实时显示系统中各个进程的资源占用状况
    top -H -p 进程号 # 列出进程的所有线程,按1键根据CPU占有率排序
    ps -ef|grep 进程名称 # 查看某个进程,一般用于找进程ID
    kill -9 进程ID # 停止某个进程
    jps # 查看所有java进程

     

    网络相关

    ifconfig # 查看系统各网卡信息(IP,mac地址,子网掩码等)
    ss -s # 查看当前系统tcp、udp连接数

    netstat -ano|grep 端口号 # 查看某个端口是否起来
    lsof -i:端口号 # 查看某个端口对应的进程信息,lsof可能需要额外安装 (sudo yum install lsof)

    ssh devuser@192.168.40.206 # 远程连接另一台linux主机

    curl http://www.baidu.com # get方式请求某个地址
    curl -i -X POST -H "Content-type:application/json" -d '{"a":"x","b":["y"]}' http://xxx# POST方式请求某个接口

    wget http://xxx.zip # 下载文件

    scp test.log devuser@192.168.40.206:/home/devuser/# 传输文件到另一台主机的目录下,如果是文件夹则加 -r

    # nc 传输,可用于文件传输(scp需要密码,nc不需要密码),需要安装 sudo yum install nc
    nc -l 1234 > test.log # 接收方,监听1234端口,将接收内容存于test.log
    nc 192.168.40.205 1234 < test.log # 发送方,向接收方(ip为192.168.40.205)发送test.log的内容

     

    系统相关

    top # 查看CPU、内存使用情况,即各进程使用情况
    free -g # 查看内存使用情况
    date # 查看系统当前时间
    uptime # 查看当前CPU使用负载情况,及系统已运行时间,相当于top的第一行
    su # 切换到root用户
    su devuser # 切换到devuser用户

    本文发表于微信公众号:“空山新雨的技术空间”

    作者:空山新雨
    欢迎关注,转发,推荐,你的支持是我持续创作的动力

  • 相关阅读:
    raw socket
    selenium and win32api
    linux ip
    network config
    grub paramiter & menu.list
    实用命令dd
    resin or tomcat .war e.g. note
    JSP 运行
    linux command screen
    docker interact example
  • 原文地址:https://www.cnblogs.com/spec-dog/p/11422093.html
Copyright © 2011-2022 走看看