RPM与YUM的安装

应用程序与系统命令的关系

角色 系统命令 应用程序
文件位置 一般在/bin和/sbin目录中,或为Shell内部指令 通常在/usr/bin、/usr/sbin和/usr/local/bin、/usr/local/sbin目录中
主要用途 完成对系统的基本管理工作,例如IP配置工具 完成相对独立的其他辅助任务,例如网页浏览器
适用环境 一般只在字符操作界面中运行 根据实际需要,有些程序可在图形界面中运行
运行格式 一般包括命令字、命令选项和命令参数 通常没有固定的执行格式,由程序开发者自行定义

典型应用程序的目录结构

文件类型 保存目录 说明
普通的可执行程序 /usr/bin 所有用户可执行
服务器程序、管理程序命令 /usr/sbin 只有管理员能执行
应用程序配置文件 /etc 通过rpm或者yum方式安装的应用程序
日志文件 /var/log 系统日志
应用程序参考文档文件 /usr/share/doc 关于应用程序的参考文档等数据
应用程序手册页文件 /usr/share/man 执行文件及配置文件的man手册

常见的软件包封装类型

文件类型 保存目录
RPM软件包 扩展名为".rpm" ,适用于RHEL、CentOS等系统
DEB软件包 扩展名为".deb",适用于Ubuntu、Debian等系统
源代码软件包 一般为".tar.gz"、".tar.bz2"等格式的压缩包,包含程序的原始代码,需要编译安装
附带安装程序的软件包 软件包的扩展名不一以TarBall格式的居多,在软件包中会提供用于安装的可执行程序或者脚本文件。例:install.sh、setup等

RPM包管理工具

RPM软件包管理器Red-Hat Package Manager
由Red Hat公司提出,被众多Linux发行版所采用
建立统一的文件数据库
详细记录软件包安装、卸载、升级等变化信息
自动分析软件包依赖关系
RPM软件包
软件素材参考:http://www.rpm.org
一般命名格式:bash-4.2.46-28.e17.x86_64.rpm(软件名+版本号+发布次数+硬件平台+扩展名)

rpm命令的格式

rpm命令能实现几乎所有对RPM软件包的管理功能
执行"man rpm"命令可以获得关于rpm命令的详细帮助信息
rpm命令功能
查询、验证RPM软件包的相关信息
安装、升级、卸载RPM软件包
维护重建RPM数据库信息等综合管理操作

查询已安装的rpm软件信息

rpm -q 软件名 # 查询指定软件是否已安装
rpm -qi 软件名 # 显示已安装的指定软件的详细信息
rpm -ql 软件名 # 显示已安装的指定软件的文件列表
rpm -qc 软件名 # 列出已安装的指定软件的配置文件
rpm -qd 软件名 # 列出已安装的指定软件的依赖的软件包及文件
rpm -qf 文件或目录 # 查询已安装的指定软件属于哪个安装包
rpm -qa # ——显示当前系统中以 rpm方式安装的所有软件列表
rpm -qa | grep -i postfix # 查询软件postfix是否已安装

查询RPM 软件包文件中信息

rpm -qpi RPM包文件名 # 查询指定软件包的详细信息
rpm -qpl RPM包文件名 # 查询指定软件包的文件列表
rpm -qpc RPM包文件名 # 查询指定软件包的配置文件
rpm -qpd RPM包文件名 # 查询指定软件包的软件包文档的位置

安装、升级、卸载 RPM 软件包

格式:

rpm [选项] RPM包文件
rpm -ivh RPM软件包
1
2
常用选项:
-i:安装一个新的 RPM 软件包。
-U:升级某个软件包,若未安装过,则进行安装。
-F:升级某个软件包,若未安装过,则放弃安装。
-h:在安装或升级软件包的过程中,以“#”号显示安装进度。
-v:显示软件安装过程中的详细信息。

  • -force:强制安装某个软件包,比如要安装版本更旧的软件包。
    -e:卸载指定名称的软件包。
  • -nodeps:在安装或升级、卸载一个软件包时,不检查与其他软件包的依赖关系。

维护RPM数据库

1.重建 RPM 数据库
当 RPM 数据库发生损坏,可通过重建RPM数据库修复

rpm --rebuilddb		或者		rpm --initdb

2.导入验证公钥
在没有导入用于数字签名验证的公钥文件之前,安装光盘中的一部分RPM软件包时会报错。需要向RPM数据库中导入位于光盘根目录下的公钥文件

mount /dev/sr0 /mnt/
rpm --import /mnt/RPM-GPG-KEY-CentOS-7

安装源代码软件包需要编译安装,需要安装支持c和c++程序语言的编译器,如gcc、gcc-c++、make
如果使用rpm方式安装,则需要先安装多个依赖包,这样会很繁琐。这里可以使用 yum方式进行一键安装。

(1)配置本地yum源仓库

mount /dev/cdrom /mnt/			#把光盘挂载到/mnt目录下
cd /etc/yum.repos.d/
mkdir repos.bak
mv * repos.bak

vim local.repo
[local]							#仓库类别
name=local						#仓库名称
baseurl=file:///mnt				#指定URL 访问路径为光盘挂载目录
enabled=1						#开启此yum源,此为默认项,可省略
gpgcheck=0						#不验证软件包的签名

yum clean all && yum makecache		#删除yum缓存并更新

(2)yum常用的操作命令
yum -y install 软件名 # 安装、升级软件包,“-y”选项表示自动确认
yum -y remove 软件名 # 卸载软件包,可自动解决其依赖关系
yum -y update 软件名 # 升级软件包

yum list # 查询软件包列表
yum list installed # 查询系统中已安装的软件包
yum list available # 查询仓库中尚未安装的软件包
yum list updates # 查询可以升级版本的软件包

yum info 软件名 # 查询软件包的描述信息
yum info httpd

yum search [all] 关键词 # 根据某个关键词来查找相关的软件包
yum search all httpd

yum whatprovides 命令 # 查询命令属于哪个软件包
yum whatprovides netstat
(3)使用yum方式进行安装
yum install -y gcc gcc-c++ make

Windows端共享权限设定:

1.解禁Guest
右击我的电脑选择管理–>本地用户和组–>在用户项中双击Guest用户–>取消账号已禁用选项
2.设置共享目录权限
右击共享目录点属性–>在共享页面中点击共享选项–>下拉选择共享对象为Everyone–>点击共享按钮
3.设置本地策略
打开命令框–>输入secpol.msc–>选择本地策略
用户权限分配–>拒绝从网络访问这台计算机–>把Guest用户删除
安全选项–>网络访问:本地账户的共享和安全模型–>下拉选择仅来宾
Linux挂载端:
1.扫描共享目录
smbclient -L //192.168.80.1/ #Windows端的IP地址
不需要输入密码直接回车
2.挂载共享目录
yum install -y cifs-utils
mkdir /data
mount.cifs //192.168.80.1/share /data
不需要输入密码直接回车
查询命令:
df -h
ls /data

猜你喜欢

转载自blog.csdn.net/xiwagogogo/article/details/113495815