软件管理

本章节目标

获取程序包的途径

软件包管理器的职责

软件包管理器的核心功能

软件包的管理

软件包的分类

软件包的管理工具

软件的安装方法

rpm包的命名规范

rpm包的管理

作业

获取程序包的途径

  • 系统发行版的光盘或官方的服务器
    • 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

软件包的管理工具

  • 分类:
    • 前端工具,常用的前端工具有以下这些:
      • yum
      • apt-get
      • zypper (suse上的rpm前端管理工具)
      • dnf(Fedora 22+ rpm前端管理工具)
  • 后端工具,常用的后端工具有以下这些:
    • rpm
    • dpt
  • 注意:
    • 前端工具是依赖于后端工具的
    • 前端工具是为了自动解决后端工具的依赖关系而存在的

软件安装方式

  • 通过前端工具安装
  • 通过后端工具安装
  • 编译安装

rpm包的命名规范

在这里插入图片描述

bash:软件名称

  • 4.2.46:版本号
  • 28.e17:发布次数
  • x86_64:硬件平台
  • rpm:扩展名,表示适用于64位系统
  • 包的组成
    • 主包: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的管理工作包括软件的安装、卸载、升级、查询、校验、重建数据库、验证软件包来源合法性等等。

PRM包的安装

RPM包安装:

使用格式:rpm [-ivh] /PATH/TO/PACKAGE_FILE …

[option]:

-i: 安装
-v: 显示详细信息
-h: 显示安装进度条
--test: 测试安装,但不真正执行安装过程
--nodeps: 忽略依赖关系
--replacepkgs: 重新安装,替换原有安装
--oldpackage: 降级
--force: 强行安装,可以实现重装或降级
--nodigest: 不检查包的完整性
--nosignature: 不检查包的来源合法性
--noscripts: 不执行程序包脚本片断

实验操作:【-ivh】

[root@localhost ~]# rpm -ivh /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm 
警告:/mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:tree-1.6.0-10.el7                ################################# [100%]

实验操作:【–test】【测试安装,并未安装】

[root@localhost ~]# rpm -ivh --test /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm 
警告:/mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中...                          ################################# [100%]
	软件包 tree-1.6.0-10.el7.x86_64 已经安装
[root@localhost ~]# rpm -ivh --test /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%]
[root@localhost ~]# rpm -q vsftpd
未安装软件包 vsftpd 

实验操作:【–nodeps】【忽略依赖关系】

[root@localhost ~]# rpm -ivh /mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm 
警告:/mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
错误:依赖检测失败:
	samba-common = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
[root@localhost ~]# rpm -ivh --nodeps /mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm 
警告:/mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:samba-0:4.6.2-8.el7              ################################# [100%]
[root@localhost ~]# rpm -q samba
samba-4.6.2-8.el7.x86_64

实验操作:【–replacepkgs】【重新安装,替换原有的安装】

[root@localhost ~]# rpm -q vsftpd
vsftpd-3.0.2-22.el7.x86_64
[root@localhost ~]# 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%]
	软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
[root@localhost ~]# rpm -ivh --replacepkgs /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%]

实验操作:【–oldpackage】【降级安装】

实验操作:【–force】【强行安装】

[root@localhost ~]# rpm -ivh --force /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%]

RPM包查询

rpm -q PACKAGE_NAME                 //查询指定的包是否已安装
[root@localhost Packages]# rpm -q xterm
未安装软件包 xterm 
[root@localhost Packages]# rpm -q vsftpd
vsftpd-3.0.2-22.el7.x86_64
rpm -qa                             //查询已经安装的所有包【安装包很多,截取部分】
[root@localhost Packages]# rpm -qa
wpa_supplicant-2.6-5.el7.x86_64
grub2-common-2.02-0.64.el7.noarch
dhclient-4.2.5-58.el7.x86_64
setup-2.8.71-7.el7.noarch
ebtables-2.0.10-15.el7.x86_64
tzdata-2017b-1.el7.noarch
fxload-2002_04_11-16.el7.x86_64
rpm -qi PACKAGE_NAME                //查询指定包的说明信息
[root@localhost Packages]# rpm -qi vsftpd
Name        : vsftpd
Version     : 3.0.2
Release     : 22.el7
Architecture: x86_64
Install Date: 2019年06月08日 星期六 04时16分46秒
Group       : System Environment/Daemons
Size        : 356220
License     : GPLv2 with exceptions
Signature   : RSA/SHA256, 2017年03月23日 星期四 22时25分48秒, Key ID 199e2f91fd431d51
Source RPM  : vsftpd-3.0.2-22.el7.src.rpm
Build Date  : 2017年03月23日 星期四 22时01分19秒
Build Host  : x86-034.build.eng.bos.redhat.com
Relocations : (not relocatable)
Packager    : Red Hat, Inc. <http://bugzilla.redhat.com/bugzilla>
Vendor      : Red Hat, Inc.
URL         : https://security.appspot.com/vsftpd.html
Summary     : Very Secure Ftp Daemon
Description :
vsftpd is a Very Secure FTP daemon. It was written completely from
scratch.
rpm -ql PACKAGE_NAME                //查询指定软件包安装后生成的文件列表【配置文件众多截取部分】
[root@localhost Packages]# 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
rpm -qf /path/to/somefile           //查询指定的文件是由哪个rpm包安装生成的
[root@localhost Packages]# rpm -qf /etc/vsftpd/vsftpd.conf 
vsftpd-3.0.2-22.el7.x86_64
rpm -qc PACKAGE_NAME                //查询指定包安装的配置文件
[root@localhost Packages]# rpm -qc vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf
rpm -qd PACKAGE_NAME                //查询指定包安装的帮助文件【文件众多,截取部分】
[root@localhost Packages]# rpm -qd vsftpd
/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
rpm -q --scripts PACKAGE_NAME       //查询指定包中包含的脚本
[root@localhost Packages]# rpm -q --scripts vsftpd
postinstall scriptlet (using /bin/sh):

