本文最后更新于 288 天前,其中的信息可能已经有所发展或是发生改变,纠正错误请发送邮件到<baigeixiangcai@gmail.com>。
Centos搜索历史命令快捷键
Ctrl + Shift + R
文件与目录操作命令
命令 | 解析 |
---|---|
cd /home | 进入 ‘/home’ 目录 |
cd .. | 返回上一级目录 |
cd ../.. | 返回上两级目录 |
cd – | 返回上次所在目录 |
cp file1 file2 | 将file1复制为file2 |
cp -a dir1 dir2 | 复制一个目录 |
cp -a /tmp/dir1 . | 复制一个目录到当前工作目录(.代表当前目录) |
ls | 查看目录中的文件 |
ls -a | 显示隐藏文件 |
ls -l | 显示详细信息 |
ls -lrt | 按时间显示文件(l表示详细列表,r表示反向排序,t表示按时间排序) |
pwd | 显示当前工作路径 |
mkdir dir1 | 当前路径位置创建 ‘dir1’ 目录 |
mkdir dir1 dir2 | 当前路径位置同时创建两个目录 |
mkdir -p /tmp/dir1/dir2 | 创建一个目录树 |
mv dir1 dir2 | 移动/重命名一个目录 dir1为要移动的文件 dir2为要移动的目标位置 |
rm -f file1 | 删除 ‘file1’ |
rm -rf dir1 | 删除 ‘dir1’ 目录及其子目录内容 |
查看程序占用线程数
ps hH p [PID]|wc -l
例:
ps hH p 21918|wc -l
查看历史执行命令
history
修改文件目录访问权限
chmod 777 *
- u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个群体(group)者,o 表示其他以外的人,a 表示这三者皆是。
- + 表示增加权限、- 表示取消权限、= 表示唯一设定权限。
- r 表示可读取,w 表示可写入,x 表示可执行,X 表示只有当该文件是个子目录或者该文件已经被设定过为可执行。
查看系统进程
ps [options] [–help]
例:
ps -ef|grep java
参数 | 说明 |
---|---|
-A | 列出所有的行程 |
a | 显示现行终端机下的所有程序,包括其他用户的程序 |
-w | 显示加宽可以显示较多的资讯 |
-au | 显示较详细的资讯 |
-aux | 显示所有包含其他使用者的行程 |
c | 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示 |
-e | 此参数的效果和指定”A”参数相同。 例如: ps -e|grep sshd |
e | 列出程序时,显示每个程序所使用的环境变量 |
f | 用ASCII字符显示树状结构,表达程序间的相互关系 |
-H | 显示树状结构,表示程序间的相互关系。 |
-N | 显示所有的程序,除了执行ps指令终端机下的程序之外 |
-s | 采用程序信号的格式显示程序状况 |
S | 列出程序时,包括已中断的子程序资料 |
-t | 指定终端机编号,并列出属于该终端机的程序的状况,格式:ps -t<终端机编号> |
u | 以用户为主的格式来显示程序状况 |
x | 显示所有程序,不以终端机来区分 |
查找文件命令
列出当前目录及子目录下所有文件和文件夹
find .
在/home
目录下查找以.txt结尾的文件名
find /home -name "*.txt"
同上,但忽略大小写
find /home -iname "*.txt"
当前目录及子目录下查找所有以.txt和.pdf结尾的文件
find . \( -name "*.txt" -o -name "*.pdf" \)
或
find . -name "*.txt" -o -name "*.pdf"
匹配文件路径或者文件
find /usr/ -path "*local*"
基于正则表达式匹配文件路径
find . -regex ".*\(\.txt\|\.pdf\)
同上,但忽略大小写
find . -iregex ".*\(\.txt\|\.pdf\)
否定参数,找出/home下不是以.txt结尾的文件
find /home ! -name "*.txt"
根据文件类型进行搜索
find . -type 类型参数
类型参数列表:
- f 普通文件
- l 符号连接
- d 目录
- c 字符设备
- b 块设备
- s 套接字
- p Fifo
基于目录深度搜索
向下最大深度限制为3
find . -maxdepth 3 -type f
搜索出深度距离当前目录至少2个子目录的所有文件
find . -mindepth 2 -type f
根据文件时间戳进行搜索
find . -type f 时间戳
UNIX/Linux文件系统每个文件都有三种时间戳:
- 访问时间(-atime/天,-amin/分钟):用户最近一次访问时间。
- 修改时间(-mtime/天,-mmin/分钟):文件最后一次修改时间。
- 变化时间(-ctime/天,-cmin/分钟):文件数据元(例如权限等)最后一次修改时间。
搜索最近七天内被访问过的所有文件
find . -type f -atime -7
搜索恰好在七天前被访问过的所有文件
find . -type f -atime 7
搜索超过七天内被访问过的所有文件
find . -type f -atime +7
搜索访问时间超过10分钟的所有文件
find . -type f -amin +10
找出比file.log修改时间更长的所有文件
find . -type f -newer file.log
根据文件大小进行匹配
find . -type f -size 文件大小单元
文件大小单元:
- b —— 块(512字节)
- c —— 字节
- w —— 字(2字节)
- k —— 千字节
- M —— 兆字节
- G —— 吉字节
搜索大于10KB的文件
find . -type f -size +10k
搜索小于10KB的文件
find . -type f -size -10k
搜索等于10KB的文件
find . -type f -size 10k
删除匹配文件
删除当前目录下所有.txt文件
find . -type f -name "*.txt" -delete
根据文件权限/所有权进行匹配
当前目录下搜索出权限为777的文件
find . -type f -perm 777
找出当前目录下权限不是644的php文件
find . -type f -name "*.php" ! -perm 644
找出当前目录用户tom拥有的所有文件
find . -type f -user tom
找出当前目录用户组sunk拥有的所有文件
find . -type f -group sunk
借助-exec
选项与其他命令结合使用
找出当前目录下所有root的文件,并把所有权更改为用户tom
find .-type f -user root -exec chown tom {} \;
上例中,用于与-exec选项结合使用来匹配所有文件,然后会被替换为相应的文件名。
找出自己家目录下所有的.txt文件并删除
find $HOME/. -name "*.txt" -ok rm {} \;
上例中,-ok和-exec行为一样,不过它会给出提示,是否执行相应的操作。
查找当前目录下所有.txt文件并把他们拼接起来写入到all.txt文件中
find . -type f -name "*.txt" -exec cat {} \;> all.txt
将30天前的.log文件移动到old目录中
find . -type f -mtime +30 -name "*.log" -exec cp {} old \;
找出当前目录下所有.txt文件并以“File:文件名”的形式打印出来
find . -type f -name "*.txt" -exec printf "File: %s\n" {} \;
因为单行命令中-exec参数中无法使用多个命令,以下方法可以实现在-exec之后接受多条命令
-exec ./text.sh {} \;
搜索但跳出指定的目录
查找当前目录或者子目录下所有.txt文件,但是跳过子目录sk
find . -path "./sk" -prune -o -name "*.txt" -print
find其他技巧收集
要列出所有长度为零的文件
find . -empty
获取线程dump日志
jstack -l [PID] >> dumpFile.txt
通过jstatd远程监控jvm(centos开启jstatd)
1. 修改JAVA_HOME/jre/lib/security/java.policy
在最后一行添加:permission java.security.AllPermission;
2.启动jstatd,注意修改端口和ip,端口默认为1099,ip指定为本机外网ip或远程连接的ip
rmiregistry 2020 &jstatd -J-Djava.security.policy=all.policy -p 1099 -J-Djava.rmi.server.hostname=192.168.1.1 &
3. 通过命令查看jstatd是否开启(开启会监听一个你配置或系统默认的端口(1099),还有一个随机生成的端口);别忘了在防火墙开放监听的两个端口;**
netstat -anp | grep jstatd
4. 在客户端通过jvisualvm.exe链接,右键远程->添加远程主机->输入上面的ip即可
tar 命令
参数:
- -A或–catenate 新增文件到已存在的备份文件。
- -b<区块数目>或–blocking-factor=<区块数目> 设置每笔记录的区块数目,每个区块大小为12Bytes。
- -B或–read-full-records 读取数据时重设区块大小。
- -c或–create 建立新的备份文件。
- -C<目的目录>或–directory=<目的目录> 切换到指定的目录。
- -d或–diff或–compare 对比备份文件内和文件系统上的文件的差异。
- -f<备份文件>或–file=<备份文件> 指定备份文件。
- -F<Script文件>或–info-script=<Script文件> 每次更换磁带时,就执行指定的Script文件。
- -g或–listed-incremental 处理GNU格式的大量备份。
- -G或–incremental 处理旧的GNU格式的大量备份。
- -h或–dereference 不建立符号连接,直接复制该连接所指向的原始文件。
- -i或–ignore-zeros 忽略备份文件中的0 Byte区块,也就是EOF。
- -k或–keep-old-files 解开备份文件时,不覆盖已有的文件。
- -K<文件>或–starting-file=<文件> 从指定的文件开始还原。
- -l或–one-file-system 复制的文件或目录存放的文件系统,必须与tar指令执行时所处的文件系统相同,否则不予复制。
- -L<媒体容量>或-tape-length=<媒体容量> 设置存放每体的容量,单位以1024 Bytes计算。
- -m或–modification-time 还原文件时,不变更文件的更改时间。
- -M或–multi-volume 在建立,还原备份文件或列出其中的内容时,采用多卷册模式。
- -N<日期格式>或–newer=<日期时间> 只将较指定日期更新的文件保存到备份文件里。
- -o或–old-archive或–portability 将资料写入备份文件时使用V7格式。
- -O或–stdout 把从备份文件里还原的文件输出到标准输出设备。
- -p或–same-permissions 用原来的文件权限还原文件。
- -P或–absolute-names 文件名使用绝对名称,不移除文件名称前的”/”号。
- -r或–append 新增文件到已存在的备份文件的结尾部分。
- -R或–block-number 列出每个信息在备份文件中的区块编号。
- -s或–same-order 还原文件的顺序和备份文件内的存放顺序相同。
- -S或–sparse 倘若一个文件内含大量的连续0字节,则将此文件存成稀疏文件。
- -t或–list 列出备份文件的内容。
- -T<范本文件>或–files-from=<范本文件> 指定范本文件,其内含有一个或多个范本样式,让tar解开或建立符合设置条件的文件。
- -u或–update 仅置换较备份文件内的文件更新的文件。
- -U或–unlink-first 解开压缩文件还原文件之前,先解除文件的连接。
- -v或–verbose 显示指令执行过程。
- -V<卷册名称>或–label=<卷册名称> 建立使用指定的卷册名称的备份文件。
- -w或–interactive 遭遇问题时先询问用户。
- -W或–verify 写入备份文件后,确认文件正确无误。
- -x或–extract或–get 从备份文件中还原文件。
- -X<范本文件>或–exclude-from=<范本文件> 指定范本文件,其内含有一个或多个范本样式,让ar排除符合设置条件的文件。
- -z或–gzip或–ungzip 通过gzip指令处理备份文件。
- -Z或–compress或–uncompress 通过compress指令处理备份文件。
- -<设备编号><存储密度> 设置备份用的外围设备编号及存放数据的密度。
- –after-date=<日期时间> 此参数的效果和指定”-N”参数相同。
- –atime-preserve 不变更文件的存取时间。
- –backup=<备份方式>或–backup 移除文件前先进行备份。
- –checkpoint 读取备份文件时列出目录名称。
- –concatenate 此参数的效果和指定”-A”参数相同。
- –confirmation 此参数的效果和指定”-w”参数相同。
- –delete 从备份文件中删除指定的文件。
- –exclude=<范本样式> 排除符合范本样式的文件。
- –group=<群组名称> 把加入设备文件中的文件的所属群组设成指定的群组。
- –help 在线帮助。
- –ignore-failed-read 忽略数据读取错误,不中断程序的执行。
- –new-volume-script=<Script文件> 此参数的效果和指定”-F”参数相同。
- –newer-mtime 只保存更改过的文件。
- –no-recursion 不做递归处理,也就是指定目录下的所有文件及子目录不予处理。
- –null 从null设备读取文件名称。
- –numeric-owner 以用户识别码及群组识别码取代用户名称和群组名称。
- –owner=<用户名称> 把加入备份文件中的文件的拥有者设成指定的用户。
- –posix 将数据写入备份文件时使用POSIX格式。
- –preserve 此参数的效果和指定”-ps”参数相同。
- –preserve-order 此参数的效果和指定”-A”参数相同。
- –preserve-permissions 此参数的效果和指定”-p”参数相同。
- –record-size=<区块数目> 此参数的效果和指定”-b”参数相同。
- –recursive-unlink 解开压缩文件还原目录之前,先解除整个目录下所有文件的连接。
- –remove-files 文件加入备份文件后,就将其删除。
- –rsh-command=<执行指令> 设置要在远端主机上执行的指令,以取代rsh指令。
- –same-owner 尝试以相同的文件拥有者还原文件。
- –suffix=<备份字尾字符串> 移除文件前先行备份。
- –totals 备份文件建立后,列出文件大小。
- –use-compress-program=<执行指令> 通过指定的指令处理备份文件。
- –version 显示版本信息。
- –volno-file=<编号文件> 使用指定文件内的编号取代预设的卷册编号。
压缩文件 非打包
tar -czvf test.tar.gz a.c //压缩 a.c文件为test.tar.gz
压缩文件
tar -tzvf test.tar.gz
解压文件
tar -xzvf test.tar.gz
iostat
iostat -x -k -d 1
选项 | 说明 |
---|---|
rrqm/s | 每秒对该设备的读请求被合并次数,文件系统会对读取同块(block)的请求进行合并 |
wrqm/s | 每秒对该设备的写请求被合并次数 |
r/s | 每秒完成的读次数 |
w/s | 每秒完成的写次数 |
rkB/s | 每秒读数据量(kB为单位) |
wkB/s | 每秒写数据量(kB为单位) |
avgrq-sz | 平均每次IO操作的数据量(扇区数为单位) |
avgqu-sz | 平均等待处理的IO请求队列长度 |
await | 平均每次IO请求等待时间(包括等待时间和处理时间,毫秒为单位) |
svctm | 平均每次IO请求的处理时间(毫秒为单位) |
%util | 采用周期内用于IO操作的时间比率,即IO队列非空的时间比率 |
查看TIME_WAIT数量
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
运行jar
java -jar xxl-job-executor-sample-springboot-2.4.0-SNAPSHOT.jar
nohup 后台执行
nohup [脚本或者命令] > [写入日志文件名称] 2>&1 &
nohup java -jar xxl-job-executor-sample-springboot-2.4.0-SNAPSHOT.jar > xxl-executor.log 2>&1 &
显示有关 CPU 架构的信息
lscpu
查看防火墙状态
systemctl status firewalld
关闭防护墙
systemctl stop firewalld
禁用防火墙
systemctl disable firewalld
安装netstat
yum install net-tools
scp命令使用
拷贝远程机器的文件
scp root@192.168.19.132:/root/test.txt /root
拷贝远程机器整个文件夹
scp -r root@192.168.19.132:/root/test/ /root/
指定端口号
scp -P 222 root@192.168.19.132:/root/test/ /root/
本地文件夹拷贝到远程机器
scp -r /root/test/ root@192.168.19.132:/root/test/
释放内存
# 释放 pagecache
echo 1 > /proc/sys/vm/drop_caches
# 释放 dentries and inodes
echo 2 > /proc/sys/vm/drop_caches
# 释放 pagecache, dentries and inodes
echo 3 > /proc/sys/vm/drop_caches
watch重复执行命令
watch
命令在 Linux 系统中用于周期性地执行给定的命令并显示输出。它的基本语法如下:
watch [options] command
其中 options
是一些参数,command
是你想要观察的命令。
下面是一些常用的 watch
命令选项:
- -n, –interval seconds: 指定刷新间隔的秒数。默认为2秒。
- -d, –differences: 高亮显示命令输出的变化部分。
- -t, –no-title: 隐藏顶部的标题行,只显示命令输出。
- -h, –help: 显示帮助信息。
例如,要每秒执行一次 ls -l
并显示输出,可以使用以下命令:
watch -n 1 ls -l
如果你想查看日志文件的实时变化,可以使用 tail
命令结合 watch
。例如:
watch -n 1 tail /var/log/syslog
在 watch
的显示界面中,你可以看到命令的输出,并且它会每隔一定时间刷新一次,显示命令的最新输出。按下 Ctrl+C
可以退出 watch
。
watch
对于监视命令的实时输出和变化非常有用,特别是在需要持续观察某些命令执行结果时。
Last Updated on 2024 31 1 月