本文采用的linux版本为CentOS 7
资料来源为 B站尚硅谷的linux教程

一,vim/vi 相关
1,一般模式,直接vim进入文件,在一般模式中可以进行删除、复制、粘贴等的动作,但是却无法编辑文件内容。可以进行以下操作

在这里插入图片描述
2,编辑模式,按下i, I, o, O, a, A等任何一个字母之后才会进入编辑模式,按esc键即可退出编辑模式

在这里插入图片描述
3,指令模式,一般模式当中,输入 : / ? 3个中的任何一个按钮,就可以将光标移动到最底下那 一行,进入指令模式。

在这里插入图片描述
常用操作

:wq 表示保存退出 
:q 不保存退出  
:q! 强行不保存退出  
:wq! 强行保存退出

网络

二、网络配置相关
1,ifconfig :显示所有网络接口的配置信息
2,ping ip :测试当前服务器是否可以连接目的主机
3,telnet ip port :测试当前服务器是否可以连接目标主机的某个端口
4,vim /etc/sysconfig/network-scripts/ifcfg-ens33 : 修改虚拟机ip,修改完后重启网络,service network restart
注意:

(1)物理机能 ping 通虚拟机,但是虚拟机 ping 不通物理机,一般都是因为物理机的 防火墙问题,把防火墙关闭就行 
(2)虚拟机能 Ping 通物理机,但是虚拟机 Ping 不通外网,一般都是因为 DNS 的设置有 问题
(3)虚拟机 Ping www.baidu.com 显示域名未知等信息,一般查看 GATEWAY 和 DNS 设 置是否正确 
(4)如果以上全部设置完还是不行,需要关闭 NetworkManager 服务 
		systemctl stop NetworkManager 关闭 
		systemctl disable NetworkManager 禁用 
(5)如果检查发现 systemctl status network 有问题 需要检查 ifcfg-ens33

5,hostname :查看当前服务器的主机名称

hostname :查看当前服务器的主机名称
vi /etc/hostname :修改主机名,修改完后需重启生效

6,vim /etc/hosts :修改hosts映射文件
三、系统管理
1,开启服务、停止服务、重启服务、查看服务状态

systemctl start | stop | restart | status 服务名 

2,systemctl 设置后台服务的自启配置

systemctl list-unit-files  :查看服务开机启动状态,按q退出查看
systemctl disable service_name  :关掉指定服务的自动启动
systemctl enable service_name  :开启指定服务的自动启动

常用命令

四,常用命令
1,help 命令 :获得 shell 内置命令的帮助信息,常用形式

help cd
ls --help

2,pwd :显示当前工作目录的绝对路径
3,常用快捷键

ctrl + c 停止进程
ctrl+l 清屏,等同于 clear;彻底清屏是:reset 
tab 键 提示(更重要的是可以防止敲错) 
上下键 查找执行过的命令

4,pwd :显示当前工作目录的绝对路径
5,ls 参数 目录或是文件 :列出目录内容

常用参数:
-a 全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用) 
-l 长数据串列出,包含文件的属性与权限等等数据;(常用)等价于“ll”
-h 以易于阅读的格式输出文件大小
常用组合:
ls -lh
更多精彩内容,请直接 ls --help 查看

6,cd 参数 :切换目录

常用参数:
cd 绝对路径 :切换路径 
cd 相对路径 :切换路径 
cd ~或者 cd :回到自己的家目录 
cd - :回到上一次所在目录 
cd .. :回到当前目录的上一级目录 
cd -P :跳转到实际物理路径,而非快捷方式路径

7,mkdir name :建立目录

常用参数:
-p 创建多层目录

mkdir -p a/b/c

8,rmdir name :移除目录
9,touch 文件名称 :创建空文件
10,cp 参数 源文件 目标文件 :复制文件

常用参数:
-r 递归复制整个文件夹

11,rm 参数 文件/目录 :删除文件或目录

常用参数
-r 递归删除目录中所有内容 
-f 强制执行删除操作,而不提示用于进行确认
-v 显示指令的详细执行过程

12,mv :移动文件与目录或重命名

常用语法:
(1)mv oldNameFile newNameFile  :重命名
(2)mv /temp/movefile /targetFolder  :移动文件

