zoukankan      html  css  js  c++  java
  • redhat yum服务器搭建

    yum基本概念

    yum是Yellow dogUpdater Modified的简称,起初是由yellow dog这一发行版的开发者Terra Soft研发,用python写成,那时还叫做yup(yellow dog updater),后经杜克大学的Linux@Duke开发团队进行改进,遂有此名。yum的宗旨是自动化地升级,安装/移除rpm包,收集rpm包的相关信息,检查依赖性并自动提示用户解决。yum的关键之处是要有可靠的repository,顾名思义,这是软件的仓库,它可以是http或ftp站点,也可以是本地软件池,但必须包含rpm的header, header包括了rpm包的各种信息,包括描述,功能,提供的文件,依赖性等.正是收集了这些 header并加以分析,才能自动化地完成余下的任务。

    repository 是用 yum-arch 或者 createrepo命令创建的,也可以用别人已有的 repository 作为镜像。

    Yum 有以下特点:

    1)        *可以同时配置多个资源库(Repository)

    2)        *简洁的配置文件(/etc/yum.conf)

    3)        *自动解决增加或删除rpm包时遇到的倚赖性问题

    4)        *使用方便

    5)        *保持与RPM数据库的一致性

    YUM的基本工作流程如下:

             服务器端:在服务器上面存放了所有的RPM软件包,然后以相关的功能去分析每个RPM文件的依赖性关系,将这些数据记录成文件存放在服务器的某特定目录内。

             客户端:如果需要安装某个软件时,先下载服务器上面记录的依赖性关系文件(可通过WWW或FTP方式),通过对服务器端下载的纪录数据进行分析,然后取得所有相关的软件,一次全部下载下来进行安装。

    2、yum 软件包安装

    2.1 Yum包确认

    [oracle@xml-ora1 ~]$ rpm -q rpm

    rpm-4.4.2.3-18.el5

             用rpm –q 查询软件包是否已经安装,如果没有安装则需要先下载或者使用光盘里的rmp包进行安装

    2.2 Yum包下载安装

    可以用wget 直接从http://yum.baseurl.org/download/网上下载,或者光盘自带的rpm包来进行安装。

    3、yum操作配置说明

    3.1 yum基本操作指令

    yum 的基本操作包括软件的安装(本地,网络),升级(本地,网络),卸载,另外还有一定的查询功能。设定好了本地的yum之后,就可以很方便的进行安装。

    [oracle@xml-ora1 ~]$ yum --help

    usage: yum [options] COMMAND

    List of Commands:

    check-update   Check for available package updates(列出所有可更新的软件清单)

    clean          Remove cached data(清除yum缓存)

    deplist        List a package's dependencies(列出指定软件包所有依赖的软件清单)

    downgrade      downgrade a package

    erase          Remove a package or packages fromyour system(删除指定已安装的软件包)

    groupinfo      Display details about a package group(列出组件包含的软件清单)

    groupinstall   Install the packages in a group on yoursystem(安装组件)

    grouplist      List available package groups(列出所有可安装的组件清单)

    groupremove    Remove the packages in a group from yoursystem(清除组件)

    help           Display a helpful usage message(列出yum所有指令说明)

    info           Display details about a package orgroup of packages(获取所有或者指定包的详细信息)

    info-security  Returns security data for the packageslisted, that affects your system

    install        Install a package or packages on yoursystem(仅安装所有或者指定的软件)

    list           List a package or groups of packages(列出所有或者指定的软件清单)

    list-security   Returnssecurity data for the packages listed, that affects your system

    localinstall    Installa local RPM(本地安装rpm软件包)

    makecache     Generate the metadata cache(生成数据缓存)

    provides       Find what package provides the givenvalue(列出软件包提供哪些文件)

    reinstall       reinstalla package(重新安装指定软件包)

    repolist       Display the configured softwarerepositories(显示软件仓库的配置)

    resolvedep     Determine which package provides the givendependency(哪个包提供依赖)

    search         Search package details for the givenstring(根据关键字模糊查找软件包)

    shell          Run an interactive yum shell(运行交互式的yum shell)

    update         Update a package or packages on yoursystem(安装所有或所有可更新软件)

    update-minimal    Works like update, but goes to the 'newest'package match which fixes a problem that affects your system

    upgrade        Update packages taking obsoletes intoaccount(大规模的版本升级,与yum update不同的是,连旧的淘汰的包也升级)

    remove                 Remove a package or packages on your system (删除指定已安装的软件)

    options:

      -h,--help          show this help messageand exit

      -t,--tolerant        be tolerant of errors (遇到错误继续运行yum)

     -C                run entirelyfrom cache, don't update cache(完全从缓冲区的程序包运行yum,缓冲区默认为/var/yum/cache)

     -c  [config file]     config file location(使用不同默认/etc/yum.conf之外的配置文件)

     -R  [minutes]       maximum command wait time(设置以分钟计算的等待时间)

     -d  [debug level]    debugging output level(代替/etc/yum.conf中的调试级别)

     --showduplicates     showduplicates, in repos, in list/search commands

     -e  [error level]     error output level(设置错误消息的级别。配置脚本级别设置为0)

      -q,--quiet           quiet operation(静默安装,不提示信息)

      -v,--verbose         verbose operation(查看rpm版本)

     -y                  answer yes forall questions(设置自动回答选项为y)

     --version            show Yumversion and exit(显示 YUM版本信息并退出)

     --installroot=[path]    set install root(设置为root安装)

    --enablerepo=[repo]  enableone or more repositories (wildcards allowed)(启用软件仓库)

     --disablerepo=[repo]  disable oneor more repositories (wildcards allowed)(禁用软件仓库)

      -x[package], --exclude=[package]   excludepackage(s) by name or glob

     --disableexcludes=[repo]  disableexclude from main, for a repo or for everything

     --obsoletes           enableobsoletes processing during updates

     --noplugins           disable Yumplugins(禁掉yum插件)

     --nogpgcheck          disable gpgsignature checking(禁掉GPG验证检查)

     --disableplugin=[plugin]  disableplugins by name( 用名称禁掉插件)

     --enableplugin=[plugin]   enableplugins by name( 用名称启用插件)

     --skip-broken         skippackages with depsolving problems( 忽略包的依赖问题)

     --color=COLOR         controlwhether color is used(设置是否启用颜色)

     --security            Includesecurity relevant packages

     --cve=CVE             Includepackages needed to fix the given CVE

     --bz=BZ               Includepackages needed to fix the given BZ

     --advisory=ADVISORY   Includepackages needed to fix the given advisory

     Plugin Options:

    yum list的特殊用法:

    列出所有可更新的软件清单

    命令:yum list updates

    列出所有已安装的软件包

    命令:yum list installed

    列出已安装但不在资源库的软件包

    命令:yum list extras

    yum info 特殊用法:

    列出所有软件包的信息

    命令:yum info

    列出所有可更新的软件包信息

    命令:yum info updates

    列出所有已安裝的软件包信息

    命令:yum info installed

    列出所有已安裝但不在YumRepository內的软件包信息

    命令:yum info extras

    清除YUM缓存特殊用法:

    yum 会把下载的软件包和header存储在cache中,而不会自动删除。如果我们觉得它们占用了磁盘空间,可以使用yum clean指令进行清除,更精确的用法是yum clean headers清除header,yum clean packages清除下载的rpm包。

    清除缓存目录(/var/cache/yum)下的软件包

    命令:yum clean packages

    清除缓存目录(/var/cache/yum)下的headers

    命令:yum clean headers

    清除缓存目录(/var/cache/yum)下旧的headers

    命令:yum clean oldheaders

    清除缓存目录(/var/cache/yum)下的软件包及旧的headers

    命令:yum clean, yum cleanall (= yum clean packages; yum clean oldheaders)

    3.2 /etc/yum.conf配置文件详解

    yum的配置一般有两种方式,一种是直接配置/etc目录下的yum.conf文件,另外一种是在/etc/yum.repos.d目录下增加.repo文件。

    yum的配置文件:

    [root@xml-oms yum]# cat /etc/yum.conf

    [main]

    cachedir=/var/cache/yum      #yum下载的RPM包的缓存目录

    keepcache=0                               #缓存是否保存,1保存,0不保存

    debuglevel=2                               #调试级别(0-10),默认为2

    logfile=/var/log/yum.log           #yum的日志文件所在的位置

    distroverpkg=redhat-release  #yum会根据软件包判断你的发行版本,默认是redhat-release,也可以是安装的任何针对自己发行版的rpm包。

    tolerant=1                                    #表示yum是否容忍命令行发生与软件包有关的错误,比如要安装1,2,3三个包,其中3此前已经安装了,如果你设为1,则yum不会出现错误信息。

    exactarch=1                                 #是否只升级和你安装软件包cpu体系一致的包,如果设为1,则如你安装了一个i386的内核,则yum不会用i686的包来升级。

    obsoletes=1                                 #update的参数,相当于upgrade,是否允许更新陈旧的RPM包

    gpgcheck=1                                  #是否检查GPG(GNU Private Guard),一种密钥方式签名

    plugins=1                                      #是否允许使用插件,默认是1允许

    exclude=selinux*          #屏蔽不想更新的RPM包,可用通配符,多个RPM包之间使用空格分离。

    retries=1                                       #网络连接发生错误后的重试次数,如果设为0,则会无限重试

    pkgpolicy=newest                  #包的策略。一共有两个选项,newest和last,这个作用是如果你设置了多个repository,而同一软件在不同的repository中同时存在,yum应该安装哪一个,如果是newest,则yum会安装最新的那个版本。如果是last,则yum会将服务器id以字母表排序,并选择最后的那个服务器上的软件安装。一般都是选newest。

    # Note: yum-RHN-plugin doesn't honor this.

    metadata_expire=1h                #用于指定信息库数据库的有效期,单位为秒。

    # Default.

    # installonly_limit = 3                #允许保留多少个内核包

    # PUT YOUR REPOS HERE OR IN separate filesnamed file.repo

    # in /etc/yum.repos.d

    3.3 /etc/yum.repos.d/中的文件

    该目录的默认版本中只有1个文件。这个repo文件是Linux中yum源(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪里下载需要安装或者升级的软件包,repo文件中的设置内容将被yum读取和应用。

    [root@dataserver01 ~]# ll /etc/yum.repos.d/*

    -rw-r--r-- 1 root root 561 Mar 10  2010 /etc/yum.repos.d/rhel-debuginfo.repo

    [oracle@dataserver01 ~]$ cat/etc/yum.repos.d/rhel-debuginfo.repo

    [rhel-debuginfo]

    name=Red Hat Enterprise Linux $releasever -$basearch - Debug

    baseurl=ftp://ftp.redhat.com/pub/redhat/linux/enterprise/$releasever/en/os/$basearch/Debuginfo/

    enabled=0

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    [rhel-debuginfo-beta]

    name=Red Hat Enterprise Linux $releaseverBeta - $basearch - Debug

    baseurl=ftp://ftp.redhat.com/pub/redhat/linux/beta/$releasever/en/os/$basearch/Debuginfo/

    enabled=0

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    所有服务器设置都应该遵循如下格式:

    [serverid]

    name=name $releasever – $basearch  

    baseurl=url://

    url://

    enabled=

    gpgcheck=

    gpgkey=

    参数说明:

    serverid: 用于指定一个仓库,用于区别各个不同的repository,必须是一个唯一的名称。

    mirrorlist:镜像站点列表,寻找可用的repository,mirrorlist和baseurl两者仅用一个即可。

    baseurl:    当mirrorlist注释掉后,这个选项就是服务设置中最重要的部分,必须设置正确。其中的url: 支持的协议有 http://ftp:// file://三种。baseurl后可以跟多个url,你可以自己改为速度比较快的镜像站,但baseurl只能有一个,其中url指向的目录必须是这个repository header目录的上一级,也支持$releasever $basearch这样的变量。

    name:   是对repository的描述,定义了软件仓库的名称,一般没什么作用。支持像$releasever$basearch这样的变量。

    $releasever:变量定义了发行版本,通常是8,9,10等数字

    $basearch:变量定义了系统的架构,可以是i386、x86_64、ppc等值。cpu的基本体系组,如i686和athlon同属i386。

    failovermethode: 有两个选项roundrobin和priority,意思分别是有多个url可供选择时,yum选择的次序,roundrobin是随机选择,如果连接失 败则使用下一个,依次循环,priority则根据url的次序从第一个开始。如果不指明,默认是roundrobin。

    enable:   用于指定是否使用本仓库,默认值为1,即可用

    gpgcheck:    这个选项表示这个repo中下载的rpm将进行gpg的校验,已确定rpm包的来源是有效和安全的.

    gpgkey:    定义用于校验的gpg密钥,可用手动导入密钥。

    3.4 导入密钥

    导入每个reposity的GPG key,yum可以使用gpg对包进行校验,确保下载包的完整性,所以我们先要到各个repository站点找到gpg key,一般都会放在首页的醒目位置,一些名字诸如 RPM-GPG-KEY.txt之类的纯文本文件,把它们下载,然后用rpm --importxxx.txt命令将它们导入,最好把发行版自带GPG-KEY也导入,rpm --import /usr/share/doc/redhat-release-*/RPM-GPG-KEY官方软件升级用的上。

    查看官方密钥:

    [oracle@dataserver01 ~]$ find / -type f -name"RPM-GPG-KEY*"

    [oracle@dataserver01 ~]$ ll/etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-*

    -rw-r--r-- 1 root root 1175 Mar 10  2010 /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-auxiliary

    -rw-r--r-- 1 root root 1706 Mar 10  2010 /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta

    -rw-r--r-- 1 root root 1990 Mar 10  2010/etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-former

    -rw-r--r-- 1 root root 1164 Mar 10  2010 /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    -rw-r--r-- 1 root root  885 Mar 10 2010 /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-rhx

    导入密钥:

    [oracle@dataserver01 ~]$

    rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY*

    或者

    rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5

    rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-beta

    4、挂载光盘搭建本地YUM服务器

    4.1 服务器端挂载光盘

    [root@xml-ora1 mnt]# mount /dev/cdrom/mnt/cdrom/

    mount: block device /dev/cdrom iswrite-protected, mounting read-only

    [root@xml-ora1 mnt]# ll /mnt/cdrom/

    total 3770

    dr-xr-xr-x 3 root root   8192 Mar 22 2010 Cluster

    dr-xr-xr-x 3 root root   8192 Mar 22 2010 ClusterStorage

    -r--r--r-- 8 root root   8445 Sep 3  2008 EULA

    -r--r--r-- 3 root root   8445 Mar 10 2010 eula.en_US

    -r--r--r-- 8 root root  18416 Dec 1  2006 GPL

    dr-xr-xr-x 4 root root   2048 Mar 22 2010 images

    dr-xr-xr-x 2 root root   2048 Mar 22  2010 isolinux

    4.2 客户端修改yum源

    yum的一切配置信息都储存在一个叫yum.conf的配置文件中,通常位于/etc目录下,是整个yum系统的核心。先copy原yum源文件备份,然后用vim编辑yum文件并保存:

    [root@xml-ora1 cdrom]# cp/etc/yum.repos.d/rhel-debuginfo.repo /etc/yum.repos.d/rhel-debuginfo.repo.bak

    [root@xml-ora1 cdrom]# vi/etc/yum.repos.d/rhel-debuginfo.repo

    [root@xml-ora1 cdrom]# more/etc/yum.repos.d/rhel-debuginfo.repo

    [Cluster]

    name=Red Hat Enterprise Linux $releasever -$basearch - Cluster

    baseurl=file:///mnt/cdrom/Cluster

    enabled=1

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    [ClusterStorage]

    name=Red Hat Enterprise Linux $releasever -$basearch - ClusterStorage

    baseurl=file:///mnt/cdrom/ClusterStorage

    enabled=1

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    [Server]

    name=Red Hat Enterprise Linux $releasever -$basearch - Server

    baseurl=file:///mnt/cdrom/Server

    enabled=1

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    [VT]

    name=Red Hat Enterprise Linux $releasever -$basearch - VT

    baseurl=file:///mnt/cdrom/VT

    enabled=1

    gpgcheck=1

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    配置文件社会自说明:

    1)        [ ]内的是仓库的名称

    2)        name是仓库的描述或者说资源名称

    3)        baseurl 仓库的位置,Yum源的目录获取路径

    4)        enabled 是否启用这个仓库,1为起用,0为禁用,本地设为1

    5)        gpgcheck 是否检查GPG签名(用来验证要安装的包是不是REDHAT官方的)

    4.3 客户端测试光盘Yum源使用

    出现如下信息,说明配置成功:

    [root@xml-ora1 etc]# yum grouplist

    Setting up Group Process

    Installed Groups:

      Administration Tools

      Legacy Software Development

      Legacy Software Support

      Mail Server

      Network Servers

      Server Configuration Tools

      System Tools

      Text-based Internet

       XWindow System

    Available Groups:

      Authoring and Publishing

      Cluster Storage

      Clustering

      DNS Name Server

      Development Libraries

      Development Tools

      Editors

      Engineering and Scientific

      FTP Server

      GNOME Desktop Environment

      GNOME Software Development

      Games and Entertainment

      Graphical Internet

      Graphics

      Java Development

      KDE (K Desktop Environment)

      KDE Software Development

      KVM

      Legacy Network Server

      MySQL Database

      News Server

      Office/Productivity

      OpenFabrics Enterprise Distribution

      PostgreSQL Database

      Printing Support

      Sound and Video

      Web Server

      Windows File Server

       XSoftware Development

      Xen

    Done

    5、Copy光盘搭建本地YUM服务器

    5.1 建立yum服务器目录

    创建一个存放放RPM所有安装包的目录,位置自定义:

    [root@xml-oms /]# mkdir -p /u01/yum

    5.2 copy光盘内容到yum服务器

    挂载光盘:

    [root@xml-oms cdrom]# mkdir -p /mnt/cdrom/

    [root@xml-oms cdrom]# mount /dev/cdrom /mnt/cdrom/

    mount: block device /dev/cdrom iswrite-protected, mounting read-only

    获取RPM包源,将ISO中的Server目录复制到本机需要安装YUM仓库的目录下:

    [root@xml-oms ~]# cp -r /mnt/cdrom/Server/  /u01/yum.

    5.3 createrepo工具安装

    yum 使用存储在每一个rpm包里的header信息摘要去完成它的工作,而这个摘要信息由'createrepo'程序创建,没有安装这个软件进行信息收集,系统是无法查询找到的。

    安装createrepo工具,然后用这个工具生成YUM通用数据库。

    [root@xml-oms Server]# rpm -q create*

    package createrepo-0.4.11-3.el5.noarch.rpmis not installed

    [root@xml-oms ~]# rpm -ivh/u01/yum/Server/createrepo-0.4.11-3.el5.noarch.rpm

    warning:/u01/yum/Server/createrepo-0.4.11-3.el5.noarch.rpm: Header V3 DSA signature:NOKEY, key ID 37017186

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

      1:createrepo            ########################################### [100%]

    5.4 createrepo创建yum仓库

    进入创建的YUM仓库目录/u01/yum,重建仓库信息配置文件(/u01/yum/目录下)

    [root@xml-oms ~]# cd /u01/yum/

    [root@xml-oms ~]# createrepo /u01/yum/

    1534/3116 -Server/tomcat5-servlet-2.4-api-javadoc-5.5.23-0jpp.7.el5_3.2.x86_64.2385/3116 -Server/jakarta-commons-collections-testframework-3.2-2jpp.3.x86_64.r2679/3116 -Server/jakarta-commons-collections-testframework-javadoc-3.2-2jpp.3.3116/3116 -Server/libFS-1.0.0-3.1.i386.rpm                                    

    Saving Primary metadata

    Saving file lists metadata

    Saving other metadata

    5.5 客户端配置yum源

    基于之前已经建立的YUM仓库,这里配置YUM客户端,进入/etc/yum.repos.d,创建yum.repo文件(满足*.repo即可),这里采用备份原配置文件,直接修改:

    [root@xml-oms yum]# cd /etc/yum.repos.d

    [root@xml-oms yum.repos.d]# ll

    total 12

    -rw-r--r-- 1 root root 561 Mar 10  2010 rhel-debuginfo.repo

    [root@xml-oms yum.repos.d]# cp rhel-debuginfo.repo  rhel-debuginfo.repo.bak

    [root@xml-oms yum.repos.d]# ll

    total 12

    -rw-r--r-- 1 root root 561 Mar 10  2010 rhel-debuginfo.repo

    -rw-r--r-- 1 root root 561 Nov 19 17:39rhel-debuginfo.repo.bak

    yum.repo文件配置信息修改为如下:

    [root@xml-oms yum.repos.d]# vi rhel-debuginfo.repo

    [Server]

    name=Server

    baseurl=file:///u01/yum/Server

    enabled=1

    gpgcheck=0

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    5.6 测试YUM仓库配置是否成功

    测试之前,最好把YUM的所有缓存清除一下

    [root@xml-oms yum.repos.d]# yum clean all

    Loaded plugins: rhnplugin, security

    Cleaning up Everything

    [root@xml-oms yum.repos.d]# yum grouplist

    Loaded plugins: rhnplugin, security

    This system is not registered with RHN.

    RHN support will be disabled.

    [root@xml-oms yum.repos.d]# yum install vsftpd

    [root@xml-oms yum.repos.d]# yum remove vsftpd

    6、FTP方式搭建远程YUM服务器(推荐)

    6.1 建立yum服务器目录

    创建一个存放放RPM所有安装包的目录,位置自定义:

    [root@xml-oms /]# mkdir -p /u01/yum

    6.2 copy光盘内容到yum服务器

    挂载光盘:

    [root@xml-oms cdrom]# mkdir -p /mnt/cdrom/

    [root@xml-oms cdrom]# mount /dev/cdrom /mnt/cdrom/

    mount: block device /dev/cdrom iswrite-protected, mounting read-only

    获取RPM包源,将ISO中的Server目录复制到本机需要安装YUM仓库的目录下:

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/Server//u01/yum

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/ClusterStorage//u01/yum/

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/VT/ /u01/yum/

    [root@xml-oms yum]# pwd

    /u01/yum

    6.3 安装FTP服务器

     [root@xml-omsyum.repos.d]# rpm -ivh/u01/yum/Server/vsftpd-2.0.5-16.el5_4.1.x86_64.rpm

    warning:/u01/yum/Server/vsftpd-2.0.5-16.el5_4.1.x86_64.rpm: Header V3 DSA signature:NOKEY, key ID 37017186

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

      1:vsftpd                ########################################### [100%]

    [root@xml-oms yum.repos.d]# chkconfig --list vsftpd

    vsftpd          0:off   1:off  2:off   3:off   4:off  5:off   6:off

    [root@xml-oms yum.repos.d]# chkconfig vsftpd on

    [root@xml-oms yum.repos.d]# chkconfig --list vsftpd

    vsftpd          0:off   1:off  2:on    3:on    4:on   5:on    6:off

    [root@xml-oms yum.repos.d]# service vsftpd status

    vsftpd is stopped

    [root@xml-oms yum.repos.d]# service vsftpd start

    Starting vsftpd for vsftpd: [  OK  ]

    [root@xml-oms yum.repos.d]# service vsftpd status

    vsftpd (pid 15673) is running...

    6.4 将FTP目录指向yum服务器目录

    这里使用将ftp目录指向yum服务器目录,在/etc/vsftpd/vstpd.conf末尾添加以下参数即可。或者可以移动系统盘中的RPM文件到FTP中,或者建立链接目录到yum服务器目录。

    [root@xml-oms ~]# vi /etc/vsftpd/vsftpd.conf

    ……

    vsftpd_log_file=/var/log/vsftpd.log

    use_localtime=YES

    anon_root=/u01/yum

    [root@xml-oms yum.repos.d]# service vsftpd restart

    Shutting down vsftpd: [  OK  ]

    Starting vsftpd for vsftpd: [  OK  ]

    在windows下测试ftp连通和有效性:

    C:UsersAdministrator>ftp 172.16.10.173

    连接到 172.16.10.173。

    220 (vsFTPd 2.0.5)

    用户(172.16.10.173:(none)): anonymous

    331 Please specify the password.

    密码:

    230 Login successful.

    ftp> ls

    200 PORT command successful. Consider usingPASV.

    150 Here comes the directory listing.

    Server

    Repodata

    6.5 createrepo工具安装

    yum 使用存储在每一个rpm包里的header信息摘要去完成它的工作,而这个摘要信息由'createrepo'程序创建,没有安装这个软件进行信息收集,系统是无法查询找到的。

    安装createrepo工具,然后用这个工具生成YUM通用数据库。

    [root@xml-oms Server]# rpm -q create*

    package createrepo-0.4.11-3.el5.noarch.rpmis not installed

    [root@xml-oms ~]# rpm -ivh/u01/yum/Server/createrepo-0.4.11-3.el5.noarch.rpm

    warning:/u01/yum/Server/createrepo-0.4.11-3.el5.noarch.rpm: Header V3 DSA signature:NOKEY, key ID 37017186

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

      1:createrepo            ########################################### [100%]

    6.6 createrepo重建仓库

             在RHEL 5中每个目录下的repodata目录下都有一个repomd.xml,该文件中就记录了rpm包的依赖关系,还有一个comps-rhel5-*.xml文件,这个文件主要记录分组情况,建立yum仓库时,需要先重建该文件。

    重建Server:

    [root@xml-oms repodata]# cd /u01/yum/Server/repodata/

    [root@xml-oms repodata]# pwd

    /u01/yum/Server/repodata

    [root@xml-oms repodata]# ls

    comps-rhel5-server-core.xml  other.xml.gz    repomd.xml

    filelists.xml.gz             primary.xml.gz  TRANS.TBL

    [root@xml-oms repodata]#

    createrepo -g /u01/yum/Server/repodata/comps-rhel5-server-core.xml/u01/yum/Server

    2679/3116 -jakarta-commons-collections-testframework-javadoc-3.2-2jpp.3.x86_64.3116/3116 -libFS-1.0.0-3.1.i386.rpm                                           

    Saving Primary metadata

    Saving file lists metadata

    Saving other metadata

    重建VT:

    [root@xml-oms yum]# cd /u01/yum/VT/repodata/

    [root@xml-oms repodata]# pwd

    /u01/yum/VT/repodata

    [root@xml-oms repodata]#createrepo -g/u01/yum/VT/repodata/comps-rhel5-vt.xml /u01/yum/VT/

    2/71 - celt051-0.5.1.3-0.el5.i386.rpm                                           

    Error opening package -Virtualization-ta-IN-5.2-11.noarch.rpm

    21/71 -Virtualization-kn-IN-5.2-11.noarch.rpm                                 

    Error opening package -Virtualization-pa-IN-5.2-11.noarch.rpm

    71/71 - Virtualization-pt-BR-5.2-11.noarch.rpm                                 

    Saving Primary metadata

    Saving file lists metadata

    Saving other metadata

    重建Cluster:

    [root@xml-oms repodata]# cd /u01/yum/Cluster

    [root@xml-oms Cluster]# pwd

    /u01/yum/Cluster

    [root@xml-oms Cluster]# createrepo -g/u01/yum/Cluster/repodata/comps-rhel5-cluster.xml /u01/yum/Cluster

    32/32 -Cluster_Administration-mr-IN-5.2-1.noarch.rpm                          

    Saving Primary metadata

    Saving file lists metadata

    Saving other metadata

    重建ClusterStorage:

    [root@xml-oms Cluster]# cd /u01/yum/ClusterStorage/

    [root@xml-oms ClusterStorage]# pwd

    /u01/yum/ClusterStorage

    [root@xml-oms ClusterStorage]#createrepo -g/u01/yum/ClusterStorage/repodata/comps-rhel5-cluster-st.xml/u01/yum/ClusterStorage/

    39/39 -kmod-cmirror-0.1.22-3.el5.x86_64.rpm                                   

    Saving Primary metadata

    Saving file lists metadata

    Saving other metadata

    6.7 准备客户端yum配置文件

    在每个客户端使用YUM时,必须需要修改配置文件/etc/yum.repos.d/*.repo。 这个文件名称可以随便定义,但是扩展名必须是repo。新建一个YUM配置文件ftp.repo,如下:

    [root@xml-oms yum]# cp /etc/yum.repos.d/rhel-debuginfo.repo/etc/yum.repos.d/ftp.repo

    [root@xml-oms yum]# ll /etc/yum.repos.d/

    ftp.repo                 rhel-debuginfo.repo      rhel-debuginfo.repo.bak

    [root@xml-oms yum]# vi /etc/yum.repos.d/ftp_rhel5.5x64.repo

    [ftp-rhel5.5-base]

    name=Redhat Enterprise 5.5x64

    baseurl=ftp://172.16.10.173/Server

    gpgcheck=0

    enabled=1

    [ftp-rhel5.5-vt]

    name=Redhat Enterprise 5.5x64

    baseurl=ftp://172.16.10.173/VT

    gpgcheck=0

    enabled=1

    [ftp-rhel5.5-cluster]

    name= Redhat Enterprise 5.5x64

    baseurl=ftp://172.16.10.173/Cluster

    gpgcheck=0

    enabled=1

    [ftp-rhel5.5-ClusterStorage]

    name= Redhat Enterprise 5.5x64

    baseurl=ftp://172.16.10.173/ClusterStorage

    复制一份到ftp目录下,提供下载。

    [root@xml-oms yum]# cp /etc/yum.repos.d/ftp_rhel5.5x64.repo /u01/yum/

    6.8 客户端更新配置yum源

             这里客户可以有2中方式下载服务器的yum源文件,FTP下载或者wget:

    [root@xml-ora1 yum.repos.d]# cd /etc/yum.repos.d

    [root@xml-ora1 yum.repos.d]# pwd

    /etc/yum.repos.d

    [root@xml-ora1 yum.repos.d]# wgetftp://172.16.10.173/ftp_rhel5.5x64.repo

    --2012-11-20 11:04:37--  ftp://172.16.10.173/ftp_rhel5.5x64.repo

               => `ftp_rhel5.5x64.repo'

    Connecting to 172.16.10.173:21...connected.

    Logging in as anonymous ... Logged in!

    ==> SYST ... done.    ==> PWD ... done.

    ==> TYPE I ... done.  ==> CWD not needed.

    ==> SIZE ftp_rhel5.5x64.repo ... 463

    ==> PASV ... done.    ==> RETR ftp_rhel5.5x64.repo ... done.

    Length: 463

    100%[======================================>]463         --.-K/s  in 0s     

    2012-11-20 11:04:37 (20.1 MB/s) -`ftp_rhel5.5x64.repo' saved [463]

    或者ftp:

    [root@xml-ora1 ~]# ftp 172.16.10.173

    6.9客户端yum测试

    清除YUM缓存 ,测试:

    [root@xml-ora1 yum.repos.d]# yum clean all

    Cleaning up Everything

    [root@xml-ora1 yum.repos.d]# yum check-update

    ftp-rhel5.5-ClusterStorage                               | 1.1 kB     00:00    

    ftp-rhel5.5-ClusterStorage/primary                       | 8.2 kB     00:00    

    ftp-rhel5.5-ClusterStorage                                               39/39

    ftp-rhel5.5-base                                         | 1.1kB     00:00    

    ftp-rhel5.5-base/primary                                 | 1.1 MB     00:00    

    ftp-rhel5.5-base                                                     3116/3116

    ftp-rhel5.5-cluster                                      | 1.1kB     00:00    

    ftp-rhel5.5-cluster/primary                              | 5.8 kB     00:00    

    ftp-rhel5.5-cluster                                                      32/32

    ftp-rhel5.5-vt                                           |1.1 kB     00:00    

    ftp-rhel5.5-vt/primary                                   |  19 kB    00:00    

    ftp-rhel5.5-vt:[#####################################################  ] 69/71[

    注意,看到上面的ftp-rhel5.5-ClusterStorage信息说明是从我们的ftp源进行数据更新的。说明配置客户端源成功。

    7、HTTP方式搭建远程YUM服务器

    7.1 建立yum服务器目录

    创建一个存放放RPM所有安装包的目录,位置自定义:

    [root@xml-oms /]# mkdir -p /u01/yum

    7.2 copy光盘内容到yum服务器

    挂载光盘:

    [root@xml-oms cdrom]# mkdir -p /mnt/cdrom/

    [root@xml-oms cdrom]# mount /dev/cdrom /mnt/cdrom/

    mount: block device /dev/cdrom iswrite-protected, mounting read-only

    获取RPM包源,将ISO中的Server目录复制到本机需要安装YUM仓库的目录下:

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/Server//u01/yum

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/ClusterStorage//u01/yum/

    [root@xml-oms cdrom]# cp -rf /mnt/cdrom/VT/ /u01/yum/

    [root@xml-oms yum]# pwd

    /u01/yum

    7.3 安装httpd

    [root@xml-oms yum]# rpm -ivh /mnt/cdrom/Server/httpd-*

    httpd-2.2.3-43.el5.x86_64.rpm         httpd-devel-2.2.3-43.el5.x86_64.rpm

    httpd-devel-2.2.3-43.el5.i386.rpm     httpd-manual-2.2.3-43.el5.x86_64.rpm

    7.4 修改http.conf

    http.conf是apache的主配置文件,为了避免启动报错。最好备份一下:

    [root@localhost conf]# cp -p /etc/httpd/conf/httpd.conf/etc/httpd/conf/httpd.conf.bak

    把 DocumentRoot 改成拷rpm包的目录,大约在281行

    [root@localhost conf]#vi httpd/conf +281

     ---->  281 DocumentRoot "/u01/yum/Server"

    7.5重启apahce服务

    [root@localhost conf]# service httpd restart

    Stopping httpd: [  OK  ]

    Starting httpd: [  OK  ]

    7.6 客户端配置

             在配置文件目录心中一个http.repo配置文件

    [root@localhost yum.repos.d]# pwd

    /etc/yum.repos.d

    [root@localhost yum.repos.d]# cat http.repo

    [http-rhel5.5-base]

    name=Redhat Enterprise 5.5x64

    baseurl=http://172.16.10.173

    enabled=1

    gpgcheck=0

    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

    7.7 软件安装测试

    [root@localhost yum.repos.d]#yum clean all

    [root@localhost yum.repos.d]#yum install sendmail –y

    8、RHEL5使用Cent-OS5的YUM源

    由于CentOS-5是RHEL-5的免费版,可以使用CentOS-5的yum源来达到在RHEL-5下更新软件。

    8.1 编辑YUM 配置文件

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

    [root@dataserver01 yum.repos.d]# ls

    rhel-debuginfo.repo

    [root@dataserver01 yum.repos.d]# pwd

    /etc/yum.repos.d

    [root@Server yum.repos.d]# vi centos5.repo

    [base]

    name=Red Hat Enterprise Linux $releasever-Base

    #mirrorlist=http://mirrorlist.centos.org/?release=$releasever5&arch=$basearch&repo=os

    #baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/

    baseurl=http://ftp.sjtu.edu.cn/centos/5/os/$basearch/

    gpgcheck=1

    gpgkey=http://mirror.centos.org/centos/RPM-GPG-KEY-centos5

    #released updates

    [update]

    name=Red Hat Enterprise Linux $releasever-Updates

    #mirrorlist=http://mirrorlist.centos.org/?release=4&arch=$basearch&repo=updates

    baseurl=http://ftp.sjtu.edu.cn/centos/5/updates/$basearch/

    gpgcheck=1

    gpgkey=http://mirror.centos.org/centos/RPM-GPG-KEY-centos5

    #packages used/produced in the build butnot released

    [addons]

    name=Red Hat Enterprise Linux $releasever-Addons

    #mirrorlist=http://mirrorlist.centos.org/?release=4&arch=$basearch&repo=addons

    baseurl=http://ftp.sjtu.edu.cn/centos/5/addons/$basearch/

    gpgcheck=1

    gpgkey=http://mirror.centos.org/centos/RPM-GPG-KEY-centos5

    #additional packages that may be useful

    [extras]

    name=Red Hat Enterprise Linux $releasever-Extras

    #mirrorlist=http://mirrorlist.centos.org/?release=4&arch=$basearch&repo=extras

    baseurl=http://ftp.sjtu.edu.cn/centos/5/extras/$basearch/

    gpgcheck=1

    gpgkey=http://mirror.centos.org/centos/RPM-GPG-KEY-centos5

    8.2 导入RPM-KEY

    [root@dataserver01 yum.repos.d]#

    rpm --importhttp://ftp.sjtu.edu.cn/centos/5/os/i386/RPM-GPG-KEY-CentOS-5

    8.3 清理以下缓存测试

    [root@dataserver01 yum.repos.d]# yum clean all

    Loaded plugins: rhnplugin, security

    Cleaning up Everything

    [root@dataserver01 yum.repos.d]#yum list

  • 相关阅读:
    五场面试之后的小结
    玩转ubuntu之初体验
    现阶段规划小结
    高并发秒杀系统--课程总结与思考
    高并发秒杀系统--秒杀高并发分析与解决方案
    高并发秒杀系统--SpringMVC整合
    高并发秒杀系统--Service事务管理与继承测试
    高并发秒杀系统--Service接口设计与实现
    对于你为什么要离职的深入思考
    两场面试之后的小结
  • 原文地址:https://www.cnblogs.com/wqswjx/p/5496360.html
Copyright © 2011-2022 走看看