if [ $1 -eq 1 ] ; then 
        # Initial installation 
        systemctl preset vsftpd.service >/dev/null 2>&1 || : 
fi
preuninstall scriptlet (using /bin/sh):

if [ $1 -eq 0 ] ; then 
        # Package removal, not upgrade 
        systemctl --no-reload disable vsftpd.service > /dev/null 2>&1 || : 
        systemctl stop vsftpd.service > /dev/null 2>&1 || : 
fi 


if [ $1 -eq 0 ] ; then 
        # Package removal, not upgrade 
        systemctl --no-reload disable vsftpd.target > /dev/null 2>&1 || : 
        systemctl stop vsftpd.target > /dev/null 2>&1 || : 
fi
postuninstall scriptlet (using /bin/sh):

systemctl daemon-reload >/dev/null 2>&1 || : 
if [ $1 -ge 1 ] ; then 
        # Package upgrade, not uninstall 
        systemctl try-restart vsftpd.service >/dev/null 2>&1 || : 
fi
rpm -q --whatprovides CAPABILITY		//查询指定的CAPABILITY(能力)由哪个包所提供
[root@localhost ~]# rpm -q --whatprovides /bin/ls
coreutils-8.22-18.el7.x86_64
rpm -q --whatrequires CAPABILITY		//查询指定的CAPABILITY被哪个包所依赖
[root@localhost ~]# rpm -q --whatrequires /usr/bin/cat
没有软件包需要 /usr/bin/cat

rpm -q --changelog COMMAND 		 //查询COMMAND的制作日志
[root@localhost ~]# rpm -qi --changelog tree
Name        : tree
Version     : 1.6.0
Release     : 10.el7
Architecture: x86_64
Install Date: 2019年09月26日 星期四 14时55分17秒
Group       : Applications/File
Size        : 89505
License     : GPLv2+
Signature   : RSA/SHA256, 2014年04月03日 星期四 05时33分48秒, Key ID 199e2f91fd431d51
Source RPM  : tree-1.6.0-10.el7.src.rpm
Build Date  : 2014年01月28日 星期二 01时29分58秒

rpm -qR PACKAGE_NAME		//查询指定的软件包所依赖的CAPABILITY
[root@localhost ~]# rpm -qR tree
libc.so.6()(64bit)
libc.so.6(GLIBC_2.14)(64bit)
libc.so.6(GLIBC_2.2.5)(64bit)
libc.so.6(GLIBC_2.3)(64bit)
libc.so.6(GLIBC_2.3.4)(64bit)
libc.so.6(GLIBC_2.4)(64bit)
rpmlib(CompressedFileNames) <= 3.0.4-1
rpmlib(FileDigests) <= 4.6.0-1
rpmlib(PayloadFilesHavePrefix) <= 4.0-1
rtld(GNU_HASH)
rpmlib(PayloadIsXz) <= 5.2-1

