不少公司都有本身搭建的yum仓库,这样作的好处有如下几点:php
1)节省流量,避免从公网重复下载软件包;为公司省钱;html
2)提高下载速度;外网下载受带宽影响,下载速度较慢,而yum仓库在局域网中就很快;linux
3)方便统一管理,软件版本,都能作到统一;数据库
4)避免访问外网,不少大公司,都是与公网隔绝的,尤为是大公司的类生产环境,绝对不予许随便访问外网,这是获取安装包的途径就只能经过内网yum仓库;vim
不一样版本操做系统安装大致上没有差异,可是也会有影响,本实例yum仓库搭建基于以下环境:centos
[root@yum ~]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) [root@yum ~]# uname -r 3.10.0-693.el7.x86_64 [root@yum ~]# uname -m x86_64
安装前必定要关闭防火墙和Selinux,不然会失败,出现异常。缓存
[root@yum ~]# getenforce #确认SELinux关闭 Disabled [root@yum ~]# systemctl status firewalld #确认防火墙关闭 ● firewalld.service - firewalld - dynamic firewall daemon Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled) Active: inactive (dead) Docs: man:firewalld(1)
yum仓库搭建过程:安全
yum仓库搭建说简单也很简单,只要注意几个细节就能够。下面会一一讲解:bash
[root@cobbler ~]# yum install -y httpd #安装httpd服务
[root@localhost yum.repos.d]# systemctl start httpd #启动httpd服务
yum仓库搭建须要建立yum仓库的命令,createrepo命令 [root@localhost yum.repos.d]# yum install -y createrepo #安装createrepo命令 [root@localhost yum.repos.d]# createrepo -pdo /var/www/html/ /var/www/html/ #建立yum仓库 [root@localhost yum.repos.d]# cd /var/www/html/ #切换到yum仓库 [root@localhost html]# ls #查看createrepo建立yum仓库生成内容 repodata #生成一个repodata包,里面包含库文件,相似数据库建库建表同样
平时咱们都喜欢使用阿里云的epel.repo源,咱们能够仿照epel.repo来写咱们的源服务器
vim /etc/yum.repos.d/rural.repo [warehouse] #这个是yum仓库的名字,是存放rpm包的目录,还须要咱们建立,这个地方困扰我两天时间,不然即使搭建好,也会出现问题,各类依赖解决不了 name=Server baseurl=http://10.0.0.170/rural/ enabled=1 gpgcheck=0 [root@yum ~]# mkdir /var/www/html/warehouse -p #<==上面建立的warehouse目录,与repodata在同一个目录下,用来存放rpm包
搭建好yum仓库,就须要获取rpm包,这个能够从公网同步;
我的在家搭建yum仓库,喜欢从公网下载rpm包到yum仓库所在虚拟机,而后定时任务同步到/var/www/html/warehouse目录里。
同步代码以下:
[root@yum ~]# cat /server/scripts/yum.sh #!/bin/bash num=`find /var/cache/yum/* -name "*.rpm" |wc -l` if [ $num -eq 0 ];then exit 1 else find /var/cache/yum/* -name "*.rpm" -exec mv -f {} /var/www/html/warehouse/ \; sleep 2 /usr/bin/createrepo --update /var/www/html/warehouse fi
默认状况下,每次yum安装rpm包以后都会清理掉,于是是不能同步的,咱们能够改yum服务的配置文件
[root@yum ~]# vim /etc/yum.conf
[main] cachedir=/var/cache/yum/$basearch/$releasever #rpm包存放路径 keepcache=1 #keepcache默认是0,不保留rpm包,改成1,则会保留rpm安装包 debuglevel=2 #Debug信息输出登记,范围为0-10,缺省为2 logfile=/var/log/yum.log #日志文件,执行yum记录 exactarch=1 #有1和0两个选项,设置为1,则yum只会安装和系统架构匹配的软件包 obsoletes=1 #update的参数,至关于upgrade,容许更新陈旧的RPM包 gpgcheck=1 #有1和0两个选项,分别表明是否进行gpg(GNU)校验,以肯定rpm包的来源是有效和安全的。这个选项若是设置在[main]部分,则对每一个repository都有效,默认为0 plugins=1 #是否启用插件,默认为1容许,0表示不容许 installonly_limit=5 bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php?category=yum distroverpkg=centos-release #指定一个软件包,yum会根据这个包判断发行版本
注意点:每次同步以后,要更新yum仓库,使用createrepo命令更新yum仓库,不然不会同步。
以上就是yum仓库的搭建过程,其实原理很简单,就是搭建一个http服务,而后把rpm放到http服务里面,经过createrepo命令建立yum仓库,相似于数据库建库建表的过程。
搭建完毕以后,咱们就能够把上面的配置文件复制到内网的机器上面,让内网机器只能从yum仓库获取rpm包。
repository部分定义了每一个源服务器的具体配置,能够有一到多个,位于/etc/yum.repos.d/目录下的各文件中
[root@rural ~]# ll /etc/yum.repos.d/ CentOS-Base.repo #<==网络源的配置文件 CentOS-Media.repo #<==本地源的配置文件 epel.repo #<==第三方源的配置文件
命令:
####查看软件包 yum list all ##列出yum源仓库里面的全部可用的安装包 yum list installed ##列出全部已经安装的安装包 yum list available ##列出没有安装的安装包 ####安装软件 yum install softwarename ##安装指定的软件 yum reinstall softarename ##从新安装指定的软件 yum localinstall 第三方software ##安装第三方文件而且会解决软件的依赖关系 yum remove softwarename ##卸装指定的软件 ####查找软件的信息 yum info software ##查看软的信息 yum search keywords ##根据关键字查找到相关安装包软件的信息 yum whatprovides filename ##查找包含指定文件的相关安装包 ####对于软件组 yum groups list ##列出软件组 yum groups install ##安装一个软件组 yum group remove ##卸载一个软件组 yum groups info ##查看一个软件组的信息 yum list httpd ##列出软件包 yum search httpd ##搜索软件包 yum provides /etc/my.cnf ##查找某个特定文件属于哪一个软件包 yum grouplist ##弹出全部可用群组 yum grouplist “MySQL Database” ##安装群组软件包 yum repolist ##弹出启用的软件库 yum repolist all(包含禁用的软件库) ##弹出全部软件包 yum –enablerepo=localinstll LNMP ##安装来自特定软件库的软件包 yum –enablerepo=local –disablerepo=base.extras.updates install LNMP ##不安装来自特定软件库的软件包 yum clean all ##清理yum缓存内容 yum makecache ##缓存本地yum源中的软件包信息 yum history ##查看yum历史记录
特别提醒:yum仓库的rpm包每更新一次,就要执行createrepo --update进行更新