yum函数介绍以及自建yum仓库

一、前言

    在之前介绍了yum的配置(详细请移步 http://www.178linux.com/archives/6445)。但是有没有发现一个问题,虽然我们已将仓库指向一个可用的仓库服务器,但是随着Linux的不断升级和改版,我们是否还需要不断的去修改仓库的配置文件,如果只有一台还好,那如果我们有多台Linux系统,那么修改工作量将会很大,那么我们要怎么保证自己的仓库永远指向的是最新的仓库呢? 这就是yum函数的魅力。


二、yum函数介绍

    在RPM介绍(详细请移步 http://www.178linux.com/archives/6383 )中我们介绍2个国内比较有名的RPM包下载路径(mirrors.163.com 和mirrors.sohu.com),其中会有一个特殊文件夹路径,这为理解yum函数很重要,下面用 mirrors.163.com ,以CentOS6系统为例介绍

   仓库 6.png4.png

让我们查看yum仓库中的“CentOS-Base.repo”中的文件

5.png

其中画了红色框框的就是yum的函数

    $releaserver:代表系统的版本,对Yum而言指的是redhat-releaser版本,指向发行版的主版本号;只替换为主版本号,如RedHat 6.5 ,则替换为6

    $basearch:系统基本架构,如果是i686,i586等基本架构就为i386

    $arch:系统架构

#比如我现在的系统是CentOS6.5,系统架构是x86_64,则
#baseurl=http://mirrors.163.com/centos/$releasever/os/$basearch/ 会自动替换为 baseurl=http://mirrors.163.com/centos/6/os/x86_64/


三、如何自建yum仓库

    3.1、引言:

        虽然系统自带的仓库已经很常用,只要连接到互联网我们就能很容易有获取到互联网的yum仓库。但是如果是在企业内网,企业内部不允许访问互联网,又或者如果企业服务器众多,如果都要从互联网去获取yum仓库,那将很占用带宽。基于这种情况,我们就需要自己在企业内部创建yum仓库。

    3.2、自建仓库需要使用的命令介绍

        createrepo(create repo):创建仓库,在自建仓库时,使用命令createrepo会自动帮我们生成repodata文件作为软件的仓库,而其目录下有四个必要文件:filelists.xml.gz,other.xml.gz,primary.xml.gz和repomd.xml,其中最重要的是repomd.xml文件。一般出现的找不到repodata目录或文件的错误的原因通常有三个:一是路径问题;二是没有生成repodate目录;三是*.repo配置文件冲突(这个需要特意注意)。

小贴士createrepo命令默认是没有安装,所以我们需要提前安装,createrepo的安装包为“createrepo-0.9.9-17.el6.noarch.rpm”,可以使用RPM或yum先将此程序包安装。

#安装方法:
#yum -y install createrepo 或 rpm -ivh createrepo-0.9.9-17.el6.noarch.rpm (路径一定要写对)

    3.3、自建yum仓库有2种方法

        1)、基于关盘镜像创建yum仓库

        2)、根据服务自建提供yum仓库的服务器(ftp、http、nfs)

    3.4、基于关盘镜像创建yum仓库

        3.4.1、先将光盘挂载至/mnt目录下

            mount /dev/cdrom /mnt

        3.4.2、配置yum仓库文件(详细方法请移步查阅 http://www.178linux.com/archives/6445)

[root@www yum.repos.d]# vim /etc/yum.repos.d/local-media.repo  #如果local-media.repo不存在,请直接创建
[Meida-repo]
name=This is Local media repo
baseurl=           #指向光盘镜像路径
enabled=1                     #是否启动该仓库
gpgcheck=0                    #是否检查包完整性
[root@www yum.repos.d]# yum clean all   #清除所有的包缓存和元数据
[root@www yum.repos.d]# yum list        #列出所有的仓库和程序包

仓库1.png

仓库2.png

    3.5、根据服务自建提供yum仓库的服务器(这里以http服务为例)

        3.5.1、首先安装http服务

                yum -y install httpd 或 rpm -ivh httpd

        3.5.2、关闭Linux防火墙和Selinux

#防火墙和Selinux可能会影响用户访问HTTP,所以这里需要将其禁用
[root@www yum.repos.d]# service iptables stop    #关闭防火墙服务
[root@localhost ~]# chkconfig iptables off       #关闭防火墙自动启动
[root@www yum.repos.d]# getenforce               #查看Selinux状态 Enforcing表示启用 Permissive表示不启用
Enforcing
[root@www yum.repos.d]# setenforce 0             #关闭Selinux  0表示关闭 1表示开启
[root@www yum.repos.d]# getenforce               
Permissive                                
[root@localhost ~]# vim /etc/selinux/config     #关闭Selinux开机启动,编辑confg文件,将其中SELINUX字段改为如下设置    
        SELINUX=disabled

        3.5.3、启动httpd服务和开机自动服务

[root@www yum.repos.d]# service httpd start   #开启httpd服务
[root@www yum.repos.d]# chkconfig on          #设置httpd服务开机自动启动
[root@localhost ~]# netstat -tunlp | grep http  #查看http服务是否已启用
tcp        0      0 :::80                       :::*                        LISTEN      1532/httpd

        3.5.4、编辑httpd的文档目录

#httpd默认的目录文档路径为/var/www/html

[root@localhost html]# mkdir /var/www/html/rpm-repo   #创建仓库路径

[root@localhost rpm-repo]# cp -a /mnt/Packages/xcb* /var/www/html/rpm-repo/   #拷贝RPM程序包为测试使用

        3.5.5、使用createrepo配置yum仓库

[root@localhost rpm-repo]# createrepo /var/www/html/rpm-repo/

create.png

1.png

blob.png

        3.5.6、验证和查看http仓库的文件

2.png

        3.5.7、配置和验证yum仓库

[root@localhost yum.repos.d]# vim /etc/yum.repos.d/local.repo   #编辑yum仓库文件,让仓库路径指向http的yum仓库
[http-repo]
name=http yum repo
baseurl=http://192.168.80.150/rpm-repo
enabled=1
gpgcheck=0
[root@localhost ~]# yum list

3.png

实验完成!

小贴士:之前有介绍过yum的函数,有兴趣的话可以在这个实验中也尝试使用yum函数调用仓库,熟悉使用yum仓库对日后工作有很大帮助。

 

原创文章,作者:螃蟹,如若转载,请注明出处:http://www.178linux.com/6510

(0)
上一篇 2015-07-24 21:56
下一篇 2015-07-24 21:58

相关推荐

  • linux中nmcli命令使用及网络配置

      Red Hat Enterprise Linux 7 与 CentOS 7 中默认的网络服务由 NetworkManager 提供,这是动态控制及配置网络的守护进程,它用于保持当前网络设备及连接处于工作状态,同时也支持传统的 ifcfg 类型的配置文件。  NetworkManager 可以用于以下类型的连接:Ethernet,VLA…

    Linux干货 2016-09-10
  • iptables

    一、机制 部队大院、高档私人住宅区都是在一个被保护起来的范围内,要想进入只能从各个大门进入,在进入的时候还在门口出示证件、或者是指纹识别、或者是保安身份认证等,只有通过了这些检查才能进入到大院、住宅区内部。 Linux系统也是这么一个大院,netfilter就是这个大院的围墙,prerouting、input、output、forward、postrouti…

    Linux干货 2017-01-13
  • centos系列初步搭建LAMP

    centos6搭建LAMP 系统环境 ip=192.168.0.105 selinux为:setenforce 0 iptables 为stop 客户机需要修改hosts文件 1.192.168.2.105 www1.stuX.com2.192.168.2.105 www2.stuX.com 安装LAMP组件 1.yum install …

    Linux干货 2016-12-11
  • lvs——高可用集群

    技术简介: LVS集群采用IP负载均衡技术和基于内容请求分发技术。调度器具有很好的吞吐率,将请求均衡地转移到不同的服务器上执行,且调度器自动屏蔽掉服务器的故障,从而将一组服务器构成一个高性能的、高可用的虚拟服务器。整个服务器集群的结构对客户是透明的,而且无需修改客户端和服务器端的程序。为此,在设计时需要考虑系统的透明性、可伸缩性、高可用性和易管理性 集群采用…

    Linux干货 2016-10-26
  • Linux下装载软Raid

    步骤1.创建磁盘,并转换为fd #fdisk /dev/sdb //这里使用新的磁盘sdb 然后输入n ,创建分区 使用默认的起始点 输入大小为+100M 然后重复刚才的操作4次,创建4个分区,创建完4个分区后 我们还要改变分区的ID 在分区的主菜单输入T 然后输入要改变ID的分区号,也就是最后4个分区 然后输入分区的ID:fd 四个分区都改成FD 完成后,…

    Linux干货 2017-08-12
  • Linux软件包管理器—rpm

    rpm 最开始是Red Hat Package Manager 之意,原用在Red Hat Linux一款软件包管理器,先在已被许多其他Linux 发行商使用,成为主流包管理器,rpm包的文件格式也写进Linux标准库中,所以rpm 现在递归意为RPM Package Manager。rpm的诞生使得在Linux上管理软件包变得方便许多,rpm功能强大,可完成构建、安装、查询、校验、升级和卸载软件包。

    Linux干货 2016-08-26