您的位置:首页 > 运维架构 > Linux

前端应该掌握的linux命令和工具

2018-01-27 14:08 232 查看
大部分前端应用都部署在linux上,若想全局hold住一个项目,linux命令是一项必不可少的技能。许多前端对linux命令并不重视,其实这是一个学习性价比非常高的知识点,没有太多需要理解的地方,大部分靠“记忆+使用”即可掌握,掌握后可解决许多问题,也能提高日常效率,还能成为面试的加分项。

linux命令非常多,有时参数也挺复杂,全部学习挺枯燥,本文主要从实际的场景和问题出发,总结几条常用的命令,希望能对大家学习linux有所帮助。


查看文件

# 首先要学会查看文件属性
ls -l

# 目录递归的查询
ls -Rl




显示结果如上图。第一列十个字符,第一个表示文件类型(-为文件,d为目录,l为软链),后九位分三组,分别代表用户、用户组、其他用户对文件的的读(r)写(w)执行(x)权限;第二列表示文件数;第三列表示所属用户;第四列表示所属用户组;第五列表示文件大小;第六七八列分别表示文件最后修改的月、日、时间;最后一列为文件名。

查看文件内容有许多命令,如下:
# 查看一个文件的内容
cat a.txt

# cat支持多个文件连接显示,并可输出到文件
cat a.txt b.txt > c.txt

# tac就是cat反过来写,作用和cat相反,是从末尾开始向前显示
tac a.txt

# tail只显示文件的最后若干行,-n 指定显示的行数
tail test.log -n 100

# 实时显示内容,看日志时非常有用
tail test.log -f


修改文件所有者

# 同时修改用户和用户组
chown zhangsan:app

# 只修改用户
chown zhangsan

# 只修改用户组
chown :app


修改文件权限

# 权限主体有三种,用户(u)、用户组(g)、其他(o),权限有读(r)、写(w)、执行(x)三种
# +表示赋予权限,-表示回收权限
chmod ug+rw test.js # 给用户、用户组赋予读写权限

# 递归改变目录需加-R
chmod -R go-wx ./src # 回收用户组和其它的写和执行权限

# 数字表示法也比较常用。4:读,2:写,1:执行,其和可组合出所有权限。数字是三位数,对应三个主体,用户、用户组、其他。
chmod 751 test.js # 用户具备读写执行权限、用户组具备读和执行权限、其他用户具备执行权限


修改文件

linux下修改文件主要用vi或vim,vim是vi发展过来的,最基本的命令是一样的。vim编辑器命令非常强大,掌握最最基本的就可以解决问题了。
# 在编辑器里打开文件
vim test.txt


学习vim最重要的是掌握三种模式

普通模式:刚进入编辑器时为普通模式,普通模式下所有的输入都当作命令,立即执行且不在终端显示。一般esc可回到普通模式。

编辑模式:普通模式下按i进入编辑模式。编辑模式下可对内容进行修改。

命令模式:普通模式下输入“shift” + “:” 进入命令模式。命令模式下接受命令输入且显示在终端,回车生效。常见的命令有,q退出,q!强制退出,w保存,wq保存并退出。


搜索文件内容

# 第一个参数是一个正则表达式,第二个参数是一个文件
grep "html" src/index.html

# 在目录中搜索时需要加-R参数
grep -R "var" ./src

# 其他命令可以管道连接到grep命令进行结果筛选
ls -R ./src | grep ".test"


搜索文件名

# 列出src目录下的所有文件
find ./src

# 列出src目录下文件名为index.js的文件
find ./src -name index.js

# 通过正则过滤
find ./src | grep 'scss'


复制或移动文件

# 基本的文件复制
cp a.txt ./test/a.txt

# 复制目录时需加-R参数
cp -R ./src ../test/src

# 大多时候不需要文件copy,软链也是一种选择,能用软链就用软链,开销小
ln -s ./bin/run.js ~/.bin/run.js

# 移动一个文件
mv abc.txt ~/test/abc.txt


跨机器同步文件

# 将本地文件同步到远程机器,相对于cp命令,就多了一个ip而已
scp ./conf/nginx.conf 10.9.108.2:/opt/nginx/conf

# 反之从远程向本地同步亦可
10.9.108.2:/opt/nginx/conf/nginx.conf ./conf

# 需要ssh登录时,请加上用户名
scp ./conf/nginx.conf user@10.9.108.2:/opt/nginx/conf

# scp只能同步普通文件,rsync能同步文件夹,而且是增量同步
# -a表示保持文件的属性不变,-v显示进度信息,-z传输中进行压缩
rsync -avz logs/ 10.9.106.19:/data/users/mj/logs

# rsync同样支持方向同步
rsync -avz 10.9.106.19:/data/users/mj/logs ./logs


查看进程id

# 查出所有在内存中的进程,结果显示可看到到pid,用户,启动命令等信息,grep用作筛选
ps aux | grep node

# 杀进程
kill pid
# 强杀进程
kill -9 pid


查看端口占用

# -a显示所有选项,-p显示建立相关链接的程序名
# 显示出程序名之后就可使用前面的方法找到pid
netstat -ap | grep 9000


发个http请求

# -X 可设置请求方法,GET POST PUT DELTE ...,-i能打印返回头
curl 'http://cn.bing.com' -X GET -i

# -H 可设置请求头
curl 'http://cn.bing.com/' -H 'Customer-Header: helo'

# -d 可设置请求body
curl 'http://cn.bing.com/' -d 'a=1&b=2'


抓包

# -c表明抓多少个包就停止,可以缺省
# -i指定网络设备
# host 指定ip地址
# port 指定端口
# src|dst 限定host、port是源地址还是目标地址
# 可以通过逻辑运算符链接 and or not
# -w 可以把抓包结果写到文件
sudo tcpdump -c100 -i eth0 dst host 10.9.6.32 -w test.cap


对于http请求,tcpdump的可读性比较差。可以将抓包结果写到文件后,下载到本地用wireshark查看,一目了然。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: