JavaEE鸿蒙应用开发HTML&JS+前端Python+大数据开发人工智能开发AI+设计软件测试新媒体+短视频直播运营产品经理集成电路应用开发(含嵌入式)Linux云计算+运维开发C/C++拍摄剪辑+短视频制作PMP项目管理认证电商运营Go语言与区块链大数据PHP工程师Android+物联网iOS.NET

玩转Linux下yum源配置

来源:黑马程序员

浏览51877人

2019.07.09

教你分分钟搞定Linuxyum源配置

Linux操作系统对于我们技术人员,不管是开发,测试还是运维都应该是耳熟能详的一个操作系统。既然如此,那么就绕不开在Linux操作系统下安装软件包。在Linux下安装软件包的方式有三种,分别是rpm安装、源码编译安装、yum安装。接下来我们就重点介绍一下最常用、最好用的一种安装方式,即yum方式安装,因为它能够帮助我们解决软件包之间的依赖关系来提高工作效率哦

一、yum知多少

1. yum是如何安装软件的

1.png

l  yum仓库(也称yum源)用于存放各种rpm的软件包以及软件包之间的依赖关系(repodata目录)

l  需要安装软件的计算机连接到指定yum仓库来安装软件包

2. yum源作用

软件包管理器,类似Windows下的软件管家。

3. yum源优势

解决软件包之间的依赖关系,提高运维人员的工作效率。

4. yum源分类

本地yum

所谓本地yum源是指yum仓库在本地,一般是本地系统光盘或镜像文件。

网络yum

所谓网络yum源是指yum仓库在远程(不在本地),需要联网才能安装。

·         国内较知名的网络源(aliyun源,163源,sohu源,知名大学开源镜像等)

·         国外较知名的网络源(centos源、redhat源、红帽扩展epel源等)

·         特定软件相关的网络源(NginxMySQLZabbix等)

二、yum源配置

说明:以下操作系统以Centos 6.5为例,其他Linux系统类似。

1. 本地yum源配置

挂载镜像到本地操作系统

手动挂载光盘到指定目录

[root@Heima ~]# mount -o ro /dev/sr0 /mnt

开机自动挂载

[root@Heima ~]# echo "mount -o ro /dev/sr0 /mnt" >> /etc/rc.local

或者

[root@Heima ~]# echo "/dev/sr0 /mnt iso9660 defaults,ro 0 0" >> /etc/fstab

 

说明:

1. /etc/rc.local文件是操作系统开机最后读取的一个文件,该文件需要有可执行权限,开机时系统会帮你自动挂载,建议使用该方式。

2. /etc/fstab文件也可以,但是如果修改错误可能会导致系统起不来。

通过配置文件指定yum仓库

进入到指定目录里,清空操作系统默认的Centos

[root@Heima ~]# cd /etc/yum.repos.d/

[root@Heima yum.repos.d]# rm -f ./*

在该目录下创建以.repo结尾的文件

[root@Heima yum.repos.d]# vim local.repo

[local]                  仓库的名字,不要有特殊符号(自定义)

name=local yum           仓库描述,可以不写

baseurl=file:///mnt      指定yum仓库的路径(重要),file://表示本地仓库

enabled=1                表示启用该仓库,1表示启用;0表示不启用

gpgcheck=0           不用校验仓库里软件包的签名,0表示不校验;1表示校验

2. 网络yum配置

方法1

直接通过修改配置文件来指定yum仓库即可。

特定软件的网络源:

[root@Heima yum.repos.d]# cat nginx.repo

[nginx]

name=nginx repo

baseurl=http://nginx.org/packages/centos/6/$basearch/

gpgcheck=0

enabled=1

 

基本软件的网络源:

[root@Heima yum.repos.d]# cat 163.repo

[163]

name=163 network yum

baseurl=http://mirrors.163.com/centos/6/os/x86_64/

enabled=1

gpgcheck=1

gpgkey=http://mirrors.163.com/centos/6/os/x86_64/RPM-GPG-KEY-CentOS-6

 

[root@Heima yum.repos.d]# cat aliyun.repo

[aliyun]

name=aliyun

baseurl=http://mirrors.aliyun.com/centos/6/os/x86_64/

enabled=1

gpgcheck=1

gpgkey=http://mirrors.aliyun.com/centos/6/os/x86_64/RPM-GPG-KEY-CentOS-6

方法2

通过安装软件包,自动创建.repo文件(自动配置)。

配置epel源为例:

1)下载epel源软件包

[root@Heima ~]# wget -P /tmp https://mirrors.aliyun.com/epel/6/x86_64/epel-release-6-8.noarch.rpm --no-check-certificate

--2019-02-20 09:42:41--  https://mirrors.aliyun.com/epel/6/x86_64/epel-release-6-8.noarch.rpm

Resolving mirrors.aliyun.com... 119.96.206.232, 116.211.153.230, 116.211.153.236, ...

Connecting to mirrors.aliyun.com|119.96.206.232|:443... connected.

WARNING: certificate common name “img.ucdl.pp.uc.cn” doesn’t match requested host name “mirrors.aliyun.com”.

HTTP request sent, awaiting response... 200 OK

Length: 14540 (14K) [application/x-redhat-package-manager]

Saving to: “/tmp/epel-release-6-8.noarch.rpm”

 

100%[================================================================================>] 14,540      --.-K/s   in 0.03s  

 

2019-02-20 09:42:41 (538 KB/s) - “/tmp/epel-release-6-8.noarch.rpm” saved [14540/14540]

2)安装软件包

[root@Heima ~]# rpm -ivh /tmp/epel-release-6-8.noarch.rpm

warning: /tmp/epel-release-6-8.noarch.rpm: Header V3 RSA/SHA256 Signature, key ID 0608b895: NOKEY

Preparing...                ########################################### [100%]

   1:epel-release           ########################################### [100%]

3)检查配置文件

[root@Heima ~]# ls /etc/yum.repos.d/epel*

/etc/yum.repos.d/epel.repo  /etc/yum.repos.d/epel-testing.repo

三、yum工具相关命令

# yum install package -y

默认是安装来自仓库里的软件,指定的是软件名字。多个包空格隔开;-y (取消交互)

# yum install ./xxx.rpm

或者

# yum localinstall ./xxx.rpm

安装来自本地指定路径下的rpm包,而不是来自仓库

# yum remove 或者 erase package

卸载软件包

# yum update

更新仓库里所有比本机已经安装过的软件要的软件   

# yum update package

指定升级的软件

# yum search mysql

搜索出所有软件名字“mysql”关键字的软件

# yum provides  "libaudiofile.so.0"

找出模块由哪些软件包提供

# yum clean all

清空之前的yum列表缓存

# yum makecache

创建新的缓存

# yum list

列出仓库里的所有软件包

# yum repolist

列出已配置的软件仓库

# yum list |grep 关键字

@代表已经安装成功

# yum list installed

查看已安装的包

# yum grouplist

查看包组

# yum groupinstall  "包组"

安装包组

# yum groupremove "包组"

四、总结

1. yumLinux下用于安装rpm软件包的一个工具,要使用它安装软件包,必须提前配置yum

2. yum源分为本地yum网络yum。本地yum源指软件仓库在本地;网络yum源指软件仓库在远程。

3. 软件仓库里既有软件包也要有repodata目录,即存放软件之间的依赖关系

4. yum工具安装rpm软件包的最大优势就是解决软件包的依赖关系,提高工作效率。