13,cat 文件名 :查看文件内容

常用参数:
-n 显示所有行的行号,包括空行。

13,more 文件名 :文件内容分屏查看器

常用操作:
空白键 (space) 代表向下翻一页;
Enter 代表向下翻『一行』; 
q 代表立刻离开 more ,不再显示该文件内容。 
Ctrl+F 向下滚动一屏
Ctrl+B 返回上一屏 
= 输出当前行的行号 
:f 输出文件名和当前行的行号

14,less 文件名 :分屏显示文件内容。它的功能与 more 指令类似,但是比 more 指令更加 强大,支持各种显示终端。less 指令在显示文件内容时,并不是一次将整个文件加载之后 才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

常用操作:
空白键 向下翻动一页;
[pagedown] 向下翻动一页 
[pageup] 向上翻动一页; 
/字串 向下搜寻『字串』的功能;n:向下查找;N:向上查找; 
?字串 向上搜寻『字串』的功能;n:向上查找;N:向下查找; 
q 离开 less 这个程序;

15,echo 参数 输出内容 :输出内容到控制台

常用参数:
-e: 支持反斜线控制的字符转换

16,head 参数 文件名 :显示文件头部内容

常用参数:
-n<行数> 指定显示头部内容的行数

head 文件 :查看文件头10行内容
head -n 5 文件 :查看文件头5行内容,5可以是任意行数

17,tail 参数 文件名 :输出文件尾部内容

常用参数:
-n<行数> 输出文件尾部 n 行内容 
-f 显示文件最新追加的内容,监视文件变化
常用操作:
(1)tail 文件 :查看文件尾部10行内容
(2)tail -n 5 文件 :查看文件尾部5行内容,5可以是任意行数
(3)tail -f 文件 :实时追踪该文档的所有更新

18,> 输出重定向和 >> 追加

> :输出重定向,会覆盖原文件内容
> > :追加,不会覆盖原文件内容

19,ln -s 原文件或目录 软链接名 :给原文件创建一个软链接

注意:
删除软链接: rm -rf 软链接名,而不是 rm -rf 软链接名/ 
如果使用 rm -rf 软链接名/ 删除,会把软链接对应的真实目录下内容删掉

20,history :查看已经执行过历史命令
21,date :显示当前时间

常用参数:
-d<时间字符串> 显示指定的“时间字符串”表示的时间,而非当前时间 
(1)date -d '1 days ago'  :显示前一天时间
(2)date -d '-1 days ago' :显示明天时间
-s<日期时间> 设置系统日期时间
(1)date -s "20220202 11:11:11"

基本语法:
(1)date :显示当前时间
(2)date +%Y :显示当前年份
(3)date +%m :显示当前月份
(4)date +%d :显示当前是哪一天
(5)date "+%Y-%m-%d %H:%M:%S" :显示年月日时分秒
常用组合:
date +%Y%m%d

22,cal 参数 :不加参数,显示本月日历

常用参数:
具体某一年 显示这一年的日历
cal 2022

用户管理

五,用户管理命令
1,useradd 添加新用户

常用操作:
useradd 用户名 :添加新用户
useradd -g 组名 用户名 :添加新用户到某个组

2,passwd 用户名 :设置用户密码
3,id 用户名 :查看用户是否存在

cat /etc/passwd 查看创建了哪些用户

4,su :切换用户

常用操作:
su 用户名称 :切换用户,只能获得用户的执行权限,不能获得环境变量
su - 用户名称 :切换到用户并获得该用户的环境变量及执行权限

5,userdel :删除用户

(1)userdel 用户名 :删除用户但保存用户主目录
(2)userdel -r 用户名 :用户和用户主目录,都删除
常用参数:
-r 删除用户的同时,删除与用户相关的所有文件

6,who :查看登录用户信息

(1)whoami :显示自身用户名称
(2)who am i :显示登录用户的用户名以及登陆时间

7,sudo :设置普通用户具有 root 权限

sudo配置:
vi /etc/sudoers
修改 /etc/sudoers 文件,找到下面一行(91 行),在 root 下面添加一行
username ALL=(ALL) ALL
或者配置成采用 sudo 命令时,不需要输入密码
username ALL=(ALL) NOPASSWD:ALL

