Linux大全
1、虚拟机安装
VMware15.5安装,傻瓜式安装,只记录变动步骤,其余都下一步,软件安装位置自己选择,最好别选c盘,软件地址https://www.nocmd.com/windows/740.html(内含激活码),安装时需要注意它文件不会在一个文件夹下,自己多建一个版本文件夹,方便管理。
文件》新建虚拟机
点击安装计算机的设置》选择镜像后》点确定
开启虚拟机》选第一个install centos7
等待一段时间不要乱点,乱点会卡死,》软件选择》最小安装或gui服务器或gnome桌面,选好后点完成。开发中一般都选最小安装,需要什么软件在自行选择,但其它安装可以省略jdk,mysql等安装,会自行安装。
在这一步也可以选择自动配置分区,这里更快,这里我选择我要配置分区。
设置好/boot要1G,swap要2G,剩余都在根目录分区大小后,设备类型点标准分区,点完成。
点接受更改
网络和主机名设置,需要联网就打开以太网。
最后一个像一把锁的安检策略可以关闭。
点开始安装
在这个页面配置root账号密码,创建用户账号密码。在实际开发中root账号要复杂点,避免被破解。
等待完成后,点击重启。
再把网络连接打开。
2、虚拟机网络连接方式
1、桥接模式:同一网段中,最多只能连接255台机子,一旦超出容易造成IP冲突。IP地址的前3位就是网段(192.168.0.1)。
2、NAT(网络地址装换)模式:虚拟机和外部通信,不会造成IP冲突。虚拟机地址不再是以0开头,而是生成1-255之间的数,如192.168.6.1,然后主机会生成一个对应的虚拟网卡如192.168.6.6,两者能通信。这种模式下虚拟机能访问192.168.0.1,由于网段不同,192.168.0.1不能访问虚拟机。
3、主机模式:虚拟网络对主机可见,虚拟机不能上网。
3、安装vmtools
vmtools工具是实现虚拟机和主机文件进行共享,两个地方都能修改同一文件。安装步骤如下
1、右击虚拟机 install vmware tools
2、双击VMware Tools,复制XXX.tar.gz压缩包到/opt目录下
3、桌面上打开终端,
cd /opt
,进入到opt目录下,使用解压命令
tar -zxvf
VM+tab键提示自动补全名称, 得到一个解压文件夹
4、进入该vm解压的目录
cd vmxxx
,/opt目录下
5、安装
./vmware-install.pl
6、全部使用默认设置即可,一直按回车,就可以安装成功
注意:安装vmtools需有gcc ,可以使用
gcc -v
查看gcc版本
共享文件夹设置
点虚拟机设置》选项》共享文件夹》总是启用》添加》指定文件夹
4、虚拟机目录
4.1、目录含义
/bin :存放着最经常使用的命令
/home :存放普通用户的主目录,一般该目录名是以用户的账号命名
/root :该目录为系统管理员,也称作超级权限者的用户主目录(根目录)
/boot:Linux启动相关文件
/lib:系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。
/lost+ found这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件
/etc:系统管理所需配置和子文件目录
/user:用户应用程序和文件
/proc[不能动]:是虚拟目录,系统内存映射,访问这个目录获取系统信息
/srv[不能动]:存放服务启动后所需数据
/sys[不能动]:该目录安装了2.6内核新出现的文件系统
/tmp:存放临时文件
/mnt:存放挂载文件
/opt:给主机额外安装软件的目录,即软件存放目录
/user/local:软件安装后的目标目录,一般是编译源码的方式安装的程序
4.2、Linux颜色含义
蓝色表示目录,白色表示文件,红色表示压缩文件,绿色表示可执行权限
5、远程登录软件
XShell和XFTP下载地址:网站一
网站二推荐
虚拟机终端输入
ifconfig
,找到虚拟机地址,如果找不到ip地址就重新设置网络,编辑》虚拟网络编辑器》更改设置》还原默认设置。
6、编辑命令
vi、vim都是编辑命令,vim是vi的增强版,它们有三种模式,一般模式,编辑模式(能输入内容),命令模式。
一般模式:输入的内容看不见
编辑模式:可以自由输入内容,可见
命令模式:在文件末尾位置,可见
命令模式》一般模式:
vim
或
vi
一般模式》编辑模式:
i
、
o
、
a
、
r
等按键
编辑模式》一般模式:
esc
一般模式》命令模式:
:
,
/
:wq
:保存退出
:q
:不保存退出
:q!
:强制退出
自动补全文件名:tab
拷贝当前行(一般模式):
yy
,并粘贴输入
p
拷贝当前行向下的
i
行:
iyy
。
删除当前行:
dd
删除当前行向下的
i
行
idd
在文件中查找某个单词(命令模式)敲
/
,回车查找,输入n就是查找下一个
设置文件的行号(:进入命令模式):命令行下
set nu
取消文件的行号:
set nonu
使用快捷键到该文档的最末行[
G
]和最首行[
gg
](一般模式下)
在一个文件中输入"hello"然后又撤销这个动作,一般模式下按
u
立即关机:
shutdown -h now
一分钟后关机:
shutdown -h 1
重启计算机:
reboot
获取帮助信息:man 【命令或配置文件】(按空格显示更多帮助信息)
获取内置命令帮助信息:help 命令
7、用户管理
切换用户:su - 用户名
权限高的用户切换到低权限用户不需要输入密码,反之需要。返回原来用户时,
exit
或
logout
添加用户:useradd 用户名
给用户指定密码:passwd 用户名
显示当前用户所在目录:pwd
删除用户(保留家目录):userdel 用户名
删除用户(删除包括家目录):userdel -r 用户名
查询用户信息:id 用户名
查看当前登录用户:who am i
用户组:系统对有权限的用户同一管理
新增组:groupadd 组名
删除组:groupdel 组名
新增用户直接分组:useradd -g 用户组 用户名
修改用户组:usermod -g 用户组 用户名
8、CentOS7找回root密码
1、启动系统,进入开机页面,按
e
键进入编辑页面
2、光标向下移动,找到以“Linux16”开头的行数,行末输入
init=/bin/sh
,接着按
ctr+x
进入单用户模式。
3、在光标闪烁位置输入:mount -o remount,rw /,完成后回车
4、接着输入passwd,完成后回车,输入密码后回车,再次输入密码。修改成功后会显示passwd……
5、接着在光标位置输入:touch /.autorelabel,完成后回车,等待系统重启,新密码就生效了。
9、文件目录指令
pwd指令
显示当前目录的绝对路径
ls指令
查看当前目录的所有内容信息:ls 【选项】【目录或文件】
常用选项有:
-a ,查看所有文件和目录包括隐藏文件
-l,以列表形式显示信息
cd指令
切换目录:cd 【参数】
cd~
或
cd:
回到自个家目录
返回当前目录的上一级目录:
cd ..
mkdir指令
创建一个目录:mkdir 创建的目录
创建多个目录:mkdir -p /test/one
rmdir指令
删除一级目录:rmdir 删除的空目录
如果删除的目录下有内容,非得删除的话使用:rm -rf 要删除的目录
touch指令
创建空文件:touch 文件名称
cp指令
cp 【选项】 源文件 目标文件
选项:-r 递归复制整个文件夹
强制覆盖不提示方法:\cp cp -r src dest
rm指令
移除文件或目录:rm 【选项】要删除的文件或目录
常用选项:
递归删除文件夹:-r
强制删除不提示:-f
mv指令
用于移动文件与目录或重命名
两个文件同一目录会重命名:mv 旧文件名 新文件名
两文件不同目录会移动:mv 要移动的文件 移动到的位置
cat指令
查看文件内容:cat 【选项】要查看的文件
常用选项:
显示行号:-n
cat只能浏览,不能修改,为浏览方便,一般会带上 管道命令
|
(|是或符号不是大写i,表示前一个指令结果交给后面的指令处理):
|more
例:cat -n /etc/profile | more
more指令
操作功能空格翻页回车向下一行ctr+f向下滚动一屏ctr+b返回上一屏=输出当前行号:f输出文件名和当前行
less指令
less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。
分屏查看文件内容:less 要查看的文件
操作功能空格 、pagedown向下翻页pageup向上翻页/子串查找字符串内容,n向下找,N向上找
echo指令
输出内容到控制台:echo 【选项】 【输出内容】
head指令
用于显示文件开头部分内容,默认只显示前10行:head 文件
查看文件头5行:head -n 5[数字] 文件
tail指令
查看文件中尾部的内容,默认显示文件的尾10行内容:tail 文件
查看文件尾5行:tail -n 5[数字] 文件
实时追踪该文档的所有更新:tail -f 文件
指令>和指令>>
输出重定向(覆盖)>,追加>>
将列表内容覆盖写入文件:ls -l > 文件
将列表内容追加写入文件:ls -al >> 文件
将文件1内容覆盖到文件2:cat 文件1 > 文件2
将内容追加到文件:echo 内容 >> 文件
ln指令
给源文件创建一个链接:ln -s [源文件或目录] [链接名]
history指令
查看所有历史命令:history
查看最近5条命令:history 5
执行历史编号为5的命令:!5
10、日期指令
显示当前日期:
date
显示今年:
date +%Y
显示当前月份:
date +%m
显示当前天数:
date +%d
指定格式显示年月日时分秒:
date "+%Y-%m-%d %H:%M:%S"
设置日期:date -s 字符串日期
查看日历:cal 【选项】,不指定选项, 默认当前月日历
11、查找指令
1、find指令
find指令从指定目录向下递归遍历其各个子目录,将满足条件的文件或者目录显示在终端。
find [搜索范围] [选项]
常用选项
-name<查询方式>
按照指定的文件名查找模式查找文件
-user<用户名>
查找属于指定用户名所有文件
-size <文件大小n>
按照指定的文件大小查找文件,+n大于,-n小于,n等于,+单位k,M,G
2、locate指令
快速查找指定文件的路径:locate 文件
由于该指令是基于数据库查询,第一次使用必须用updatedb指令创建数据库,
3、which指令
查看指令在哪个目录下:which 指令
4、grep指令
过滤查找:grep 【选项】 查找内容 源文件
-n:显示匹配行和行号
-i:忽略字母大小写
12、压缩解压指令
1、gzip和gunzip指令
压缩文件:gzip 文件,只能将文件压缩为*.gz格式
解压文件:gunzip 需要解压的文件.gz
2、zip和unzip指令
项目打包发布时常用命令
压缩文件:zip 【选项】 XXX.zip
常用选项-r:递归压缩目录
解压文件:unzip 【选项】 XXX.zip
常用选项-d 目录:指定解压后文件存放目录
3、tar指令
既可打包又可解压,打包后文件后缀是
.tar.gz
打包目录:tar 【选项】 XXX.tar.gz
常用选项功能-c产生.tar打包文件-z打包同时压缩-x解包.tar文件-v显示详细信息-f指定压缩后的文件名
例:
压缩多文件:
tar -zcvf dc.tar.gz /hmoe/bbb/cat.txt /home/bbb/dog.txt
将bbb文件夹压缩成myb.tar.gz:
tar -zcvf myb.tar.gz bbb
将文件解压到当前目录:
tar -zxvf myb.tar.gz
将myb.tar.gz解压到tom目录下:
tar -zxvf myb.tar.gz -C tom
13、Linux组
一个文件有个所有者,所有者又归于一个组。
13.1、所有者和组
所有者:文件谁创建就归谁所有
查看文件所有者:ls -ahl
修改所有者:chown 用户名 文件
组的创建:groupadd 组名
新增用户直接分组:useradd -g 用户组 用户名
修改文件所在组:chgrp 组名 文件名
其他组:除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组
改变用户所在组(需要root的管理权限)
- usermod -g 新组名 用户名
- usermod -d 目录名 用户名 (改变该用户登陆的初始目录,注意这里的用户需要有进入新目录的权限)
13.2、权限介绍
Is -I中显示的内容如下:
d rwx r-x r-x. 2 root root 53 7月 9 20:08 bbb
0-9位说明
1.第0位确定文件类型(d,-,I,c,b)
d是目录,相当于windows的文件夹
-是普通文件
l是链接,相当于windows的快捷方式
c是字符设备文件,如鼠标,键盘
b是块设备,比如硬盘
2.第1- 3位
rwx
该文件的所有者拥有该文件的权限。——User
3.第4 - 6位
r-x
所属组的用户拥有该文件的权限。——Group
4.第7 - 9位
r-x
其他用户拥有该文件的权限——Other
rwx作用:r表示读,w表示写,x表示可执行(作用到文件是可执行,作用到目录是可进入)
其他说明:
数字2 :文件数和子目录数和
第一个root所有者,第二个root所在组
53:文件大小(字节),如果是文件夹,显示4096字节
7月 9 20:08:文件最后修改日期
13.3、修改权限chmod
方式一:+、一、=变更权限
u:所有者,g:所有组,o:其他用户,a:所有人
给文件的所有者读写执行权限,给所在组读执行权限,给其他用户执行权限:chmod u=rwx,g=rx,o=x 文件/目录名
给其他人增加写权限:chmod o+w 文件/目录名/所有者/所有组
该文件不让所有人执行:chmod a-x 文件/目录名/所有者/所有组
方式二:数字变更权限
r=4,w=2,x=1
chmod u=rwx,g=rx,o=x 文件/目录名 相当于 chmod 751 文件/目录名
13.4、修改文件所有者
改变所有者:chown 改成的所有者 文件/目录
改变所有者和所在组:chown 新所有者:新所有组 文件/目录
14、定时任务调度
任务调度:系统在某个时间执行特定的命令或程序。
14.1、任务调度分类
1.系统工作:某些重要工作周而复始的进行,如病毒查杀
2.个别用户工作:个别用户执行某些程序,如打开qq
定时任务的设置:crontab [选项]
选项功能-e编辑crontab定时任务-l查询当前任务调度-r删除当前用户所有的定时任务
14.2、重启任务调度
service crond restart
crontab -e 回车然后输入 */1 * * * * ls
*号位置含义第一个一小时当中的第几分钟(分钟)第二个一天当中的第几小时(小时)第三个一月当中的第几天(天)第四个一年中第几个月(月)
| 第五个 | 一周当中的星期几
范围0-7 ( 0和7都代表星期日) |
特殊符号说明
特殊符号含义表示任何时间,比如第一个,表示一小时每分钟执行一次,表示不连续时间,比如“0 8,10 * * * * 命令”,表示每天8点0分,10点0分执行一次命令-表示连续的时间范围,比如“0 2 * * 1-6 命令”,表示周一到周六凌晨2点执行命令*/n表示每隔多久执行一次,比如“*/10 * * * * 命令”,表示没10分钟执行一次命令
特定时间执行案例
14.3、at定时任务
at命令是一次性定时计划任务 ,at的守护进程atd会以后台模式运行,检查作业队列来运行。默认情况下, atd守护进程每60秒检查作业队列,有作业时,会检查作业运行时间,如果时间与当前时间四配,则运行此作业。at命令只执行一次。
在使用at命令的时候,一定要保证atd进程的启动,可以使用相关指令来查看
检测当前进程有哪些:ps -ef
检测acd进程是否在运行:ps -ef | grep atd
命令格式:at 【选项】【时间】,ctr+d结束at命令输入
选项功能-m当指定的任务被完成后,将给用户发送邮件,即使没有标准输出-Iatq(显示系统中待执行的任务列表)的别名-datrm(删除待执行任务队列中的任务)的别名-v显示任务将被执行的时间-V显示版本信息-c打印任务的内容到标准输出-q 队列使用指定的队列-f 文件从指定文件读入任务而不是从标准输入读入-t 时间参数以时间参数的形式提交要运行的任务
14.4、at指定时间的方式
1、hh:mm(小时:分钟)24小时制指定时间,如果该时间已过,会放到第二天执行。
2、使用midnight (深夜), noon (中午), teatime (饮茶时间,一般是下午4点)等模糊词来指定时间。
3、采用12小时计时制,即在时间后面加上am (上午)或pm (下午)来说明是上午还是下午。
4、指定命令执行的具体日期,指定格式为month day(月日)或mm/dd/yy (月/日/年)或dd.mm.yy
(日.月.年) ,指定的日期必须跟在指定时间的后面。 例如: 09:00 2021-07-1
5、使用相对计时法。指定格式为: now + count time- units , now就是当前时间, time-units是时间单位,这里能够是minutes、hous、days、weeks。count是时间的数量,几天,几小时。例如 : now + 5 minutes
6、直接使用today (今天)、tomorrow (明天)来指定完成命令的时间。
例1:一天后凌晨12点执行 /bin/ls /home
at 12am + 1 day,然后输入/bin/ls /home,接着ctr+d
例2 : atq命令来查看系统中没有执行的工作任务
例3 : 2分钟后,输出时间到指定文件内比如/root/date200.log
例4 :删除已经设置的任务, atrm 编号
atrm 1
15、Linux磁盘分区
15.1、分区原理
Linux来说无论有几个分区,分给哪一目录使用,归根结底就只有一个根目录,一个独立且唯一的
文件结构,Linux中每个分区都是用来组成整个文件系统的一部分。
Linux采用了一种叫“载入的处理方法,它的整个文件系统中包含了一整套的文件和目录,且将一
个分区和一个目录联系起来。一个分区挂载一个目录。
15.2、硬盘说明
1.Linux硬盘分IDE硬盘和SCSI硬盘,目前基本上是SCSI硬盘
2.对于IDE硬盘,驱动器标识符为"hdx" ,其中"hd" 表明分区所在设备的类型,这里是指IDE硬盘。“x"为盘号( a为基本盘, b为基本从属盘,c为辅助主盘,d为辅助从属盘)。”代表分区,前四个分区用数字1到4表示,它们是主分区或扩展分区,从5开始就是逻辑分区。
3.对于SCSI面则标识为"sdx~” , SCSI硬盘是用"sd" 来表示分区所在设备的类型的,其余的和IDE硬盘的表示方法一样。
查看设备挂载情况:lsblk或lsblk -f
查询磁盘使用情况:df -h 【/目录】,不写目录默认查询当前目录
统计/opt下文件个数:
ls -l /opt | grep "^-" | wc -l
(^-是以-开头的文件,wc统计个数)
统计/opt下目录个数:
ls -l /opt | grep "^d" | wc -l
统计/opt文件夹下文件的个数,包括子文件夹里的:
ls -lR /opt | grep "^-" | wc -l
统计/opt文件夹下目录的个数,包括子文件夹里的:
ls -lR /opt | grep "^d" | wc -l
以树状显示目录结构:
tree 目录
,注意默认是没有安装tree的,安装要root权限,安装tree命令:
yum install tree
16、网络配置
IP地址配置
1、自动获取
2、指定IP地址,避免虚拟机因自动获取IP造成地址变更,导致找不到
修改指定IP命令:
vi /etc/sysconfig/network-scripts/ifcfg-ens33
修改内容如下
BOOTPROTO=static
#IP地址
IPADDR=192.168.200.66
#网关
GATEWAY=192.168.200.2
#域名解析器
DNS1=192.168.200.2
虚拟机改完IP地址后,vmnet8也要修改在同一网段192.168.200.X,只有在同一网段中才能ping通。
虚拟机工具栏下》编辑》虚拟网络编辑器》修改子网IP》应用》确定
重启网络服务或重启Linux系统生效:service network restart 或 reboot
查看主机名:hostname
修改主机名:vim /etc/hostname,之后需要reboot重启生效
设置hosts映射
设置目的是为了通过主机名来ping通
Windows下:找到C:\Windows\System32\drivers\etc\hosts 文件指定即可,
指定内容:192.168.200.200 smile200
Linux下:/etc/hosts 文件指定,内容:192.168.200.200 smile
17、进程管理
程序:静态的,是躺在硬盘上。
进程:动态的,程序运行在内存中就是进程。
线程:进程的不同执行路径。
每个进程都可能以两种方式存在的。前台和后台,所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行。一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中,直到关机才结束。
17.1、查看当前系统中哪些进程正在执行
ps 【选项】
PS -aux执行后,参数含义
参数 含义
USER 用户
PID 进程号
%CPU 执行命令时候进程占用的CPU
%MEM 执行命令时候进程占用的CPU
VSZ 进程占用虚拟内存的大小(单位kb)
RSS 进程占用物理内存的大小(单位kb)
TTY 终端机号
STAT 运行状态
R: 正在运行
S:睡眠
D:短期等待
T:被跟踪或者被停止
Z:僵死进程(进程可能死掉,没有释放)
s:该进程是会话的先导进程
+:该进程为前台进程
l:该进程是多线程进程
N:低优先级进程
<:高优先级进程
[]:表示这个一个内核线程
START 执行开始的时间
TIME 进程消耗cpu的时间
COMMAND 进程名,执行该进程的指令
全格式显示所有进程,查看父进程:ps -ef
UID:用户名
PPID:父进程
C : CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,执行优先级会降低;
数值越小,表明进程是I/O密集型运算,执行优先级会提高
STIME:进程启动时间
CMD:启动进程所用命令和参数
其余和上面一样
选项功能-a显示当前终端的所有进程信息-u以用户的格式显示进程信息-x显示后台进程运行的参数-e显示所有进程-f全格式
17.2、终止进程
kill 【选项】 进程号
killall 进程名称
常用选项:-9:强迫进程立即停止
17.3、查看进程树
pstree 【选项】
常用选项
-p :显示进程的PID
-u :显示进程的所属用户
17.4、服务管理
service管理指令
service 服务名 [start I stop | restart | reload | status]
在CentOS7.0后很多服务不再使用service ,而是systemctl
查看服务名
查看全部系统服务:setup
带*号的服务是自动启动的,光标移至 * 号,按空格就会删除,按tab键进行切换。
查看service指令管理的服务:ls -l /etc/init.d
17.5、指定运行级别
CentOS7后运行级别说明
指定运行级别:init 数字0-6,常用运行级别是3和5
级别说明
0:关机
1:单用户(找回丢失密码用)
2:多用户状态无网络
3:多用户状态有网络
4:系统未使用保留给用户
5:图形界面
6:虚拟机重启
在/etc/initab进行了简化, 如下:
multi-user.target: analogous to runlevel 3
graphical.target : analogous to runlevel 5
查看当前的运行级别是什么:systemctl get-default
修改运行级别:systemctl set-default multi-user.target
17.6、chkconfig指令
查看服务:chkconfig --list [| grep xxx]
给服务在指定的运行级别下设置开关:chkconfig --level 5 服务名 on/off
注意:使用了chkconfig指令服务自启或关闭,需要reboot重启生效
17.7、systemctl指令
语法:systemctl 服务名 [start I stop | restart | reload | status]
查看管理的服务:ls -l /usr/lib/systemd/system
systemctl设置服务的自启动状态
- systemctl list-unit-files [ I grep服务名] (查看服务开机启动状态)
- systemctl enable 服务名(设置服务开机启动)
- systemctl disable 服务名(关闭服务开机启动)
- systemctl is-enabled 服务名(查询某个服务是否是自启动的)
例:查看当前防火墙的状况,关闭防火墙和启动防火墙
1.systemctl status firewalld.service
2.systemctl stop firewalld.service
3.systemctl start firewalld.service
17.8、防火墙
防火墙打开情况下,xshell6访问Linux需要打开22端口号,不然访问不到。防火墙关闭后,xshell6可以直接访问,不需要打开端口号。
打开或者关闭指定端口
在真正的生产环境,往往需要将防火墙打开,但此时外部请求数据包却不能跟服务器监听端口通讯。这时需要打开指定的端口,比如80、22、 3306等。
17.8.1、firewall指令
打开端口: firewall-cmd --permanent --add-port=端口号/协议
关闭端口: firewall-cmd --permanent --remove-port=端口号/协议
重新载入才能生效: firewall-cmd --reload
查看所有开放端口:firewall-cmd --zone=public --list-port
查询端口是否开放: firewall-cmd --query-port=端口/协议
17.9、动态监控进程
top与ps命令相似,都是用来显示正在执行的进程。top与ps最大的不同之处,在于top在执行一段时间可以更新正在运行的的进程。
指令:top 【选项】
选项功能-d 秒速指定top命令每隔几秒更新,默认3秒-i使top不显示任何闲置或者僵死进程-P通过指定监控进程ID来仅仅监控某个进程的状态
交互操作说明
操作功能P以CPU使用率排序,从大到小,默认就是此项M以内存的使用率排序,从大到小N以PID排序,从大到小Q或q退出top
例1:监视特定用户,比如我们监控tom用户
top命令下,输入“u"回车,再输入用户名,输错可按向下键清空。
例2 :终止指定的进程
top命令下,输入"k"回车,再输入要结束的进程ID号
18、rpm和yum
18.1、rpm
rpm用于下载包的打包及安装工具,它生成具有.rpm扩展名的文件。RPM是RedHat Package Manager ( RedHat软件包管理工具)的缩写,类似windows的setup.exe。
查询所有安装rpm软件包:rpm -qa
查询软件包是否安装:rpm -q 软件包名
查询软件包信息:rpm -qi 软件包名
查询软件包中的文件:rpm -ql 软件包名
查询文件所属的软件包:rpm -qf 文件全路径名
卸载软件包:rpm -e 软件包
安装软件包:rpm -ivh 安装的全路径
18.2、yum
yum是个Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包。
查询yum服务器是否有需要安装的软件:yum list l grep xx软件列表
安装指定的yum包:yum install xx下载安装
19、Java环境安装
19.1、jdk安装
安装步骤
1、创建jdk文件夹:mkdir /opt/jdk
2、通过xftp传输Linux版本的jdk安装包到/opt/jdk目录下
3、进入jdk目录:cd /opt/jdk
4、解压jdk安装包:tar -zxvf jdk-8u261-linux-x64.tar.gz
5、创建java文件夹:mkdir /usr/local/java
6、移动jdk安装文件:mv /opt/jdk/jdk1.8.0_261/ /usr/local/java/
7、配置环境变量:vim /etc/profile
8、在profile文末添加
export JAVA_HOME=/usr/local/java/jdk1.8.0_261
export PATH=$JAVA_HOME/bin:$PATH
9、让编辑过的环境变量生效:source /etc/profile
19.2、Tomcat安装
安装步骤
1、新建tomcat目录:mkdir /opt/tomcat
2、通过xftp传输Linux版本的tomcat安装包到/opt/tomcat目录下
3、进入tomcat目录:cd /opt/tomcat
4、解压tomcat安装包:tar -zxvf apache-tomcat-8.5.69.tar.gz ,下载core核心包地址https://tomcat.apache.org/download-80.cgi
5、进入tomcat的bin目录:cd apache-tomcat-8.5.69/bin,启动tomcat:./startup.sh
6、开放端口8080
防火墙打开8080端口号:firewall-cmd --permanent --add-port=8080/tcp
重新载入生效:firewall-cmd --reload
测试是否打开端口号:firewall-cmd --query-port=8080/tcp
也可以通过虚拟机ip地址:8080/,查看是否可以登录tomcat首页。
19.3、MySQL安装
1、新建mysq文件夹,并进入:mkdir /opt/mysql
2、Xftp将安装包传输到/opt/tomcat目录下,
下载地址 https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar,
或直接执行:wget http://dev.mysql.com/get/mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
3、进入tomcat目录:cd /opt/mysql
4、解压tomcat安装包:tar -xvf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
5、查询mariadb: rpm -qa | grep mari。注意centos7.6自带的类mysql数据库是mariadb,会跟mysql冲突,要先删除。
5、卸载mariadb:rpm -e --nodeps mariadb-libs ,rpm -e --nodeps marisa
6、开始安装mysql
rpm -ivh mysql-community-common-5.7.26-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.26-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.26-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-5.7.26-1.el7.x86_64.rpm
7、启动服务:systemctl start mysqld.service
8、开始设置root密码
Mysql自动给root用户设置随机密码,运行grep “password” /var/log/mysqld.log可看到当前密码
运行mysql -u root -p,复制粘贴输入上述密码
开发环境中密码要复杂,平时自己用就设简单密码,避免不能输入简单需修改设置策略,默认值为1,带分号输入。
mysql密码设置有三种策略:0策略密码设置最低8位,1策略要求长度,数字,大小写,特殊符号,3策略在2的基础上还多了个字典文件。
set global validate_password_policy=0;
最后开始设置密码,带分号
set password for 'root'@'localhost' = password('root6666');
9、运行如下命令使密码生效
flush privileges;
20、Shell编程
Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动、挂起、停止甚至是编写一些程序。
20.1、Shell脚本执行方式
- 脚本格式要求脚本以#!/bin/bash开头,需要可执行权限
例:创建shell脚本,输出hello world
- 常用执行方式方式1:输入脚本的绝对路径或相对路径(./xxx.sh) 说明:首先要赋予hello.sh脚本的 +x权限,再执行脚本方式2:sh+脚本 说明:不用赋予脚本 +x权限,直接执行即可。
20.2、shell变量
介绍
1)Linux Shell中的变量分为系统变量和自定义变量。
2)系统变量: $HOME等
3)显示当前shell中所有变量: set
shell变量的定义
基本语法
- 定义变量:变量名=值
- 撤销变量: unset 变量
- 声明静态变量 : readonly 变量,静态变量不能unset
变量定义实操
#!/bin/bash
#定义变量A
A=100
#输出变量需加上$
echo A=$A
echo "A=$A"
#撤销变量,变量A便没了
unset A
echo A=$A
#声明静态的变量B=2
readonly B=2
echo "B=$B"
C=`date`
D=$(date)
echo C=$C
echo D=$D
定义变量的规则
1.变量名称可以由字母、数字和下划线组成,但是不能以数字开头。
2.等号两边不能有空格
3.变量名称一般习惯为大写,这是一个规范,虽然小写也可运行。
将命令的返回值赋给变量
A=`date`反引号,运行里面的命令,并把结果返回给变量A,如果没有反引号表示的是将单词date给A
A=$(date)等价于上面的语句
20.2.1、设置环境变量(全局变量)
基本语法
export 变量名=变量值 (功能描述:将shell变量输出为环境变量)
source 配置文件 (功能描述:让修改后的配置信息立即生效)
echo $变量名 (功能描述:查询环境变量的值)
案例
在/etc/profile文件中定义TOMCAT_ HOME环境变量,profile文件修改后,需刷新生效
vim /etc/profile
输入如下内容
#定义一个tomcat环境变量
export TOMCAT_HOME=/opt/tomcat
保存退出
刷新profile
source /etc/profile
查看环境变量TOMCAT HOME的值
echo $TOMCAT_HOME
shell多行注释
:<<!
注释内容
!
20.2.2、位置参数变量
- 用途
当我们执行一个shell脚本时 ,如果希望获取到命令行的参数信息,就可以使用到位置参数变量
- 基本语法
$n ( 功能描述: n为数字, $0代表命令本身,$1-$9代表第一到第九个参数, 10以上的参数需要用大括号包含,如${10}$* (功能描述:命令行中所有的参数,$*把所有参数看成一个整体)$@ (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待,分别输出)$# (功能描述:命令行中所有参数的个数)
案例:编写一个shell脚本position.sh,在脚本中获取到命令行的各个参数信息。
vim myshell.sh
输入如下内容
#!/bin/bash
echo "0=$0 1=$1 2=$2"
echo "所有的参数=$*"
echo "$@"
echo "参数的个数=$#"
sh myshell.sh 10 20
20.2.3、预定义变量
含义:事先定义好的变量,直接在脚本中使用
基本语法
$$(功能描述:当前进程的进程号(PID)
$! (功能描述:后台运行的最后一个进程的进程号( PID) )
$? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一 个命令正确执行;
如果这个变量的值为非0 (具体是哪个数,由命令自己来决定), 则证明上一个命令执行不正确了。)
应用实例
在一个shell脚本中简单使用一下预定义变量
vim preVar.sh
输入内容
#!/bin/bash
echo "当前进程的进程id=$$"
#以后台方式运行脚本,并获取进程ID
/root/shcode/myshell.sh &
echo "最后一个进程的进程号id=$!"
echo "将执行结果返回=$?"
20.3、运算符
基本语法
$((表达式))或 $[表达式] 或expr m + n
注意expr(expression表达式简写)运算符间要有空格,m,n为数字。
希望某个结果赋值给变量,使用``反引号,单引号就相当于字符串拼接
expr m - n
expr \*(乘),/(除),%(取余)
应用实例
#!/bin/bash
#案例1:计算(2+3)*4的值
#方式1
RES1=$(((2+3)*4))
echo "res1=$RES1"
#方式2,推荐使用
RES2=$[(2+3)*4]
echo "res2=$RES2"
#方式3
TEMP=`expr 2 + 3`
RES3=`expr $TEMP \* 4`
echo "temp=$TEMP"
echo "res3=$RES3"
#案例2:请求出命令行的两个参数的和
SUM=$[$1+$2]
echo "sum=$SUM"
20.4、条件判断
判断语句基本语法
[ condition ] (注意condition前后要有空格)
#非空返回true ,可使用$?验证( 0为true , > 1为false )
应用实例
[ smile ] ,返回true
[ ],返回false
[ condition ] && echo OK II echo notok,条件满足,执行后面的语句
常用判断条件
1)=字符串比较
2)两个整数的比较
-It 小于
-le 小于等于
-eq 等于
-gt 大于
-ge 大于等于
-ne 不等于
3)按照文件权限进行判断
-r 有读的权限
-w 有写的权限
-x 有执行的权限
4)按照文件类型进行判断
-f 文件存在并且是一 个常规的文件
-e 文件存在
-d 文件存在且是一个目录
20.5、流程控制
20.5.1、if使用
基本语法
#单分支
if [ 条件判断 ]
then
代码
fi
#多分支
if [ 条件判断 ]
then
代码
elif [ 条件判断 ]
then
代码
fi
注意事项:[ 条件判断 ],中括号和条件之间必须有空格
案例
#!/bin/bash
#如果输入的参数,大于等于60,则输出及格了,如果小于60,则输出不及格
if [ $1 -ge 60 ]
then
echo "及格了"
elif [ $1 -lt 60 ]
then
echo "不及格"
fi
20.5.2、case语句
基本语法
case $变量名 in
"值1")
如果变量的值等于值1 ,则执行程序1
;;两分号代表结束
"值2")
如果变量的值等于值2,则执行程序2
;;
其他分支
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
案例
#!/bin/bash
#当命令行参数是1时,输出"周一"是2时,就输出"周二”,其它情况输出"other"
case $1 in
"1")
echo "周一"
;;
"2")
echo "周二"
;;
*)
echo “other”
;;
esac
20.5.3、for使用
基本语法
语法1:
for 变量 in 值1 值2 ...
do
代码
done
语法2:
for (( 始值;循环控制条件;量变化 ))
do
代码
done
应用实例
案例1:打印命令行输入的参数
#!/bin/bash
#$*输出方式
for i in "$*"
do
echo "num is $i"
done
#$@方式
echo "==========="
for j in "$@"
do
echo "num is $j"
done
案例2:从1加到100的值输出显示
#!/bin/bash
SUM=0
for(( i=1; i<=100; i++ ))
do
SUM=$[$SUM+$i]
done
echo "sum=$SUM"
20.5.4、while使用
基本语法
while [ 条件判断式 ]
do
代码
done
案例:从命令行输入一个数n,统计从1+……n的值是多少?
#!/bin/bash
SUM=0
i=0
while [ $i -le $1 ]
do
SUM=$[$SUM+$i]
i=$[$i+1]
done
echo "结果=$SUM"
20.5.5、read读取控制台输入
基本语法
read [选项] [参数]
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒), 如果没有在指定的时间内输入,就不再等待。
参数
变量:指定读取值的变量名
应用实例
#!/bin/bash
#案例1 :读取控制台输入一个num1值
read -p "请输入指定的num1=" NUM1
echo "输入的num1=$NUM1"
#案例2 :读取控制台输入一个num2值,在5秒内输入
read -t 5 -p "请输入num2=" NUM2
echo "输入的num2=$NUM2"
20.6、函数
系统函数
basename基本语法
basename [pathname] [suffix](功能:返回完整路径最后/的部分,常用于获取文件名)
basename [string] [suffix] (功能:basename命令会删掉所有的前缀包括最后一个/,然后将字符串显示出来)
suffix为后缀,如果suffix被指定了, basename会将pathname或string中的suffix去掉。
dirname基本语法
dirname 文件绝对路径 (功能描述:绝对路径中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分))
自定义函数
基本语法
[function] funname (参数){
Action;
[return int;]
}
[]表示可有可无
调用直接写函数名: funname [值]
应用实例
#!/bin/bash
#案例:计算输入两个参数的和,getSum
function getSum(){
sum=$[$n1+$n2]
echo "和是=$sum"
}
#输入两个值
read -p "第一个值=" n1
read -p "第二个值=" n2
#调用函数
getSum $n1 $n2
20.7、数据备份案例
需求分析
1.每天凌晨2:30备份数据库smile到/data/backup/db
2.备份开始和备份结束能够给出相应的提示信息
3.备份后的文件要求以备份时间为文件名,并打包成.tar.gz的形式,比如: 2021-07-15 230201.tar.gz
4.在备份的同时,检查是否有7天前备份的数据库文件,如果有就将其删除。
vim /usr/sbin/mysql_db_backup.sh 内容如下
#!/bin/bash#备份目录BACKUP=/data/backup/db
#当前时间DATATIME=$(date +%Y-%m-%d_%H%M%S)#数据库地址HOST=localhost
#数据库用户名DB_USER=root
#数据库密码DB_PW=root6666
#备份的数据库名DATABASE=smile
#创建备份目录,不存在就创建[! -d "${BACKUP}/${DATATIME}"]&&mkdir -p "${BACKUP}/${DATATIME}"#备份数据库echo"开始备份数据库${DATABASE}"
mysqldump -u${DB_USER} -p${DB_PW} --host=${HOST} -q -R --databases ${DATABASE}|gzip>${BACKUP}/${DATATIME}/$DATATIME.sql.gz
#将备份文件夹处理成.tar.gz的格式cd${BACKUP}tar -zcvf $DATATIME.tar.gz ${DATATIME}#删除对应的备份目录rm -rf ${BACKUP}/${DATATIME}#删除7天前的备份find${BACKUP} -atime +7 -name "*.tar.gz" -exec rm -rf {}\;echo"备份数据库${DATABASE}成功"
定时脚本
命令行敲crontab -e ,接着输入如下内容
302 * * * /usr/sbin/mysql_db_backup.sh
效果图
21、日志管理
21.1.系统常用日志
标红的是重点
日志管理服务rsyslogd
CentOS7.6日志服务是rsyslogd , CentOS6.x 日志服务是syslogd。rsyslogd 功能更强大,和syslogd兼容。
查询rsyslogd服务是否启动:ps aux | grep "rsyslog" | grep -v "grep"
grep -v "grep"表示反向选中前面过滤的内容
查询rsyslogd服务的自启动状态(enable)
systemctl list-unit-files | grep rsyslog
配置文件: /etc/rsyslog.conf
编辑文件时的格式为:
*.*
,存放日志文件
其中第个*代表日志类型,第二个代表日志级别
日志类型分为
auth ##pam产生的日志
authpriv ##ssh、ftp等登录信息的验证信息
corn ##时间任务相关
kern ##内核
Ipr ##打印
mail ##邮件
mark(syslog)-rsyslog ##服务内部的信息 ,时间标识
news ##新闻组
user ##用户程序产生的相关信息
uucp ##unix to nuix copy主机之间相关的通信
local 1-7 ##自定义的日志设备
日志级别分为
debug ##有调试信息的,日志通信最多
info ##一般信息日志 ,最常用
notice ##最具有重要性的普通条件的信息
warning ##警告级别
err ##错误级别,阻止某个功能或者模块不能正常工作的信息
crit ##严重级别,阻止整个系统或者整个软件不能正常工作的信息
alert ##需要立刻修改的信息
emerg ##内核崩溃等重要信息
none ##什么都不记录
注意:从上到下,级别从低到高,记录信息越来越少
日志文件格式有4列信息
1.事件产生的时间
2.产生事件的服务器的主机名
3.产生事件的服务名或程序名
4.事件的具体信息
21.2、自定义日志
自定义日志添加在/etc/rsyslog.conf ,编辑内容如图
21.3、日志轮替
日志轮替就是把旧的日志文件移动并改名,同时建立新的空日志文件,当旧日志文件超出保存的范围之后,就会进行删除。
日志轮替文件命名
1)centos7使用logrotate进行日志轮替管理,要想改变日志轮替文件名字,通过
/etc/logrotate.conf
配置文件中"dateext" 参数:
2)如果配置文件中有"dateext" 参数,那么日志文件以日期后缀 ,例如"secure-20210716"。此时不会重名,只需要指定保存日志个数,删除多余的日志文件即可。
3)如果配置文件中没有"dateext" 参数,那么日志文件就需要改名。当第一次进行日志轮替时,当前"secure"日志会自动改名为"secure.1",然后新建”secure"日志,用来保存新日志。当第二次进行日志轮替时,” secure.1”会自动改名为"secure.2" ,当前的"secure" 日志会自动改名为"secure.1”, 然后也会新建"secure"日志,用来保存新的日志,以此类推。
4、查看内存日志
journalctl ##查看全部
journalctl -n 3 ##查看最新3条
journalctl --since 19:00 - until 19:10:10 #查看起始时间到结束时间的日志可加日期
journalctl -p err ##报错日志
journalctl -o verbose ##日志详细内容
journalctl_PID=1245 COMM=sshd ##查看包含这些参数的日志 (在详细日志查看)
或者journalctl| grep sshd
注意: journalctl查看的是内存日志,重启清空
22、数据备份和恢复
安装dump和restore
yum -y install dump
yum -y install restore
使用dump备份
- 基本介绍 dump支持分卷和增量备份(所谓增量备份是指备份上次备份后修改/增加过的文件,也称差异备份)。
- dump语法说明
dump [ cu] [-123456789] [ -f <备份后文件名>] [-T <日期>] [ 目录或文件系统]dump []-wW-C :创建新的归档文件,并将由一个或多个文件参数所指定的内容写入归档文件的开头。-0123456789 :备份的层级。0为最完整备份,会备份所有文件。若指定0以上的层级,则备份至上一次备份以来修改或新增的文件,到9后,可以再次轮替。-f <备份后文件名> :指定备份后文件名-j :调用bzlib库压编备份文件,也就是将备份后的文件压缩成bz2格式,让文件更小-T <日期> : 指定开始备份的时间与日期-u :备份完毕后,在/etc/dumpdares中记录备份的文件系统,层级,日期与时间等。-t :指定文件名,若该文件已存在备份文件中,则列出名称-W :显示需要备份的文件及其最后一次备份的层级,时间,日期。-w :与-W类似,但仅显示需要备份的文件。
dump案例
案例1
将/boot分区所有内容备份到/opt/boot.bak0.bz2文件中,备份层级为"0"
dump -0uj -f /opt/boot.bak0.bz2 /boot
案例2
在/boot目录下新增文件,备份层级为"1”(只备份上次使用层次"0"备份后发生过改变的数据)
dump -1uj -f /opt/boot.bak1.bz2 /boot
dump备份文件或者目录
在备份分区时,是可以支持增量备份的。但如果备份目录或文件,不再支增量备份即只能使用0级别备份。
案例3
使用dump备份/etc整个目录
dump -0j -f /opt/etc.bak.bz2 /etc/
使用restore恢复数据
基本介绍
restore命令用来恢复已备份的文件,可以从dump生成的备份文件中恢复原文件
restore基本语法
restore [模式选项] [选项]
说明下面四个模式,不能混用,在一次命令中,只能指定一种。
-C:使用对比模式,将备份的文件与已存在的文件相互对比。
-i:使用交互模式,在进行还原操作时, restors指令将依序询问用户
-r:进行还原模式
-t:查看模式,看备份文件有哪些文件
选项
-f <备份设备>:从指定的文件中读取备份数据,进行还原操作
应用案例
案例1:restore命令比较模式,比较备份文件和原文件的区别
restore -C -f boot.bak1.bz2 //注意和最新的文件比较
案例2:restore命令查看模式,看备份文件有哪些数据/文件
restore -t -f boot.bak0.bz2
案例3
restore命令还原模式注意细节:如果你有增量备份,需要把增量备份文件也进行恢复,有几个增量备份文件就要恢复几个,按顺序来恢复即可。
mkdir /opt/boottmp
cd /opt/boottmp
restore -r -f /opt/boot.bak0.bz2 //恢复到第1次完全备份状态
restore -r -f /opt/boot.bak1.bz2 //恢复到第2次增量备份状态
23、Linux可视化管理
23.1、webmin安装
基本介绍
Webmin是功能强大的基于Web的Unix/linux系统管理工具。管理员通过浏览器访问Webmin的各种管理功能并完成相应的管理操作。
1.创建webmin文件夹
mkdir /opt/webmin
2.进入webmin
cd /opt/webmin
3.下载webmin包
wget http://download.webmin.com/download/yum/webmin-1.700-1.noarch.rpm
4.安装: rpm -ivh webmin-1.700-1.noarch.rpm
5.重置密码:/usr/libexec/webmin/changepass.pl /etc/webmin root webminroot
root是webmin的用户名,不是OS的,这里就是把webmin的root用户密码改成了webminroot
6.修改webmin服务的端口号 (默认是10000,出于安全目的修改端口号)
vim /etc/webmin/miniserv.conf
修改端口
将port=10000修改为其他端口号,如port=6868
将listen=10000修改为listen=6868
7.重启webmin
/etc/webmin/restart#重启
/etc/webmin/start #启动
/etc/webmin/stop #停止
6.防火墙打开6868端口
#配置防火墙开放666端口
firewall-cmd --zone=public --add-port=6868/tcp --permanent
#更新防火墙配置,生效
firewall-cmd --reload
#查看已经开放的端口号
firewall-cmd --zone=public --list-ports
7.登录webmin
http://ip:6868可以访问了
用root账号和重置的新密码webminroot登录
1.1webmin修改成中文版
23.2、BT宝塔安装
bt宝塔介绍
bt宝塔Linux面板是提升运维效率的服务器管理软件,支持键LAMP/LNMP/集群/监控/网站/FTP/数据库/JAVA等多项服务器管理功能。
宝塔安装
执行以下代码进行安装宝塔6.9.9免费版。宝塔6.9.9版本已经很稳定了,推荐大家直接安装6.9.9版本(注意:宝塔linux6.0版本是基于centos7开发的,务必使用centos7.x 系统)
创建bt文件夹
mkdir /opt/bt
进入bt安装目录
cd /opt/bt
执行安装命令
yum install -y wget&&wget -O install.sh http://download.bt.cn/install/install_6.0.sh &&sh install.sh
注意如果之前安装过mysql服务,此时安装需要输入yes强制安装,不要写y
安装完成后显示如下界面
外网面板地址: http://183.250.125.184:8888/12006102
内网面板地址: http://192.168.200.66:8888/12006102
username: svxkakvi
password: 67cb896d
如果bt的用户名,密码忘记了,使用bt default可以查看
版权归原作者 史莱姆君 所有, 如有侵权,请联系我们删除。