rpm -q --provides PACKAGE_NAME		 //列出指定软件包所提供的CAPABILITY
[root@localhost ~]# rpm -q --provides tree
tree = 1.6.0-10.el7
tree(x86-64) = 1.6.0-10.el7
rpm -qpi /PATH/TO/PACKAGE_FILE 		 //查询指定未安装包的说明信息
root@localhost ~]# rpm -qpi /mnt/Packages/psacct-6.6.1-13.el7.x86_64.rpm 
警告:/mnt/Packages/psacct-6.6.1-13.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
Name        : psacct
Version     : 6.6.1
Release     : 13.el7
Architecture: x86_64
Install Date: (not installed)
Group       : Applications/System
Size        : 203425
License     : GPLv3+
Signature   : RSA/SHA256, 2017年03月28日 星期二 23时18分05秒, Key ID 199e2f91fd431d51
rpm -qpl /PATH/TO/PACKAGE_FILE		//查询未安装的软件包会产生哪些文件
[root@localhost ~]# rpm -qpl /mnt/Packages/sqlite-3.7.17-8.el7.x86_64.rpm 
警告:/mnt/Packages/sqlite-3.7.17-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
/usr/bin/sqlite3
/usr/lib64/libsqlite3.so.0
/usr/lib64/libsqlite3.so.0.8.6
/usr/share/doc/sqlite-3.7.17
/usr/share/doc/sqlite-3.7.17/README
/usr/share/man/man1/sqlite3.1.gz

RPM包升级【-Uvh 有老版本升级,没有安装】【-Fvh 有老版本升级,没有退出】
[root@localhost Packages]# rpm -Uvh /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%]
	软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
[root@localhost Packages]# rpm -Fvh /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
RPM包卸载:使用格式:rpm -e PACKGE_NAME
先查询,然后卸载
[root@localhost Packages]# rpm -qa | grep vsftpd
vsftpd-3.0.2-22.el7.x86_64
[root@localhost Packages]# rpm -e vsftpd
[root@localhost Packages]# rpm -q  vsftpd
未安装软件包 vsftpd
RPM包效验
S   //文件的容量大小是否被改变
M   //文件的类型或者文件的属性是否被修改
5   //MD5这一种指纹加密的内容已经不同
D   //装置的主/次代码已经改变
L   //路径已经被改变
U   //文件的所属主已被修改
G   //文件的所属组已被修改
T   //文件的创建时间已被改变
[root@localhost Packages]# rpm -ivh vsftpd-3.0.2-22.el7.x86_64.rpm 
警告: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@localhost Packages]# rpm -V vsftpd
[root@localhost Packages]# echo '123456789' >> /etc/vsftpd/vsftpd.conf 
[root@localhost Packages]# rpm -V vsftpd
S.5....T.  c /etc/vsftpd/vsftpd.conf
[root@localhost Packages]# useradd sh
[root@localhost Packages]# chown sh.sh -R /etc/vsftpd/
[root@localhost Packages]# rpm -V vsftpd
.....UG..    /etc/vsftpd
.....UG..  c /etc/vsftpd/ftpusers
.....UG..  c /etc/vsftpd/user_list
S.5..UGT.  c /etc/vsftpd/vsftpd.conf
.....UG..    /etc/vsftpd/vsftpd_conf_migrate.sh
RPM重建数据库
rpm --rebuilddb     //重建数据库,一定会重新建立
rpm --initdb        //初始化数据库,没有才建立,有就不用建立
[root@localhost ~]# cd /var/lib/rpm
[root@localhost rpm]# ls
Basenames     __db.002  Group       Obsoletename  Requirename  Triggername
Conflictname  __db.003  Installtid  Packages      Sha1header
__db.001      Dirnames  Name        Providename   Sigmd5
[root@localhost rpm]# rm -rf Packages 
[root@localhost rpm]# rpm --initdb
[root@localhost rpm]# rpm --rebuilddb
[root@localhost rpm]# ls
Basenames     Dirnames  Installtid  Obsoletename  Providename  Sha1header  Triggername
Conflictname  Group     Name        Packages      Requirename  Sigmd5

作业

如何查询 util-linux软件包安装了哪些文件?【配置文件较多,截取部分】
[root@localhost ~]# rpm -ivh /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
准备中...                          ################################# [100%]
	软件包 util-linux-2.23.2-43.el7.x86_64 已经安装
[root@localhost ~]# rpm -q util-linux
util-linux-2.23.2-43.el7.x86_64
[root@localhost ~]# 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
如何查询 mkdir 命令是由哪个 RPM 软件包安装的?
[root@localhost ~]# which mkdir
/usr/bin/mkdir
[root@localhost ~]# rpm -qf /usr/bin/mkdir
coreutils-8.22-18.el7.x86_64
升级软件包时,-F、-U选项有何区别?
[root@localhost ~]# 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%]
	软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
[root@localhost ~]# rpm -Uvh /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%]
	软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
[root@localhost ~]# rpm -Fvh /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



    //-F:如果已安装的版本是老版本,就升级老版本,反之退出安装。 
    
    //-U:如果已安装的是老版本,就升级老版本,反之安装这个版本。
如何检查vsftpd软件包是否安装?
[root@localhost ~]# rpm -q vsftpd
vsftpd-3.0.2-22.el7.x86_64
[root@localhost ~]# rpm -e vsftpd
[root@localhost ~]# rpm -q vsftpd
未安装软件包 vsftpd

 //输入rpm -q vsftpd  屏幕打印出包就是安装了,打印出未安装就是没有安装