8,usermod :修改用户

基本用法:
usermod -g 用户组 用户名
-g 修改用户的初始登录组,给定的组必须存在。默认组 id 是 1

用户组管理命令
groupadd 组名:新增组
groupdel  组名:删除组
groupmod -n 新组名 老组名 :修改组

cat /etc/group 查看创建了哪些组

9,文件权限类

在这里插入图片描述

如果没有权限,就会出现减号[ - ]而已。
从左至右用0-9这些数字来表示: 
(1)0 首位表示类型 在Linux中第一个字符代表这个文件是目录、文件或链接文件等等 
	- 代表文件 d 代表目录 l 链接文档(link file); 
(2)第1-3位确定属主(该文件的所有者)拥有该文件的权限。---User 
(3)第4-6位确定属组(所有者的同组用户)拥有该文件的权限,---Group 
(4)第7-9位确定其他用户拥有该文件的权限

(1)chmod 改变权限

推荐用法:
r=4 w=2 x=1 rwx=4+2+1=7
chmod 777 test.txt

(2)chown 改变所有者

chown 参数 用户 文件或目录 :改变文件或者目录的所有者
常用参数:
-R 递归操作

chown -R user:user test/

(3)chgrp 改变所属组

chgrp 用户组 文件或目录 :改变文件或者目录的所属组

查找

10,搜索查找类
(1)find 查找文件或者目录

语法:
find 搜索范围 参数
常用参数:
-name<查询方式> 按照指定的文件名查找模式查找文件 
-user<用户名> 查找属于指定用户名所有文件 
-size<文件大小> 按照指定的文件大小查找文件,单位为: 
	b —— 块(512 字节) 
	c —— 字节 w —— 字(2 字节) 
	k —— 千字节 
	M —— 兆字节 
	G —— 吉字节

find / -name test.txt

(2)locate 快速定位文件路径

语法:
locate 搜索文件
注意:
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令创 建 locate 数据库

(3)grep 过滤查找及“|”管道符。管道符表示将前一个命令的处理结果输出传递给后面的命令处理

语法:
grep 参数 查找内容 源文件
常用参数
-n 显示匹配行及行号
用法:
grep -n ts test.txt
ll |grep test*.txt
ps -ef|grep java

(4)wc 查看文件的换行数、字数、字节数

语法:
wc 参数 文件名
常用参数:
-c 输出字节数
-m 打印字符数
-l 打印换行计数
-L 显示最长行的长度
-w 显示单词计数
用法:
wc -l test.txt :查看文件多少行

11, 压缩和解压类
(1)gzip/gunzip 压缩

语法:
gzip 文件 :压缩文件,只能将文件压缩为*.gz 文件
gunzip 文件.gz :解压缩文件命令
注意:
(1)只能压缩文件不能压缩目录 
(2)不保留原来的文件 
(3)同时多个文件会产生多个压缩包

(2)zip/unzip 压缩

语法:
zip 参数 XXX.zip 文件(可以指定多个文件)或目录 :压缩文件和目录
参数:
-r 压缩目录
unzip 参数 XXX.zip :解压缩文件
参数:
-d<目录> 指定解压后文件的存放目录

(3)tar 打包、解包

用法:
tar 参数 XXX.tar.gz 文件(可以指定多个文件)或目录 :打包,压缩后的文件格式.tar.gz
常用参数:
-c 产生.tar 打包文件 
-v 显示详细信息 
-f 指定压缩后的文件名 
-z 打包同时压缩 
-x 解包.tar 文件 
-C 解压到指定目录
用法:
tar -zcvf all.tar.gz a.txt b.txt c.txt
tar -zxvf flink.tar.gz -C /user/local

磁盘

12,磁盘查看和分区类
(1)du 查看文件和目录占用的磁盘空间

语法:
du 参数 目录/文件 (功能描述:显示目录下每个子目录的磁盘使用情况)
常用参数:
-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示; 
-a 不仅查看子目录大小,还要包括文件 
-c 显示所有的文件和子目录大小后,显示总和 
-s 只显示总和 
--max-depth=n 指定统计子目录的深度为第 n 层
用法:
du -sh:查看当前用户主目录占用的磁盘空间大小

