- 如何快速创建多个相同类型的文件
如创建名字为pudn1.py,pudn2.py到pudn100.py的批量文件。
touch pudn{1..100}.py
- 如何快速生成一个大文件
有时候需要在本机生成一个大文件,用于测试磁盘的读写能力,可以借助dd命令生成大文件。
dd if=/dev/zero of=/root/pudnlinux/test.txt bs=1M count=1024
上述命令,在/root/pudnlinux目录下生成一个文件名为test.txt 大小为 1G 的文件。
- 快速清空一个文件的方法,如清空pudn.py文件
cat /dev/null > pudn.py
或
echo -n "" > pudn.py
或
true > pudn.py
或
: > pudn.py
或
truncate -s 0 pudn.py
以上5种快速清空文件方法,大家可以选择自己常用的一种!
- 查找当前目录下名字为pudn.py的文件
find . -name pudn.py
- 查找当前目录下名字以.py结尾的文件
find . -name "*.py"
- 查找当前目录下名字以.py结尾的文件,并且指定为文件类型搜索
find . -type f -name "*.py"
- 查找当前目录下名字包含pudn的目录
find . -type d -name "pudn*"
- 查找当前目录下文件权限为755的对应文件
find . -type f -perm 755
- 查找当前目录下不具有755权限的所有文件
find . -type f ! -perm 755
- 查找当前目录下具有777权限的所有文件,并且将这些权限全部改为755
find . -type f -perm 777 -exec chmod 755 {} \;
- 查找当前目录下文件大小为100MB~1GB的所有文件
find . -type f -size +100M -size -1G
- 查找当前目录下以.py结尾的文件,并且删除
find . -name "*.py" -exec rm -rf {} \;
或
find . -name "*.py" | xargs rm -rf {};
或
rm -rf $(find . -name "*.py")
以上3种快速删除指定类别文件方法,你平时习惯用那一种呢?
- 查找当前目录下30天前修改过的所有文件
find . -mtime 30
- 查找当前目录下30天前访问过的所有文件
find . -atime 30
- 查找当前目录下过去1个小时内修改过的所有文件
find . -mmin -60
- 查找当前目录下过去1个小时内访问过的所有文件
find . -amin -60
- 查找当前目录下修改超过10天,但修改不到30天的所有文件
find . -mtime +10 -mtime -30
- 查找当前目录下7天前创建的,并且后缀名是以.py结尾的文件,并且进行删除
find . -mtime +7 -name "*.py" | xargs rm -rf {};
- 查找当前目录大于1000M的文件,并将该文件移动到/root/home目录下
find . -size +1000M -exec mv {} /root/home ;
- 查找当前目录下创建于30天前,大小大于1000M,以.py结尾的文件,并且进行删除
find . -name "*.py" –mtime +30 –type f –size +1000M |xargs rm –rf {};
- 查看有几个逻辑cpu, 包括cpu型号
cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c
- 查看有几颗cpu,每颗分别是几核
cat /proc/cpuinfo | grep physical | uniq -c
- 后台运行命令,如后台运行ping www.baidu.com命令
nohup ping www.baidu.com &
以上命令执行时后台运行,并且有nohup.out输出。
或
nohup ping www.baidu.com > /dev/null &
以上命令执行时后台运行, 不输出任何日志。
或
nohup ping www.baidu.com >out.log 2>&1 &
以上命令执行时后台运行, 并将错误信息做标准输出到日志中。
- 强制关闭进程名包含xxx的所有进程
ps aux|grep xxx | grep -v grep | awk '{print $2}' | xargs kill -9
- /var目录按照目录大小排序展示最前面20个目录或者文件
du -xB M --max-depth=2 /var | sort -rn | head -n 20
- 按照大到小排列出当前文件或者目录最大的10个
du -s * | sort -n | tail
- 查找当前系统内存使用量较高的进程(前20个)
ps -aux | sort -rnk 4 | head -20
可以看到输出的第 4 列就是内存的耗用百分比。最后一列就是相对应的进程。
- 查找当前系统CPU使用量较高的进程(前20个)
ps -aux | sort -rnk 3 | head -20
可以看到输出的第 3 列为 CPU 的耗用百分比,最后一列就是对应的进程。
- 后台持续 ping包, 并将结果记录到日志中;
ping www.baidu.com | awk '{ print $0 " " strftime("%Y-%m-%d %H:%M:%S",systime()) }' >> /root/pudnping.log &
以上命令实现后台每一秒自动ping www.baidu.com,并将结果记录到/root/pudnping.log文件中;
- 查找 80 端口请求数最高的前 15 个 IP
netstat -anlp|grep 80|grep tcp|awk '{print $5}' |awk -F: '{print $1}'|sort|uniq -c|sort -nr|head -n 15
- 查看自己本机系统最常用的10条命令
cat /root/.bash_history |grep -v ^# |awk '{print $1}' |sort |uniq -c |sort -nr |head -10
- 查看2022年12月11日09时这个时间内有多少个IP访问你的tomcat服务器
awk '{print $4,$1}' access.log | grep 11/Dec/2022:09 | awk '{print $2}'| sort | uniq | wc -l
这里只要给出访问日志文件,就可以计算出来,自己可以根据需要计算某个时间点的访问的IP数。
- 查看自己tomcat服务器访问量排在前20 位的IP地址
cat access.log|awk '{print $1}'|sort|uniq -c|sort -nr|head -20
- 查看某一个IP地址访问了tomcat服务器的哪些页面资源
grep ^192.168.30.200 access.log| awk '{print $1,$7}'
- 查看自己tomcat服务器中某一个页面资源被访问的次数
grep "/portal/index.html" access.log | wc -l
- 通过抓包工具tcpdump查看8080端口访问量情况
tcpdump -i ens33 -tnn dst port 8080 -c 1000 | awk -F"." '{print $1"."$2"."$3"."$4}' | sort | uniq -c | sort -nr |head -10
- 如何通过sed命令将文件test.py中的pudn全部替换成pudn
sed -i "s/pudn/pudn/g" test.py
- 替换pudn.py文件中的目录
sed -i "s:/etc/dhcp:/home:g" pudn.py
即表示将pudn.py文件中的/etc/dhcp目录替换成/home目录。
- 以下针对pudn.py文件举例sed命令常见技巧
- 去掉行首的#字符,命令为:
sed -i "s/^#//g" pudn.py
- 在行首添加linux字符,命令为:
sed -i "s/^/linux/g" pudn.py
- 在行尾添加一个study字符,命令为:
sed -i "s/$/study/" pudn.py
- 在特定行后,即we love行后添加一个you字符,命令为:
sed -i "/we love/ayou" pudn.py
- 在特定行前,即pudn行前添加一个where字符,命令为:
sed -i "/pudn/iwhere" pudn.py
- 针对网口ens33抓取不限制大小的报文,保存为文件pudn.cap
tcpdump -i ens33 -s 0 -w pudn.cap
- 针对网口ens33进行抓包,过滤出 icmp 报文并且源 IP 地址是 192.168.20.231的相关报文
tcpdump icmp and src 192.168.20.231 -i ens33 -n
- 针对网口ens33进行抓包,过滤出源 IP 地址是 192.168.20.231的相关报文
tcpdump src host 192.168.20.231 -i ens33 -n -c 5
- 针对网口ens33进行抓包,过滤出目的 IP 地址是 192.168.20.231的相关报文
tcpdump dst host 192.168.20.231 -i ens33 -n -c 5
- 针对网口ens33进行抓包,过滤出端口号是 8080 的相关报文
tcpdump port 8080 -i ens33 -n -c 5
- 针对网口ens33进行抓包,过滤出 80端口到443端口 的相关报文
tcpdump portrange 80-433 -i ens33 -n -c 8