cenros7软件包的安装方式
软件包分类 | 安装方式 | 优缺点 |
---|---|---|
rpm包 | 软件开发商编译打包,安装简单,快速 | 软件版本可能偏低,安装路径是固定好的 |
源码包 | 自己手动编译安装并且复杂 | 软件爸爸随意选,可以定制安装路径 |
二进制包 | 解压就可以使用 | 不能进行修改源码,软件包大 |
什么是源码包?
开发人员编写好的程序源代码,并且没有将其编译为一个能正常使用的工具或软件。
为什么要进行源码包安装
部分软件官网提供源码包,需要自己编译并且安装;
部分软件在新版本有一些特性还没来得及制作rpm包时,或者软件包可以进行自行编译软件使用新的特性
比如:下面的编译参数介绍(添加了一些模块,可以使用源码安装)
源码包的优缺点
优点:
- 可以自行修改源代码
- 可以定制需要的相关功能
- 新版软件优先更新源码(python,go学开发做运维)
缺点:
4. 性对于yum安装软件会很复杂
5. 标准化实施困难,自动化运维复杂
源码包如何获取
常见的软件包都可以在官网获取源码包:apache(并发能力3000-5000),nginx(10000-30000),mysql等,阿里云,清华源
apache已经被国内淘汰了(不建议大家去学)
已经被nginx代替了
编译安装源码包软件
编译安装过程
上述安装是c语言开发的软件,很多系统服务软件大多都是c语言开发
c语言优势:运行速度快
缺点:难学,开发速度慢(互联网企业在逐渐大众消失)
python语言:开发效率高,用途广
缺点:解释语言,运行速度慢
go语言:开发效率高,用途在变广,编译速度快,主要是高并发场合,替代c语言
实践:安装nginx了解源码包编译过程
1.环境准备
[root@calms ~]# rpm -qa gcc
gcc-4.8.5-44.el7.x86_64
[root@calms ~]# rpm -qa make gcc wget
wget-1.14-18.el7_6.1.x86_64
gcc-4.8.5-44.el7.x86_64
make-3.82-24.el7.x86_64
如果已经装好了,忽略下面的步骤
yyum install gcc make wget -y(Development tools中含有gcc make)
2.下载源码包
去www.nginx官网找到对应下载的版本复制下载地址
[root@calms ~]# cd /usr/src
wget -q https://nginx.org/download/nginx-1.26.0.tar.gz(静默安装)
3.解压源码目录
[root@calms src]# tar xf nginx-1.26.0.tar.gz
[root@calms src]# cd nginx-1.26.0
[root@calms nginx-1.26.0]#
4.配置相关的选项,并且生成makefile
[root@calms nginx-1.26.0]# ./configure --prefix=/application/nginx-1.26.0
故障:
这样直接安装不了,需要安装
[root@calms nginx-1.26.0]# yum install pcre-devel -y
如果还进行报错
安装yum install zlib-devel -y
这时候再进行编译:
./configure --prefix=/application/nginx-1.26.0
echo $?显示0表示正确
5.将makefile文件编译成可执行的二进制程序
cat Makefile(可以查看makefile文件内容)
make命令进行编译
6.将二进制文件拷贝至对应的文件
make install
7.启动,测试
netstat -lntup|grep nginx检查是否有(我这里是没有的)
补充:
这里最好用软连接做:
做软连接目的:我们以后进行访问只访问nginx,未来nginx软件包进行升级的时候(nginx-1.26.7)我们只需要ln -s 换成新的即可,对于编译软件的时候我们只使用nginx,要升级新的就直接链接到新的;工作中只使用ln /application/nginx即可!
/application/nginx-1.26.0/sbin/nginx
netstat -lntup|grep nginx
启动成功!
curl 127.0.0.1也可以终端查看,也可以在浏览器访问自己的ip
epel源里面有nginx的官方更新的
yum install nginx -y
. /application/nginx-1.26.0/sbin/nginx -s stop停止
特点:
安装复杂,特别慢,很容易报错
安装软件的时候,尽量找它的yum安装包,去官方去找它的镜像配置,如果官方的yum源符合不了要求。如果是大量的服务器将源码包进行定制化(定制为rpm包)然后把rpm包放置到私有仓库,然后用私有仓库作为源再通过yum进行安装
Linux进程管理
什么是进程?
计算机软件或代码被执行,运行与内存的时候,称之为进程,系统会为其分配内存资源,并且分配到pid,网路端口,运行用户及文件描述符。
进程及守护进程和程序的区别
进程:程序或者软件运行起来后的产物,放在内存中
守护进程:为提供服务持续运行,还具备普通进程的特点,ftp,mysql等都属于守护进程
程序:代码文件或应用软件文件永久存放在系统中,并且可以看到实体文件(放置在磁盘中),把程序及软件运行起来就是进程;持续的运行着,就是守护进程
进程运行原理
监控和管理进程(企业)
ps命令:查看进程
功能:列出执行ps命令那个时刻的进程快照(静态查看)
动态查看(top):
ps 【选项】
参数格式:Unix格式:一个 - 开头
bsd格式:没有- 开头
gnu 两个-开头
常用参数
-f :额外显示UID PPID c与STIME栏位
ps -ef 简易查看进程,过滤进程的命令
相当于windows管理器;
UID:进程被该UID所拥有
PID:进程的标识号
ppid:进程的父进程的标识号
c:cpu使用资源的百分比
STime:进程开始的时间
TTY:该进程是在那个终端机上面运作,若与终端机无关,显示?,另外tty1-tty6是本机上面的登入者进程,若为pts/0等,表示由网络接主机的进程
time:进程所用到的总和的cpu时间
cmd:正在执行的命令行
PID为1的初始进程,c7:systemd,c6:init
使用BSD语法格式显示每一个进程信息
ps aux
BSDd格式采纳数,使用a选项和x选项显示所有的进程,使用u选项显示进程的用户信息
ps auxx可以显示全路径
STAT:该进程被触发的时间;
TIME:该进程实际cpu运作时间
COMMAND:该进程的实际命令,【方括号】属于内核态的进程,没有 [ ]的是用户态进程
进程状态
运行:R 休眠:S D:不可中断睡眠 T:正在侦测或停止
Z:已经终止 +:前台进程
I:多线程进程 N:低优先级进程 <:高优先进程
s:进程领导者 L:已将页面锁定在内存中
AIX格式:ps -eo “%p %y %x %c”
语法说明,-e是显示所有的进程,-o可以自定义输出的字段,以逗号进行分隔,支持的字端
zabbix监控,每隔几分钟监控
pa aux --sort -vsz |head sort后面加上减号表示逆序排序
查看某一个进程在哪个cpu上运行:
这里可以和之前学习到的命令进行结合
重要的参数总结:
ps aux
a:显示与终端相关的所有的进程,包含每一个进程的完整路径
u显示进程的用户信息
x显示与终端无关的所有进程
-u 显示指定用户相关的进程信息
-e 显示所有的进程
-f 额外显示UID PPID C与STIME栏位
企业中如何使用?
查找占用cpu mem虚拟内存 更多的进程
分析进程的问题,解决问题,把资源降下来
如果发现没有异常,还无法进行降下来,就增加增加资源
维护服务器性能:CPU,内存,IO
pstree:显示进程状态树
用法
pstree 选项 【进程号、用户】
在后面会写linux启动流程的时候再详谈
pstree -a展示系统的子进程
psgrep:查找匹配条件的进程(了解即可)
用法:pgrep 【选项】
top:实时显示系统中各个进程的占用资源状况
top 【选项】
-U 指定用户的进程(搭建集群的时候可能会把程序跑在普通用户下)
指定pid查看进程
top的输出
第一行:任务队列信息,同uptime命令的执行结果;当前系统时间;系统运行对少天;2个用户登录系统;
后面三个数分别是1分钟,5分钟,15分钟的平均负载的情况。体现系统繁忙的重要简单的查看指标
top - 18:22:25 up 1:32, 2 users, load average: 0.00,
【平均负载load average】
第二行:task为任务(进程)
一共有有120个进程,其中运行的状态有1个,119在睡眠,stoped状态为0个;zombie状态(僵死)都有0个
Tasks: 120 total, 1 running, 119 sleeping, 0 stoppe
第三行,cpu状况信息
#模拟消耗负载,消耗cpu,消耗io工具
stress - tool to impose load on and stress test systems
example:
stress --cpu 8 --io 4 --vm 2 --vm-bytes 128M --timeout 10s
%Cpu(s): 0.0 us, 0.1 sy, 0.0 ni, 99.9 id, 0.0 wa,
第四行内存状态:
内存总结、可用内存(剩余内存)、已用内存、系统缓存和缓冲区占用内存空间
KiB Mem : 7989840 total, 7054432 free, 399116 used,
以上两行:cat/proc/meminfo或free -m获取
第五行:swap交换分区信息
交换分区总量 使用的交换区总量 空闲交换区总量 可用内存大小
KiB Swap: 1048572 total, 1048572 free, 0 used.
t
从第七行开始,是各进程(任务)状态监控
top必会的快捷键指令(笔试可能会问)
企业面试:输入top命令,想看服务器有几个cpu核心?
按1键
load average 平均负载
进程杀手:
1.kill 2.killall 3. pkill
kill 终止目标进程
-l 列出全部信号名称
-s指定要发送的信号
什么是信号?
kill命令发送给操作系统,让操作系统去执行的一个命令
常见的信号列表:
环境测试:
vsftpd( FTP服务),端口21端口,数据段端口20
默认不加参数关闭vsftpd
[root@calms ~]# pgrep vsftpd
7344
[root@calms ~]# kill 7344
[root@calms ~]# pgrep vsftpd
当用kill杀不死的时候,可以用kill -9 进程名(强制)
也可以这样杀进程:
kill -9 pgrep vsftpd(用反引号进行包含)
改配置文件不重启,直接生效
1 HUP 挂起信号 可以让进城重新配置,重新加载
kill -1 进程ID
生产经验:kill -0 pid是不发送关闭停止信号,但是会检查进程是否存在?
生产用途:检查进程是否存在,实际应用(mysql服务关闭的时候)
kill PID
补充:在shell脚本开发,关闭服务的时候,可以用kill -0
如果vsftpd存在则输出1否则为0
也可以判断进程是否存在
也可以判断进程是否存在:
企业经验:
强制杀,导致服务器不来
数据服务不能强杀mysql,oracle,mongodb(数据库,磁盘上有自己的文件系统)
非数据服务可以强杀nginx,vsftpd(数据在磁盘上)
已知端口去查服务:查看80端口是什么服务:
kill all通过名字杀进程
killall 进程名
可以多次执行直到看到后面出现没有发现即可
缺点:杀得很慢,不重复执行
pkill通过进程(完整名称)
-t 终端 杀死指定终端进程
-u 用户 杀死指定用户的进程
总结·:
pkill 进程名(一次杀死)
killall 进程名(多次)
-9强杀会引起服务起不来
-u用户
kill PID 默认不会引起服务器启动
kill -HUP PID 平滑重启(重新加载配置)
kill -0 PID(检查进程是否存在,mysql关闭的时候)
kill -9 PID(强杀,可能会引起服务起不来)
批量杀进程:
ps -ef|grep nginx|awk ’ {print $2}’ |sed -r ‘s#(.*)kill \1#g’|bash
这一篇先写到这里了,想要学习更多关注我的专栏!!!