目录
一、yum仓库简介
1.yum简介
yum是一个基于RPM包(是Red-Hat Package Manager红帽软件包管理器的缩写)构建的软件更新机制,能够自动解决软件包之间的依赖关系。解决了日常工作中的大量查找安装依赖包的时间 为什么会有依赖关系的发生 因为linux本身就是以系统简洁为自身优势,所以在安装操作系统的时候并没有将所有的库文件以及编译软件包进行安装,所以在linux操作系统上进行软件安装的时候会出现软件包依赖的情况。yum由仓库和客户端组成,也就是整个yum由两部分组成,所以yum可以存放在两台服务器上。也可以存放在一台服务器上。可以有官方来提供服务,也可以由第三方来提供,比如国内的阿里云,搜狐云,还有一些非盈利组织比如学校等。官方的源一般在国外,下载速度肯定有限,手动更改成国内的云可以大幅提升下载速度。
2.yum的实现过程
(1)先在yum服务器上创建 yum repository(仓库)
(2)在仓库中事先存储了众多rpm包,以及包相关的元数据文件(放置于特定目录repodata下)
(3)当yum客户端利用yum/dnf工具进行安装时包时,会自动下载repodata中的元数据
(4)查询远数据是否存在相关的包及依赖关系,自动从仓库中找到相关包下载并安装。
二. yum配置文件及命令
1.yum配置文件
(1)主配置文件
[root@localhost]# /etc/yum.conf
[a]
cachedir=/var/cache/yum/$basearch/$releasever硬件 版本
keepcache=0 是否保存缓存 0代表不保存,1代表保存
debuglevel=2 调试级别了解即可
logfile=/var/log/yum.log 日志文件位置
exactarch=1 是否允许不同版本的rpm安装
obsoletes=1 update 的一个参数是否可以允许旧版本的运行
gpgcheck=1 验证秘钥
plugins=1 是否允许插件1代表可以
installonly_limit=5 保存几个内核 5代表5个yum的repo配置文件中可用的变量:
$releasever: 当前OS的发行版的主版本号,如:8,7,6
$arch: CPU架构,如:aarch64, i586, i686,x86_64等
$basearch:系统基础平台;i386, x86_64
$contentdir:表示目录,比如:centos-8,centos-7
$YUM0-$YUM9:自定义变量
(2)仓库设置文件
[root@localhost]# cd /etc/yum.repos.d
[root@localhost yum.repos.d]# ls /etc/yum.repos.d/
bak CentOS-Debuginfo.repo CentOS-Sources.repo
CentOS-Base.repo CentOS-fasttrack.repo CentOS-Vault.repo
CentOS-CR.repo CentOS-Media.repoPS:这里默认的yum仓库是centos官方的yum源,需要联网才可以使用
(3)日志文件
[root@localhost]# cd /etc/yum.repos.d
[root@localhost yum.repos.d]# cat /var/log/yum.log (查看日志文件)
2.yum命令
命令 | 不加关键字 | 加入关键词、软件包、软件包组 |
---|---|---|
yum list | 显示所有可用包 | 单个的可安装包 |
yum info | 显示所有可用包的信息 | 单个具体的信息 |
yum search | \ | 模糊查找所有的相关信息 |
yum whatprovides | \ | 精确查找 |
yum grouplist | 显示所有可用包组 | 显示具体的包组 |
yum groupinfo | 显示所有的包组具体信息 | 显示具体的包组的具体信息 |
yum install | \ | 安装具体软件包 |
yum groupinstall | \ | 安装具体软件包组 |
yum update | 所有软件升级 | 具体软件升级 |
yum groupupdate | 所有包组升级 | 具体包组升级 |
yum remove | \ | 卸载具体软件 |
yum groupremove | \ | 卸载具体包组软件 |
yum history | 查看当前yum操作历史 | \ |
yum history undo | 加入序号卸载序号里安装的软件 | \ |
PS:红色字体为查询命令
蓝色字体为yum安装升级
黄色字体为软件卸载
三.搭建仓库的方式
1.搭建本地yum仓库
[root@localhost ~]# mount /dev/sr0 /mnt/
mount: /dev/sr0 写保护,将以只读方式挂载
[root@localhost ~]# cd /etc/yum.repos.d/
[root@localhost yum.repos.d]# mkdir bak
[root@localhost yum.repos.d]# mv *.repo bak/
[root@localhost yum.repos.d]# vim a.repo
[a]
name=a
baseurl=file:///mnt
enabled=1
gpgcheck=0
:wq
[root@localhost yum.repos.d]# yum clean all
[root@localhost yum.repos.d]# yum install -y [软件名]
2.搭建云仓库(http外网环境)
(1)切换到 yum.repo.d 目录 将自带的仓库移走
[root@localhost ~]# cd /etc/yum.repos.d/
[root@localhost yum.repos.d]# mkdir bak
[root@localhost yum.repos.d]# mv *.repo bak/(2)新建aliyun仓库(这里以阿里云为例)
[root@localhost yum.repos.d]# vim ali.repo
[ali]
name=aliyun
#baseurl=https://mirrors.aliyun.com/centos/7/os/x86_64/
baseurl=https://mirrors.aliyun.com/centos/$releasever/os/$basearch
gpgcheck=0[epel] //epel源仓库
name=epel
baseurl=https://mirrors.aliyun.com/centos/7/extras/x86_64/
gpgcheck=0[update] //更新包仓库
name=update
baseurl=https://mirrors.aliyun.com/centos/7/updates/x86_64/
gpgcheck=0:wq
[root@centos7 ~]#yum -y install 【软件名】
yum源地址
CentOS系统的yum源
#阿里云
https://mirrors.aliyun.com/centos/$releasever/
#腾讯云
https://mirrors.cloud.tencent.com/centos/$releasever/
#华为云
https://repo.huaweicloud.com/centos/$releasever/
#清华大学
https://mirrors.tuna.tsinghua.edu.cn/centos/$releasever/
EPEL的yum源
#阿里云
https://mirrors.aliyun.com/epel/$releasever/x86_64
#腾讯云
https://mirrors.cloud.tencent.com/epel/$releasever/x86_64
#华为云
https://mirrors.huaweicloud.com/epel/$releasever/x86_64
#清华大学
https://mirrors.tuna.tsinghua.edu.cn/epel/$releasever/x86_64#更新源
http://mirrors.aliyun.com/centos/$releasever/updates/$basearch/ http://mirrors.aliyuncs.com/centos/$releasever/updates/$basearch/ http://mirrors.cloud.aliyuncs.com/centos/$releasever/updates/$basearch/
3.ftp方式搭建云仓库
四、NFS共享
1.简介
NFS(Network File System 网络文件服务) NFS 是一种基于 TCP/IP 传输的网络文件系统协议,最初由 Sun 公司开发。 通过使用 NFS 协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源 NFS 也是 NAS 存储 设备必然支持的一种协议
2.特点
(1)采用TCP/IP传输网络文件
(2)安全性低
(3)简单易操作
(4)适合局域网环境
3.原理
4.优势
节省本地存储空间,将常用的数据如:/home 目录,存放在NFS服务器上且可以通过网络访问,将减少本地磁盘的使用率
5.搭建过程
五、总结
这次主要讲了yum仓库的搭建以及NFS,希望对大家有所帮助!