1.RPM包管理

RPM
RPM Package Manger,前身Redhat Package Manger,由红帽开发用于软件包的安装升级卸载与查询
有一个完整的数据库体系,每个RPM包的所有信息都固定保存到指定的位置

源码
最原始代码,最新的版本,功能、bug

软件包管理
分类     安装                   版本
RPM      预先编译打包,安装简单  软件版本偏低
源码     手动编译打包,安装复杂  软件版本随意
二进制   解压即可使用,安装简单  不能修改源码

2.常见的软件包
注意:不管是源码包,还是二进制包,安装时都可能会有依赖关系!

系统平台      包类型    工具    自动解决依赖
RedHat/Centos RPM       rpm         yum
Ubuntu/Debian DPKG      dpkg        apt

3.RPM获取路径
1.RedHat光盘或官方网站
2.RPM查询官网网站
3.Nginx软件官方网站

4.RPM软件包命名规则

RPM包命名以-将软件分成了若干部分bash-4.2.46-28.e17.x86_64.rpm

name:软件包名称
version:版本号,主版本,重大更新,次版本,子功能更新,修订号,修复bug
release:发布版本el6,el7(hostnamectl)
arch:系统平台

rpm包的组成:
安装释放的文件
软件包的元数据(版本,发布号,架构,描述,要求,更改日志等)
脚本:安装前执行的脚本和安装后的脚本

5.查看系统光驱中RPM软件包
如果你的系统中还有系统的安装盘,首先我们让虚拟机链接上我们的系统安装盘,然后我们可以通过mount /dev/cdrom /mnt/命令把光驱
挂载到/mnt目录下,那么你会在/mnt/Packages目录下看到很多.rpm的文件。

[root@xiaoming ~]# mount /dev/cdrom /mnt/
mount: /dev/sr0 is write-protected, mounting read-only
[root@xiaoming ~]# ls /mnt/
CentOS_BuildTag  EULA  LiveOS    RPM-GPG-KEY-CentOS-7          TRANS.TBL  isolinux
EFI              GPL   Packages  RPM-GPG-KEY-CentOS-Testing-7  images     repodata
[root@xiaoming ~]# ls /mnt/Packages/ | head
GeoIP-1.5.0-14.el7.x86_64.rpm
ModemManager-glib-1.6.10-3.el7_6.x86_64.rpm
NetworkManager-1.18.0-5.el7.x86_64.rpm
...

RPM包安装
使用rpm命令安装软件包,需要了解如下参数:

-i:安装
-v:详细安装
-h:安装进度
//安装软件吧,需要指定软件包的绝对路径
[root@xiaoming Packages]# rpm -ivh /mnt/Packages/sg3* 
warning: /mnt/Packages/sg3_utils-1.37-18.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:sg3_utils-libs-1.37-18.el7       ################################# [ 50%]
   2:sg3_utils-1.37-18.el7            ################################# [100%]
preparing:准备过程
     检查软件包的依赖关系
         只要安装软件包中有依赖关系,且没有找到所依赖的软件包,停止安装
     检查软件包是否已安装
         只要检测安装软件包中有一个已经安装了,就停止安装

//如果软件包已安装,强制再次安装
[root@xiaoming Packages]# rpm -ivh --force /mnt/Packages/sg3* 
warning: /mnt/Packages/sg3_utils-1.37-18.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:sg3_utils-libs-1.37-18.el7       ################################# [ 50%]
   2:sg3_utils-1.37-18.el7            ################################# [100%]
--nodeps
  忽略依赖关系(不建议) 
--force
  强制覆盖安装  
  覆盖安装过程中,如果软件自带文件都存在,安装过程中不会将这些文件重新覆盖
 
 
RPM包查询
rpm -q  //查看指定软件包是否安装                  ***
rpm -qa //查看系统中已安装的所有RPM软件包列表     *****
[root@xiaoming Packages]# rpm -qa | wc -l
341
[root@xiaoming ~]# rpm -qa vim*
vim-common-7.4.629-6.el7.x86_64
vim-minimal-7.4.629-6.el7.x86_64
vim-filesystem-7.4.629-6.el7.x86_64
vim-enhanced-7.4.629-6.el7.x86_64

rpm -qi //查看指定软件的详细信息
rpm -ql //查询指定软件包所安装的目录、文件列表    ***
rpm -qc //查询指定软件包的配置文件
rpm -qd //查询指定软件包的帮助文档
rpm -qf //查询文件或目录属于哪个RPM软件           *****
[root@xiaoming Packages]# rpm -qf `which mount`
util-linux-2.23.2-61.el7.x86_64

rpm -q --scripts  //查询rpm包安装前和安装后执行的脚本

//查询未安装的软件包信息
rpm -qip  //查询未安装的rpm的详细信息
rpm -qlp  //查询未安装的软件包会产生哪些文件