(2)df 查看磁盘空间使用情况

df 参数 :列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占用情况
常用参数:
-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;

(3)lsblk 查看设备挂载情况

lsblk 参数:查看设备挂载情况
常用参数:
-f 查看详细的设备挂载情况,显示文件系统信息

(4)查看磁盘 IO 读写情况

iotop -o :直接查看输出比较高的磁盘读写程序

进程管理

13,进程管理类
(1)ps 查看当前系统进程状态

常用语法:
ps aux | grep xxx :查看系统中所有进程 
	ps aux 显示信息说明 
		USER:该进程是由哪个用户产生的 
		PID:进程的 ID 号 
		%CPU:该进程占用 CPU 资源的百分比,占用越高,进程越耗费资源;
		%MEM:该进程占用物理内存的百分比,占用越高,进程越耗费资源;
		VSZ:该进程占用虚拟内存的大小,单位 KB;
		RSS:该进程占用实际物理内存的大小,单位 KB; 
		TTY:该进程是在哪个终端中运行的。对于 CentOS 来说,tty1 是图形化终端, tty2-tty6 是本地的字符界面终端。pts/0-255 代表虚拟终端。 
		STAT:进程状态。常见的状态有:
			R:运行状态、
			S:睡眠状态、
			T:暂停状态、 
			Z:僵尸状态、
			s:包含子进程、
			l:多线程、
			+:前台显示 
		START:该进程的启动时间
		TIME:该进程占用 CPU 的运算时间,注意不是系统时间 
		COMMAND:产生此进程的命令名
ps -ef | grep xxx :可以查看子父进程之间的关系
	ps -ef 显示信息说明 
		UID:用户 ID 
		PID:进程 ID 
		PPID:父进程 ID 
		C:CPU 用于计算执行优先级的因子。数值越大,表明进程是 CPU 密集型运算, 执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高 
		STIME:进程启动的时间 
		TTY:完整的终端名称 
		TIME:CPU 时间 
		CMD:启动进程所用的命令和参数
常用参数
a 列出带有终端的所有用户的进程 
x 列出当前用户的所有进程,包括没有终端的进程 
u 面向用户友好的显示风格 
-e 列出所有进程 
-u 列出某个用户关联的所有进程 
-f 显示完整格式的进程列表

(2)kill 终止进程

kill -9 进程号 :表示强迫进程立即停止

(3)pstree 查看进程树

pstree 参数
p 显示进程的 PID 
-u 显示进程的所属用户

(4)top 实时监控系统进程状态

top 参数
常用参数:
 -d 秒数 指定 top 命令每隔几秒更新。默认是 3 秒在 top 命令的交互模式当 中可以执行的命令:
 -i 使 top 不显示任何闲置或者僵死进程。 
 -p 通过指定监控进程 ID 来仅仅监控某个进程的状态。
操作说明:
 P 以 CPU 使用率排序,默认就是此项 
 M 以内存的使用率排序 
 N 以 PID 排序 
 q 退出 top
 
解释说明:
第一行信息为任务队列信息
	12:26:46 系统当前时间 
	up 1 day,13:32 系统的运行时间,本机已经运行 1 天 13 小时 32 分钟 
	2 users 当前登录了两个用户 
	load average: 0.00, 0.00, 0.00 系统在之前 1 分钟,5 分钟,15 分钟的平均负 载。一般认为小于 1 时,负载较小。如果大于 1,系统已经超出负荷。 
第二行为进程信息 
	95 total 系统中的进程总数 
	1 running 正在运行的进程数 
	94 sleeping 睡眠的进程 
	0 stopped 正在停止的进程 
	0 zombie 僵尸进程。如果不是 0,需要手工检查僵尸进程 
