开发人员需要掌握的日常Linux命令集

2019-08-28 09:37:01

本文整理了开发人员日常用到的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\ncba'> 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用户

 


  • 2019-01-23 20:56:57

    YouTube视频爬虫-批量采集-低成本解决方案-技术难点和细节回顾

    对于我们这些国内玩家而言,实现youtube视频爬虫和批量采集有先天性的遗憾。起初,公司需要一大批的youtube视频,时长3分钟左右,720p下载的话,每视频30-50M左右。公司雇了一大批人,采购科学上网神器手工下载 ,无奈,效率之低令人发指。所以老板要我做爬虫自动采集,需求每天下载2000+个视频,视频存储需要提高国内访问速度,方便合作方的程序抓取我们的内容。 --------------------- 作者:ucsheep 来源:CSDN 原文:https://blog.csdn.net/ucsheep/article/details/81380342 版权声明:本文为博主原创文章,转载请附上博文链接!

  • 2019-01-24 16:11:39

    数据库去除重复记录

    如何删除数据库中重复的记录 一般情况下,数据库去重复有以下那么三种方法:

  • 2019-01-26 10:12:40

    一行代码让webview不加载图片

    最近项目中需要控制列表页和详情页图片资源的显示,列表页比较好做,详情页是用WebView来展示的,不太好控制图片资源的加载。在Google上找到了两个解决办法,跟大家分享一下!