常用linux命令

grep

grep [-acinv] [--color=auto] '搜寻字符串' filename 选项与参数:

  • -a :将 binary 文件以 text 文件的方式搜寻数据
  • -c :计算找到 '搜寻字符串' 的次数
  • -i :忽略大小写的不同,所以大小写视为相同
  • -n :顺便输出行号
  • -v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
  • --color=auto :可以将找到的关键词部分加上颜色的显示喔!

awk

awk '{pattern + action}' {filenames}

sed

sed [-nefr] [动作]

选项与参数:

  • -n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
  • -e :直接在命令列模式上进行 sed 的动作编辑;
  • -f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
  • -r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
  • -i :直接修改读取的文件内容,而不是输出到终端。动作说明: [n1[,n2]]function
  • n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』function:
  • a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
  • c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
  • d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
  • i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
  • p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
  • s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!

lsof

默认 : 没有选项,lsof列出活跃进程的所有打开文件 组合 : 可以将选项组合到一起,如-abc,但要当心哪些选项需要参数

  • -a : 结果进行“与”运算(而不是“或”)
  • -l : 在输出显示用户ID而不是用户名
  • -t : 仅获取进程ID
  • -U : 获取UNIX套接口地址
  • -F : 格式化输出结果,用于其它命令。可以通过多种方式格式化,如-F pcfn(用于进程id、命令名、文件描述符、文件名,并以空终止)

curl

调试类

  • -v, --verbose 输出信息
  • -q, --disable 在第一个参数位置设置后 .curlrc 的设置直接失效,这个参数会影响到 -K, --config -A, --user-agent -e, --referer
  • -K, --config FILE 指定配置文件
  • -L, --location 跟踪重定向 (H)

CLI显示设置

  • -s, --silent Silent模式。不输出任务内容
  • -S, --show-error 显示错误. 在选项 -s 中,当 curl 出现错误时将显示
  • -f, --fail 不显示 连接失败时HTTP错误信息
  • -i, --include 显示 response的header (H/F)
  • -I, --head 仅显示 响应文档头
  • -l, --list-only 只列出FTP目录的名称 (F)
  • -#, --progress-bar 以进度条 显示传输进度

数据传输类

  • -X, --request [GET|POST|PUT|DELETE|…] 使用指定的 http method 例如 -X POST
  • -H, --header
    设定 request里的header 例如 -H "Content-Type: application/json"
  • -e, --referer 设定 referer (H)
  • -d, --data 设定 http body 默认使用 content-type application/x-www-form-urlencoded (H)
    --data-raw ASCII 编码 HTTP POST 数据 (H)
    --data-binary binary 编码 HTTP POST 数据 (H)
    --data-urlencode url 编码 HTTP POST 数据 (H)
  • -G, --get 使用 HTTP GET 方法发送 -d 数据 (H)
  • -F, --form <name=string> 模拟 HTTP 表单数据提交 multipart POST (H)
    --form-string <name=string> 模拟 HTTP 表单数据提交 (H)
  • -u, --user user:password 使用帐户,密码 例如 admin:password
  • -b, --cookie cookie 文件 (H)
  • -j, --junk-session-cookies 读取文件中但忽略会话cookie (H)
  • -A, --user-agent user-agent设置 (H)

传输设置

  • -C, --continue-at OFFSET 断点续转
  • -x, --proxy [PROTOCOL://]HOST[:PORT] 在指定的端口上使用代理
  • -U, --proxy-user USER[:PASSWORD] 代理用户名及密码

文件操作

  • -T, --upload-file 上传文件
  • -a, --append 添加要上传的文件 (F/SFTP)

输出设置

  • -o, --output 将输出写入文件,而非 stdout
  • -O, --remote-name 将输出写入远程文件
  • -D, --dump-header 将头信息写入指定的文件
  • -c, --cookie-jar 操作结束后,要写入 Cookies 的文件位置
wget

文件参数

  • -o,--output-file=FILE 将软件输出信息保存到文件;
  • -a,--append-output=FILE将软件输出信息追加到文件;
  • -d,--debug显示输出信息;
  • -q,--quiet 不显示输出信息;
  • -i,--input-file=FILE 从文件中取得URL;

下载参数

  • -t,--tries=NUMBER 是否下载次数(0表示无穷次)
  • -O --output-document=FILE 指定下载目录和文件名
  • -nc, --no-clobber 不要覆盖已经存在的文件
  • -N,--timestamping只下载比本地新的文件
  • -T,--timeout=SECONDS 设置超时时间
  • -Y,--proxy=on/off 关闭代理

tail

  • tail -n flilename 查看文件的最后几行
  • tail -f filename 实时监控文件的更新内容
  • tail -f -s 间隔一定时间查看文件的更新

head

head 默认 显示前10行,head -n 显示文件的前n行 head -n -line除了line行之外显示

less

分页显示 -g 只标志最后搜素的关键词 -i 搜索是忽略大小写 -m显示类似more的百分比 -N显示每行行号

find

find [参数] [路径] [查找和搜索范围] -name 按名称查找 -size 按大小查找 -user 按属性查找 -type 按类型查找 -iname 忽略大小写

kill

kill [参数][进程号pid]

  • -l 列出系统支持的信号

常用信号如下:

  • HUP 1 终端断线
  • INT 2 中断(同 Ctrl + C)
  • QUIT 3 退出(同 Ctrl + \)
  • TERM 15 终止
  • KILL 9 强制终止
  • CONT 18 继续(与STOP相反, fg/bg命令)
  • STOP 19 暂停(同 Ctrl + Z)
  • -s指定向进程发送信号
  • -a 处理当前进程时不限制命令名和进程号的对应关系
  • -p 指定kill命令只打印相关进程的进程号,而不发送任何信号

正则表达式

  • ^ 表示以什么开头,^bqh 以bqh开头
  • $ 是以什么结尾
  • ^$ 表示空行。
  • \ 例. 就只代表点本身,转义符号,让有着特殊身份移动的字符,脱掉马甲,还原原型$
  • ^.* 以任意多个字符开头。
  • .*$ 以任意多个字符结尾。
  • (.*) 从第一字符匹配,到空格停止,
  • [abc] 匹配字符集合内的任意一个字符【a-zA-Z】
  • [^abc] 匹配不包括^后的任意字符的内容;中括号里的^为取反,注意和以...开头区别。
  • a{n,m} 重复n到m次,前一个重复的字符。如果有用egrep/sed -r 可以去掉斜线。
  • {n,} 重复至少n次,前一个重复的字符。如果有用egrep/sed -r 可以去掉斜线。
  • {n} 重复n次,前一个重复的字符。如果有用egrep/sed -r 可以去掉斜线。
  • ①^word 搜索以word开头的;vi ^ 一行的开够
  • ②word搜索以word结尾的;vi 搜索以word结尾的;vi搜索以word结尾的;vi 一行的开头
  • ③^$ 表示空行。

扩展的正则表达式:ERP(egrep或grep -E)

    • 重复一个或一个以上前面的字符
  • ? 复0个或一个0前面的字符
  • | 用或的方式查找多个符合的字符串
  • () 找出“用户组”字符串
上一篇:how to design a good api and why it matters


下一篇:451 Research分析:OpenStack云的今天和明天