如何检查vsftpd软件包所有的文件存放目录?
[root@localhost ~]# 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@localhost ~]# 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
如何检查vsftpd软件包的配置文件?
[root@localhost ~]# rpm -qc vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf
如何使用rpm安装vsftpd服务?
[root@localhost ~]# sed -i 's/NO/YES/g' /etc/vsftpd/vsftpd.conf  
[root@localhost ~]# /usr/sbin/vsftpd 
500 OOPS: missing value in config file for: q:q
[root@localhost ~]# ftp localhost
Trying ::1...
ftp: connect to address ::1拒绝连接
Trying 127.0.0.1...
ftp: connect: 拒绝连接
ftp> exit
[root@localhost ~]#
如何使用rpm强制安装依赖包?
[root@localhost ~]# rpm -q samba
samba-4.6.2-8.el7.x86_64
[root@localhost ~]# rpm -e samba
[root@localhost ~]# rpm -q samba
未安装软件包 samba 
[root@localhost ~]# rpm -ivh /mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm 
警告:/mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
错误:依赖检测失败:
	samba-common = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
	samba-common-libs = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
	samba-common-tools = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
	samba-client-libs = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
	samba-libs = 4.6.2-8.el7 被 samba-0:4.6.2-8.el7.x86_64 需要
[root@localhost ~]# rpm -ivh --nodeps /mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm 
警告:/mnt/Packages/samba-4.6.2-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:samba-0:4.6.2-8.el7              ################################# [100%]
[root@localhost ~]# rpm -q samba
samba-4.6.2-8.el7.x86_64
如何使用rpm卸载vsftpd软件包?
[root@localhost ~]# rpm -q vsftpd
vsftpd-3.0.2-22.el7.x86_64
[root@localhost ~]# rpm -e vsftpd
警告:/etc/vsftpd/vsftpd.conf 已另存为 /etc/vsftpd/vsftpd.conf.rpmsave
[root@localhost ~]# rpm -q vsftpd
未安装软件包 vsftpd
将本章学习到的rpm命令整理成一个列表,写明每个命令的作用
RPM包安装命令:
rpm -ivh /PATH/TO/PACKAGE_FILE
-i: 安装
    -v: 显示详细信息
    -h: 显示安装进度条
    --test: 测试安装,但不真正执行安装过程
    --nodeps: 忽略依赖关系
    --replacepkgs: 重新安装,替换原有安装
    --oldpackage: 降级
    --force: 强行安装,可以实现重装或降级
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 --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包卸载命令
rpm -e PACKAGE_NAME
RPM包效验命令
rpm -V PACKGE_NAME
S   //文件的容量大小是否被改变
M   //文件的类型或者文件的属性是否被修改
5   //MD5这一种指纹加密的内容已经不同
D   //装置的主/次代码已经改变
L   //路径已经被改变
U   //文件的所属主已被修改
G   //文件的所属组已被修改
T   //文件的创建时间已被改变
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python高仿360软件管家是指使用Python编程语言来开发一个功能与360软件管家相似的软件。下面是一个使用Python实现高仿360软件管家的简单示例: 首先,我们需要创建一个用户界面,可以使用Python的GUI库,如Tkinter、PyQt或wxPython。在界面中,我们可以添加类似于360软件管家的各种功能按钮,如扫描、清理、优化、软件升级等。当用户点击按钮时,对应的功能就会被触发。 其次,我们需要编写针对不同功能的代码逻辑。比如,对于扫描功能,我们可以编写一个扫描函数,用于扫描用户计算机上的垃圾文件、临时文件、无效注册表等,并将扫描结果显示在界面上。对于清理功能,我们可以编写清理函数,用于删除扫描出的垃圾文件等。类似地,我们还可以编写优化、软件升级等功能的代码逻辑。 此外,我们还可以使用Python的爬虫库来实现软件升级功能。通过爬取官方网站或相关软件下载网站的最新版本信息,我们可以编写一个自动更新函数,用于检测当前软件的版本号,并与最新版本进行对比。如果发现有新版本可用,就可以提醒用户进行软件更新。 最后,我们可以打包成可执行文件,方便用户直接使用。Python有很多打包工具可以帮助我们将Python代码打包成可执行文件,如PyInstaller、cx_Freeze等。通过打包,用户可以在没有安装Python环境的情况下直接使用我们开发的高仿360软件管家。 总而言之,使用Python编程语言开发一个高仿360软件管家,需要创建用户界面、编写各种功能的代码逻辑,并可以使用爬虫库实现软件升级功能。最后,通过打包工具将Python代码打包成可执行文件,方便用户使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值