第三行为 CPU 信息 
	0.1%us 用户模式占用的 CPU 百分比 
	0.1%sy 系统模式占用的 CPU 百分比 
	0.0%ni 改变过优先级的用户进程占用的 CPU 百分比 
	99.7%id 空闲 CPU 的 CPU 百分比 
	0.1%wa 等待输入/输出的进程的占用 CPU 百分比 
	0.0%hi 硬中断请求服务占用的 CPU 百分比 
	0.1%si 软中断请求服务占用的 CPU 百分比
	0.0%st st(Steal time)虚拟时间百分比。就是当有虚拟 机时,虚拟 CPU 等待实际 CPU 的时间百分比。 
第四行为物理内存信息
	Mem: 625344k total 物理内存的总量,单位 KB 
	571504k used 已经使用的物理内存数量 
	53840k free 空闲的物理内存数量,我们使用的是虚拟机,总 共只分配了 628MB 内存,所以只有 53MB 的空 闲内存了 
	65800k buffers 作为缓冲的内存数量 
第五行为交换分区(swap)信息
	Swap: 524280k total 交换分区(虚拟内存)的总大小 
	0k used 已经使用的交互分区的大小 
	524280k free 空闲交换分区的大小 
	409280k cached 作为缓存的交互分区的大小

(5)netstat 显示网络状态和端口占用信息

netstat -anp | grep 进程号 :查看该进程网络信息
netstat –nlp | grep 端口号 :查看网络端口号占用情况
netstat -tunlp | grep 端口号:查看端口占用情况
netstat -ntp | grep xxxx :查看tcp的网络信息
	可以配合lsof使用,进行一些监控:
	查看那些服务与mysql建立了连接
	netstat -ntp | grep 192.168.217.11:3306
	查看建立连接的应用的信息
	lsof -i:端口号
	lsof相关介绍:https://blog.csdn.net/qq_27870421/article/details/92803453
参数:
-a 显示所有正在监听(listen)和未监听的套接字(socket) 
-n 拒绝显示别名,能显示数字的全部转化成数字 
-l 仅列出在监听的服务状态 
-p 表示显示哪个进程在调用
-t 表示查看tcp

14,crontab 系统定时任务
(1)crontab 服务管理

systemctl restart crond :重新启动 crond 服务

(2)crontab 定时任务设置

用法:
crontab 参数
常用参数:
-e 编辑 crontab 定时任务 
-l 查询 crontab 任务 
-r 删除当前用户所有的 crontab 任务
crontab表达式详解:
* * * * * 执行的任务
第一个“*” 一小时当中的第几分钟 0-59 
第二个“*” 一天当中的第几小时 0-23 
第三个“*” 一个月当中的第几天 1-31 
第四个“*” 一年当中的第几月 1-12 
第五个“*” 一周当中的星期几 0-7 ( 0 和 7 都 代 表 星 期 日)
特殊符号:
* 代表任何时间。比如第一个“*”就代表一小时中每分钟 都执行一次的意思。 
, 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表 在每天的 8 点 0 分,12 点 0 分,16 点 0 分都执行一次命令 
- 代表连续的时间范围。比如“0 5 * * 1-6 命令”,代表在 周一到周六的凌晨 5 点 0 分执行命令 
*/n 代表每隔多久执行一次。比如“*/10 * * * * 命令”,代 表每隔 10 分钟就执行一遍命令

实在不会写的,推荐大家个网站:https://www.bejson.com/othertools/cron/

六,软件包管理
1,RPM

rpm -qa  :查询所安装的所有 rpm 软件包
	例:rpm -qa |grep firefox
rpm -e  RPM软件包 :卸载软件包
	-e 卸载软件包 
	--nodeps 卸载软件时,不检查依赖。这样的话,那些使用该软件包的软件在此之后可能就不能正常工作了。
rpm -ivh RPM 包全名 :安装软件包
参数:
	-i install,安装 
	-v --verbose,显示详细信息 
	-h --hash,进度条 
	--nodeps 安装前不检查依赖

2,YUM

yum 选项 参数 软件名
选项:
	-y 对所有提问都回答“yes”
参数:
	install 安装 rpm 软件包 
	update 更新 rpm 软件包 
	check-update 检查是否有可用的更新 rpm 软件包 
	remove 删除指定的 rpm 软件包 
	list 显示软件包信息 
	clean 清理 yum 过期的缓存 
	deplist 显示 yum 软件包的所有依赖关系
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