//查询未安装的软件会产生哪些文件
[root@xiaoming ~]#rpm -qlp /mnt/Packages/shadow-utils-4.6-5.el7.x86_64.rpm 

//查询未安装的rpm的详细信息
[root@xiaoming ~]# rpm -qip /mnt/Packages/shadow-utils-4.6-5.el7.x86_64.rpm 


RPM升级
-U 如果老版本不存在,就全新安装,如果存在有新版即升级
-F 老版本必须存在

//如果有新版则升级,软件升级不要跨操作系统主版本号
[root@xiaoming ~]# rpm -Uvh /mnt/Packages/ustr-1.0.4-16.el7.x86_64.rpm      
warning: /mnt/Packages/ustr-1.0.4-16.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
Preparing...                          ################################# [100%]
    package ustr-1.0.4-16.el7.x86_64 is already installed

RPM卸载
卸载包时需要先把依赖的包卸载掉,如果依赖的包时系统必须的,那就不能卸载这个包,否则会造成系统崩溃
-e

RPM包校验
软件相关的数据库存放于/var/lib/rpm目录

S //文件的容量大小是否被改变
M //文件的类型或者文件的属性是否被修改
5 //MD5这一种指纹加密的内容已经不同
D //装置的主/次代码已经改变
L //路径已经被改变
U //文件的所属主已被修改
G //文件的所属组已被修改
T //文件的创建时间已被修改

 

RPM包小结
如何查询util-linux软件包安装了哪些文件?
[root@xiaoming ~]# rpm -qa util-linux*
util-linux-2.23.2-61.el7.x86_64

如何查询mkdir命令是由哪个RPM软件包安装的
[root@xiaoming ~]# rpm -qf `which mkdir`
coreutils-8.22-24.el7.x86_64

安装.rpm软件包时,-i、-U、-F选项有何区别
-i 安装软件包,必须之前没有任何版本
-U 升级安装软件包,之前可有可无
-F 刷新安装软件包,必须有之前版本

 

YUM软件仓库管理
yum
yellowdog update modify

yum是基于RPM包管理,能够自动解决依赖关系,极大的方便rpm包的安装升级
1.联网获取软件
2.基于RPM管理
3.自动解决依赖
4.命令简单好记
5.生产最佳实践

YUM软件仓库管理
本地YUM仓库
有时候你的linux系统不能联网,当然就不能很便捷的使用联网的yum源了,这时候就需要你自己会利用linux光盘制作一个yum源。具体步骤如下:

1.挂载镜像
[root@xiaoming ~]# mount /dev/cdrom /mnt

2.备份原有仓库
[root@xiaoming ~]# gzip /etc/yum.repos.d/*

[root@xiaoming ~]# mkdir /etc/yum.repos.d/backup
[root@xiaoming ~]# cp /etc/yum.repos.d/*.gz /etc/yum.repos.d/backup/


3.创建新仓库文件,并加入如下内容:

手动添加repo配置文件
[root@xiaoming yum.repos.d]# vim mnt.repo 

[local]
name=this is local repo
baseurl=file:///mnt
enabled=1
gpgcheck=0

[]          //仓库名称
name        //仓库描述信息
baseurl     //YUM源url地址,可以是file://
enabled     //是否激活该YUM源(0代表禁用,1代表允许)
gpgcheck    //安装软件时是否检查签名(0代表禁用,1代表允许)

4.刷新repos生成缓存
[root@xiaoming yum.repos.d]# yum clean all
[root@xiaoming yum.repos.d]# yum makecache
缺点:软件版本较低 2.软件不全 3.光驱读速慢
临时使用

网络YUM源仓库

官方网络YUM源配置

阿里镜像站点。https://developer.aliyun.com/mirror/centos?spm=a2c6h.13651102.0.0.53322f70WwceaG
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

EPEL扩展源

//国外epel源
[root@xiaoming ~]# yum -y install epel-release

//阿里云epel源
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
https://developer.aliyun.com/mirror

官方YUM源仓库

//Nginx官方源
cat >/etc/yum.repos.d/nginx.repo<<EOF
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=0
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
EOF

 

mysql官方库
创建mysql官方库
yum install -y https://repo.mysql.com//mysql80-community-release-el7-3.noarch.rpm
yum makecache

zabbix官方库
创建zabbix官方库
rpm -Uvh https://repo.zabbix.com/zabbix/4.4/rhel/7/x86_64/zabbix-release-4.4-1.el7.noarch.rpm

openstack官方库

yum install centos-release-openstack-pike
yum install https://rdoproject.org/repos/rdo-release.rpm

企业部署服务器的流程:
1.最小化安装操作系统
2.部署网络库和官方库
3.更新内核
yum update