Linux(Centos7.*)命令笔记
本文最后更新于 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 月

暂无评论

发送评论 编辑评论

|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
下一篇