linux软件管理
@
获取程序包的途径
- 系统发行版的光盘或官方的服务器
- http://mirrors.aliyun.com
- http://mirrors.sohu.com
- http://mirrors.163.com
- 项目官方站点
- 第三方组织
- Fedora-EPEL(推荐)
- 搜索引擎:
- http://pkgs.org
- http://rpmfind.net
- http://rpm.pbone.net
- 自己制作
软件包管理器的职责
- 将二进制程序,库文件,配置文件,帮助文件打包成一个文件;
- 安装软件时按需将二进制文件,库文件,配置文件,帮助文件放到相应的位置;
- 生成数据库,追踪所安装的每一个文件;
- 软件卸载时根据安装时生成的数据库将对应的文件删除
软件包管理器的核心功能
- 制作软件包
- 安装软件
- 卸载软件
- 升级软件
- 查询软件
- 校验软件
软件包管理
- 程序的组成清单(每个包独有)
- 文件清单
- 安装或卸载时运行的脚本 - 数据库(公共)
- 程序包名称及版本
- 依赖关系
- 功能说明
安装生成的各文件的文件路径及校验码信息
软件包分类
- 二进制格式(编译好的,装上就可以用)
- rpm包作者下载源程序,编译配置完成后,制作成rpm包
- why would we do that? because:
- 有些特性是编译时选定的,如果编译时未选定此特性,将无法使用
- rpm包的版本会落后于源码包,甚至落后很多
- 源码格式(需要编译,也叫定制)
- 命名方式:name-VERSION.tar.gz
- VERSION:major.minor.release
- 命名方式:name-VERSION.tar.gz
软件包管理工具
- 分类
- 前端工具,常用的前端工具有以下这些
- yum
- apt-get (ubuntu)
- zypper(suser上的rpm前端管理工具)
- dnf (Fedora 22 + rpm前端管理工具)
- 后端工具,常用后端工具有以下这些:
-rpm- dpt
- 前端工具,常用的前端工具有以下这些
- 注意:
- 前端工具是依赖于后端工具的
前端工具是为了自动解决后端工具的依赖关系而存在的
软件安装方式
- 通过前端工具安装
- 通过后端工具安装
- 编译安装
rpm包命名规范
- 包的组成
- 主包:bind-9.7.1-1.el5.i586.rpm
- 子包:bind-libs-9.7.1-1.el5.i586.rpm
- bind-utils-9.7.1-1.el5.i586.rpm
- 包名格式
- name-version-release-arch.rpm
- bind-major.minor.release-release.arch.rpm
- 包名格式说明
- major(主版本号):重大改进
- minor(次版本号):某个子功能发生重大变化
- release(发行号):修正了部分bug,调整了一点功能
- 常见的arch
- x86:i386,i486,i586,i686
- x86_64:x64,x86_64,amd64
- 跟平台无关:noarch
rpm包管理
什么是rpm及其作用
- rpm是Redhat Package Manager的简称,用于管理软件包。
- rpm有一个强大的数据库/var/lib/rpm。
rpm的管理工作包括软件的安装、卸载、升级、查询、校验、重建数据库、验证软件包来源合法性等等
RPM包安装
- 语法: rpm -ivh /PATH/TO/PACKAGE_FILE ...
- 常用选项:
- -i: 安装
- -v: 显示详细信息
- -h: 显示安装进度条
- --test: 测试安装,但不真正执行安装过程
- --nodeps: 忽略依赖关系
- --replacepkgs: 重新安装,替换原有安装
- --oldpackage: 降级
- --force: 强行安装,可以实现重装或降级
- --nodigest: 不检查包的完整性
- --nosignature: 不检查包的来源合法性
- --noscripts: 不执行程序包脚本片断
%pre:安装前脚本 --nopre
%post:安装后脚本 --nopost
%preun:卸载前脚本 --nopreun
%postun:卸载后脚本 --nopostun
- 安装软件包, 需要指定软件包绝对路径
//安装软件包, 需要指定软件包绝对路径 [root@localhost ~]# rpm -ivh /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm [root@localhost ~]# rpm -ivh /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm //在软件包所在目录下可以不指定绝对路径 [root@localhost ~]# cd /mnt/Packages/ [root@localhost Packages]# rpm -ivh zsh-5.0.2-28.el7.x86_64.rpm
RPM包查询
命令 | 解释 |
---|---|
rpm -q PACKAGE_NAME | 查询指定的包是否已安装 |
rpm -qa | 查询已经安装的所有包 |
rpm -qi PACKAGE_NAME | 查询指定包的说明信息 |
rpm -ql PACKAGE_NAME | 查询指定软件包安装后生成的文件列表 |
rpm -qf /path/to/somefile | 查询指定的文件是由哪个rpm包安装生成的 |
rpm -qc PACKAGE_NAME | 查询指定包安装的配置文件 |
rpm -qd PACKAGE_NAME | 查询指定包安装的帮助文件 |
rpm -q --scripts PACKAGE_NAME | 查询指定包中包含的脚本 |
rpm -q --whatprovides CAPABILITY | 查询指定的CAPABILITY(能力)由哪个包所提供,如:rpm -q --whatprovides /bin/cat |
rpm -q --whatrequires CAPABILITY | 查询指定的CAPABILITY被哪个包所依赖 |
rpm -q --changelog COMMAND | 查询COMMAND的制作日志 |
rpm -q --scripts PACKAGE_NAME | 查询指定软件包包含的所有脚本文件 |
rpm -qR PACKAGE_NAME | 查询指定的软件包所依赖的CAPABILITY |
rpm -q --provides PACKAGE_NAME | 列出指定软件包所提供的CAPABILITY |
rpm -qpi /PATH/TO/PACKAGE_FILE | 查询指定未安装包的说明信息 |
rpm -qpl /PATH/TO/PACKAGE_FILE | 查询未安装的软件包会产生哪些文件 |
- 查询vsftpd这个rpm包是否安装
[root@hostnamectl ~]# rpm -q vsftpd 未安装软件包 vsftpd [root@hostnamectl ~]# rpm -q vsftpd vsftpd-3.0.2-22.el7.x86_64
RPM包卸载
- rpm -e PACKAGE_NAME
- 先查询, 然后卸载
[root@hostnamectl ~]# rpm -q vsftpd vsftpd-3.0.2-22.el7.x86_64 [root@hostnamectl ~]# rpm -qa |grep vsftpd vsftpd-3.0.2-22.el7.x86_64 [root@hostnamectl ~]# rpm -e vsftpd [root@hostnamectl ~]# rpm -qa |grep vsftpd [root@hostnamectl ~]#
注:如果其他包依赖于要卸载的包,这个被依赖的包是无法卸载的,除非强制卸载,强制卸载后依赖于这个包的其他程序将无法正常工作
RPM包校验
- 回复无内容则表示此包未被修改
[root@localhost ~]# rpm -V vsftpd
- 如果回复有内容
S.5....T. c /etc/pam.d/vsftpd
标识 | 解释 |
---|---|
S | 文件的容量大小是否被改变 |
M | 文件的类型或者文件的属性是否被修改 |
5 | MD5这一种指纹加密的内容已经不同 |
D | 装置的主/次代码已经改变 |
L | 路径已经被改变 |
U | 文件的所属主已被修改 |
G | 文件的所属组已被修改 |
T | 文件的创建时间已被改变 |
RPM重建数据库
数据库信息在/var/lib/rpm目录中
- rpm --rebuilddb:重建数据库,一定会重新建立
[root@hostnamectl ~]# ls /var/lib/rpm Basenames __db.001 __db.003 Group Name Packages Requirename Sigmd5 Conflictname __db.002 Dirnames Installtid Obsoletename Providename Sha1header Triggername [root@hostnamectl ~]# rpm --rebuilddb [root@hostnamectl ~]# ls /var/lib/rpm Basenames Conflictname Dirnames Group Installtid Name Obsoletename Packages Providename Requirename Sha1header Sigmd5 Triggername
rpm --initdb:初始化数据库,没有才建立,有就不用建立
[root@hostnamectl ~]# rpm --initdb [root@hostnamectl ~]# ls /var/lib/rpm Basenames __db.001 __db.003 Group Name Packages Requirename Sigmd5 Conflictname __db.002 Dirnames Installtid Obsoletename Providename Sha1header Triggername
检查软件包来源合法性和完整性
- 加密类型:
- 对称加密 //加密解密使用同一个密钥
- 公钥加密 //一对密钥,公钥和私钥。公钥隐含于私钥中,可以提取出来并公布出去
- 单向加密 //只能加密不能解密
/etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release //红帽官方公钥
- rpm -K PACKAGE_FILE ,检查指定包有无密钥信息
dsa,gpg ,验证来源合法性,也即验证签名。可以使用--nosignatrue略过此项
sha1,md5 ,验证软件包完整性。可以使用--nodigest略过此项
[root@hostnamectl ~]# rpm -K /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm: RSA sha1 (MD5) PGP md5 不正确
作业
1. 如何查询util-linux软件包安装了那些文件?
- 未安装查询
[root@hostnamectl ~]# rpm -qpl /mnt/Packages/util-linux-2.23.2-43.el7.x86_64.rpm 警告:/mnt/Packages/util-linux-2.23.2-43.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY /etc/mtab /etc/pam.d/chfn /etc/pam.d/chsh /etc/pam.d/login /etc/pam.d/remote /etc/pam.d/runuser /etc/pam.d/runuser-l /etc/pam.d/su /etc/pam.d/su-l /usr/bin/cal /usr/bin/chfn /usr/bin/chrt /usr/bin/chsh /usr/bin/col /usr/bin/colcrt /usr/bin/colrm /usr/bin/column /usr/bin/dmesg /usr/bin/eject /usr/bin/fallocate /usr/bin/findmnt /usr/bin/flock /usr/bin/getopt /usr/bin/hexdump /usr/bin/i386 /usr/bin/ionice /usr/bin/ipcmk /usr/bin/ipcrm /usr/bin/ipcs /usr/bin/isosize /usr/bin/kill /usr/bin/linux32 /usr/bin/linux64 /usr/bin/logger
- 已安装查询
[root@hostnamectl ~]# rpm -ql util-linux /etc/mtab /etc/pam.d/chfn /etc/pam.d/chsh /etc/pam.d/login /etc/pam.d/remote /etc/pam.d/runuser /etc/pam.d/runuser-l /etc/pam.d/su /etc/pam.d/su-l /usr/bin/cal /usr/bin/chfn /usr/bin/chrt /usr/bin/chsh /usr/bin/col /usr/bin/colcrt /usr/bin/colrm /usr/bin/column /usr/bin/dmesg /usr/bin/eject /usr/bin/fallocate /usr/bin/findmnt /usr/bin/flock ...
2. 如何查询 mkdir 命令是由哪个 RPM 软件包安装的?
[root@hostnamectl ~]# which mkdir /usr/bin/mkdir [root@hostnamectl ~]# rpm -qf /usr/bin/mkdir coreutils-8.22-18.el7.x86_64
3. 升级软件包时,-F、-U选项有何区别?
- -U已经安装老版本时------------更新
[root@hostnamectl ~]# ls a abc accc add anaconda-ks.cfg cookie0001.txt wget-1.14-18.el7_6.1.x86_64.rpm [root@hostnamectl ~]# rpm -qa |grep wget wget-1.14-15.el7.x86_64 [root@hostnamectl ~]# rpm -Uvh wget-1.14-18.el7_6.1.x86_64.rpm 警告:wget-1.14-18.el7_6.1.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:wget-1.14-18.el7_6.1 ################################# [ 50%] 正在清理/删除... 2:wget-1.14-15.el7 ################################# [100%] [root@hostnamectl ~]# rpm -qa |grep wget wget-1.14-18.el7_6.1.x86_64
- -U没有安装老版本时------------安装新版本
[root@hostnamectl ~]# rpm -e wget [root@hostnamectl ~]# rpm -qa |grep wget [root@hostnamectl ~]# rpm -Uvh wget-1.14-18.el7_6.1.x86_64.rpm 警告:wget-1.14-18.el7_6.1.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:wget-1.14-18.el7_6.1 ################################# [100%] [root@hostnamectl ~]# rpm -qa |grep wget wget-1.14-18.el7_6.1.x86_64
- -F已经安装老版本时------------更新
[root@hostnamectl ~]# rpm -qa |grep wget wget-1.14-15.el7.x86_64 [root@hostnamectl ~]# rpm -Fvh wget-1.14-18.el7_6.1.x86_64.rpm 警告:wget-1.14-18.el7_6.1.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:wget-1.14-18.el7_6.1 ################################# [ 50%] 正在清理/删除... 2:wget-1.14-15.el7 ################################# [100%] [root@hostnamectl ~]# rpm -qa |grep wget wget-1.14-18.el7_6.1.x86_64
- -F没有安装老版本时------------无操作
[root@hostnamectl ~]# rpm -e wget [root@hostnamectl ~]# rpm -qa |grep wget [root@hostnamectl ~]# rpm -Fvh wget-1.14-18.el7_6.1.x86_64.rpm 警告:wget-1.14-18.el7_6.1.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY [root@hostnamectl ~]# rpm -qa |grep wget [root@hostnamectl ~]#
4. 如何检查vsftpd软件包是否安装?
以下三种都可以
[root@hostnamectl ~]# which vsftpd /usr/sbin/vsftpd [root@hostnamectl ~]# rpm -q vsftpd vsftpd-3.0.2-22.el7.x86_64 [root@hostnamectl ~]# rpm -qa |grep vsftpd vsftpd-3.0.2-22.el7.x86_64
5. 如何检查vsftpd软件包所有的文件存放目录?
- 已安装查询
[root@hostnamectl ~]# rpm -ql vsftpd /etc/logrotate.d/vsftpd /etc/pam.d/vsftpd /etc/vsftpd /etc/vsftpd/ftpusers /etc/vsftpd/user_list /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd_conf_migrate.sh /usr/lib/systemd/system-generators/vsftpd-generator /usr/lib/systemd/system/vsftpd.service /usr/lib/systemd/system/vsftpd.target /usr/lib/systemd/system/vsftpd@.service /usr/sbin/vsftpd /usr/share/doc/vsftpd-3.0.2 /usr/share/doc/vsftpd-3.0.2/AUDIT /usr/share/doc/vsftpd-3.0.2/BENCHMARKS /usr/share/doc/vsftpd-3.0.2/BUGS /usr/share/doc/vsftpd-3.0.2/COPYING /usr/share/doc/vsftpd-3.0.2/Changelog /usr/share/doc/vsftpd-3.0.2/EXAMPLE /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/README /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/README.configuration /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/vsftpd.conf /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/vsftpd.xinetd /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE_NOINETD ...
- 未安装查询
[root@hostnamectl ~]# rpm -ql vsftpd /etc/logrotate.d/vsftpd /etc/pam.d/vsftpd /etc/vsftpd /etc/vsftpd/ftpusers /etc/vsftpd/user_list /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd_conf_migrate.sh /usr/lib/systemd/system-generators/vsftpd-generator /usr/lib/systemd/system/vsftpd.service /usr/lib/systemd/system/vsftpd.target /usr/lib/systemd/system/vsftpd@.service /usr/sbin/vsftpd /usr/share/doc/vsftpd-3.0.2 /usr/share/doc/vsftpd-3.0.2/AUDIT /usr/share/doc/vsftpd-3.0.2/BENCHMARKS /usr/share/doc/vsftpd-3.0.2/BUGS /usr/share/doc/vsftpd-3.0.2/COPYING /usr/share/doc/vsftpd-3.0.2/Changelog /usr/share/doc/vsftpd-3.0.2/EXAMPLE /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/README /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/README.configuration /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/vsftpd.conf /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE/vsftpd.xinetd /usr/share/doc/vsftpd-3.0.2/EXAMPLE/INTERNET_SITE_NOINETD
6.如何检查vsftpd软件包的配置文件?
[root@hostnamectl ~]# rpm -qc vsftpd /etc/logrotate.d/vsftpd /etc/pam.d/vsftpd /etc/vsftpd/ftpusers /etc/vsftpd/user_list /etc/vsftpd/vsftpd.conf
7.如何使用rpm安装vsftpd服务?
//先挂载 [root@hostnamectl ~]# mount /dev/cdrom /mnt/ mount: /dev/sr0 写保护,将以只读方式挂载 然后用rpm 工具 -i安装 -v显示过程 -h 显示进度 [root@hostnamectl ~]# rpm -ivh /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm 警告:/mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:vsftpd-3.0.2-22.el7 ################################# [100%] [root@hostnamectl ~]# rpm -qa |grep vsftpd vsftpd-3.0.2-22.el7.x86_64
8.如何使用rpm强制安装依赖包?
[root@hostnamectl ~]# rpm -qa |grep httpd [root@hostnamectl ~]# rpm -ivh --nodeps /mnt/Packages/httpd-2.4.6-67.el7.x86_64.rpm 警告:/mnt/Packages/httpd-2.4.6-67.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY 准备中... ################################# [100%] 正在升级/安装... 1:httpd-2.4.6-67.el7 ################################# [100%] [root@hostnamectl ~]# rpm -qa |grep httpd httpd-2.4.6-67.el7.x86_64
8. 如何使用rpm强制安装依赖包?
[root@hostnamectl ~]# rpm -q --whatrequires httpd-tools httpd-2.4.6-67.el7.x86_64
9. 如何使用rpm卸载vsftpd软件包?
[root@hostnamectl ~]# rpm -q httpd-tools httpd-tools-2.4.6-67.el7.x86_64 [root@hostnamectl ~]# rpm -e httpd-tools [root@hostnamectl ~]# rpm -q httpd-tools 未安装软件包 httpd-tools [root@hostnamectl ~]#
将本章学习到的rpm命令整理成一个列表,写明每个命令的作用
- 包安装
-i | 安装 |
---|---|
-v | 显示详细信息 |
-h | 显示安装进度条 |
--test | 测试安装,但不真正执行安装过程 |
--nodeps | 忽略依赖关系 |
--replacepkgs | 重新安装,替换原有安装 |
--oldpackage | 降级 |
--force | 强行安装,可以实现重装或降级 |
--nodigest | 不检查包的完整性 |
--nosignature | 不检查包的来源合法性 |
--noscripts | 不执行程序包脚本片断 |
- 包查询
选项 | 解释 |
---|---|
rpm -q PACKAGE_NAME | 查询指定的包是否已安装 |
rpm -qa | 查询已经安装的所有包 |
rpm -qi PACKAGE_NAME | 查询指定包的说明信息 |
rpm -ql PACKAGE_NAME | 查询指定软件包安装后生成的文件列表 |
rpm -qf /path/to/somefile | 查询指定的文件是由哪个rpm包安装生成的 |
rpm -qc PACKAGE_NAME | 查询指定包安装的配置文件 |
rpm -qd PACKAGE_NAME | 查询指定包安装的帮助文件 |
rpm -q --scripts PACKAGE_NAME | 查询指定包中包含的脚本 |
rpm -q --whatprovides CAPABILITY | 查询指定的CAPABILITY(能力)由哪个包所提供 |
rpm -q --whatrequires CAPABILITY | 查询指定的CAPABILITY被哪个包所依赖 |
rpm -q --changelog COMMAND | 查询COMMAND的制作日志 |
rpm -q --scripts PACKAGE_NAME | 查询指定软件包包含的所有脚本文件 |
rpm -qR PACKAGE_NAME | 查询指定的软件包所依赖的CAPABILITY |
rpm -q --provides PACKAGE_NAME | 列出指定软件包所提供的CAPABILITY |
rpm -qpi /PATH/TO/PACKAGE_FILE | 查询指定未安装包的说明信息 |
rpm -qpl /PATH/TO/PACKAGE_FILE | 查询未安装的软件包会产生哪些文件 |
- 包升级
选项 | 解释 |
---|---|
rpm -Uvh /PATH/TO/NEW_PACKAGE_FILE | 如果装有老版本的,则升级;否则,则安装 |
rpm -Fvh /PATH/TO/NEW_PACKAGE_FILE | 如果装有老版本的,则升级;否则,退出 |
rpm --oldpackage | 降级 |