搭建内网yum仓库

编译源码,根据自己的需求做成定制RPM包–>搭建内网yum仓库–yum安装。

[root@www ~]# uname -a
Linux www 2.6.32-642.6.2.el6.x86_64 #1 SMP Wed Oct 26 06:52:09 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux

[root@www ~]# cat /etc/redhat-release
CentOS release 6.8 (Final)

=================定制化RPM包==========================

fpm工具是rpm-bulid的封装工具,使用更方便,用于打包文件为rpm格式。

FPM功能简单说就是将一种类型的包转换成另一种类型。

Fpm 之 工具安装

1、安装ruby模块

fpm是ruby写的,因此系统环境需要ruby

yum -y install ruby rubygems ruby-devel

2、把当前的rubygems仓库,改为淘宝的rubygems仓库

gem sources --add https://ruby.taobao.org/ --remove http://rubygems.org/

3、升级ruby版本到2.3

[root@Linux_Test ~]# curl -L get.rvm.io | bash -s stable

[root@localhost ~]# curl -sSL https://rvm.io/mpapis.asc | gpg2 --import

[root@Linux_Test ~]# curl -L get.rvm.io | bash -s stable

[root@Linux_Test rvm]# source /etc/profile.d/rvm.sh

[root@Linux_Test rvm]# rvm -v

rvm 1.29.3 (latest) by Michal Papis, Piotr Kuczynski, Wayne E. Seguin[https://rvm.io]

[root@Linux_Test rvm]# rvm install 2.3.0

4、开始安装fpm

yum -y install rpm-build

gem install json -v 1.8.3

gem install fpm -v 1.3.3

仅适合CentOS6系统,CentOS7系统一步搞定,即gem install fpm

FPM参数
详细使用见fpm –help

常用参数

-s 指定源类型
-t 指定目标类型,即想要制作为什么包
-n 指定包的名字
-v 指定包的版本号
-C 指定打包的相对路径 Change directory to here before searching forfiles
-d 指定依赖于哪些包
-f 第二次打包时目录下如果有同名安装包存在,则覆盖它
-p 输出的安装包的目录,不想放在当前目录下就需要指定
--post-install 软件包安装完成之后所要运行的脚本;同--after-install
--pre-install 软件包安装完成之前所要运行的脚本;同--before-install
--post-uninstall 软件包卸载完成之后所要运行的脚本;同--after-remove
--pre-uninstall 软件包卸载完成之前所要运行的脚本;同--before-remove

使用实例–实战定制nginx的RPM包

  1. 安装nginx

yum -y install pcre-devel openssl-devel
useradd nginx -M -s /sbin/nologin
tar xf nginx-1.6.2.tar.gz
cd nginx-1.6.2
./configure --prefix=/application/nginx-1.6.2 --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module
make && make install
ln -s /application/nginx-1.6.2/ /application/nginx

  1. 编写脚本

[root@oldboy ~]# cd /server/scripts/
[root@oldboy scripts]# vim nginx_rpm.sh # 这是安装完rpm包要执行的脚本

#!/bin/bash
useradd nginx -M -s /sbin/nologin
ln -s /application/nginx-1.6.2/ /application/nginx

  1. 打包

[root@oldboy ~]# fpm -s dir -t rpm -n nginx -v 1.6.2 -d ‘pcre-devel,openssl-devel‘ --post-install /server/scripts/nginx_rpm.sh -f /application/nginx-1.6.2/

no value for epoch is set, defaulting to nil {:level=>:warn}
no value for epoch is set, defaulting to nil {:level=>:warn}
Created package {:path=>"nginx-1.6.2-1.x86_64.rpm"}

[root@oldboy ~]# ll -h nginx-1.6.2-1.x86_64.rpm
-rw-r--r-- 1 root root 6.7M Nov 1 10:02 nginx-1.6.2-1.x86_64.rpm

安装rpm包

安装rpm包的三种方法:

1、rpm命令安装

[root@LB-nginx-01 ~]# rpm -ivh nginx-1.6.2-1.x86_64.rpm
error: Failed dependencies:
pcre-devel is needed by nginx-1.6.2-1.x86_64
openssl-devel is needed by nginx-1.6.2-1.x86_64

但会报如上依赖错误,需要先yum安装依赖才能安装rpm包。

2、yum命令安装rpm包

yum -y localinstall nginx-1.6.2-1.x86_64.rpm

这个命令会自动先安装rpm包的依赖,然后再安装rpm包。

3、搭建内网yum仓库

注意事项:

1.必须使用绝对路径打包

使用rpm -qpl 命令可以查看rpm包的内容。
注:fpm类似tar打包一样,只是fpm打的包能够被yum命令识别而已。

2.打包时,软链接必须要加/ /application/nginx/

==================搭建YUM仓库==========================

  1. 创建yum仓库目录

mkdir -p /application/yum/centos6.6/x86_64/
cd /application/yum/centos6.6/x86_64/
rz # 上传rpm包到此目录,此目录下面还可以包括文件夹

  1. 安装createrepo软件
    yum -y install createrepo
  2. 初始化repodata索引文件
    createrepo -pdo /application/yum/centos6.6/x86_64/ /application/yum/centos6.6/x86_64/
  3. 提供yum服务

可以用Apache或nginx提供web服务,但用Python的http模块更简单,适用于内网环境

cd /application/yum/centos6.6/x86_64/
python -m SimpleHTTPServer 80 &>/dev/null &

可以通过浏览器输入本机IP查看。

  1. 添加新的rpm包

只下载软件不安装
yumdownloader pcre-devel openssl-devel
createrepo --update /application/yum/centos6.6/x86_64/

每加入一个rpm包就要更新一下。
平时yum安装软件时不删除安装包

cat /etc/yum.conf
keepcache=1

安装包存储目录
cachedir=/var/cache/yum/$basearch/$releasever

/var/cache/yum/x86_64/6/base/packages

开启yum缓存

sed -i ‘s#keepcache=0#keepcache=1#g‘ /etc/yum.conf

查找是否有rpm包了:

find /var/cache/yum/ -name "*.rpm"


  1. 客户端配置

cd /etc/yum.repos.d

[root@B yum.repos.d]# vim oldboy.repo

[oldboy]
name=Server
baseurl=http://10.0.0.5
enable=1
gpgcheck=0

[root@YUM ~]# yum --enablerepo=oldboy --disablerepo=base,extras,updates,epel list

指定使用oldboy库

上面是临时使用内网yum源,想永久并简单使用yum -y install lrzsz命令,就需要修改配置文件将默认的repo文件关闭。

[root@oldboy ~]# cd /etc/yum.repos.d/
[root@oldboy yum.repos.d]# vim CentOS-Base.repo

在每一个启动的源加上
enabled=0 #改为1就启用,没有此参数也是启用。
[base]
…………
enabled=0
[updates]
…………
enabled=0
[extras]
…………
enabled=0
还有其他开启的仓库就使用这个办法关闭。

  1. 镜像yum源

镜像同步公网yum源
上游yum源必须要支持rsync协议,否则不能使用rsync进行同步。
http://mirrors.ustc.edu.cn/status/

同步base源,小技巧,我们安装系统的光盘镜像含有部分rpm包,大概3G,这些就不用重新下载。

/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/os/x86_64/ /data/yum_data/centos/6/os/x86_64/
/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/extras/x86_64/ /data/yum_data/centos/6/extras/x86_64/
/usr/bin/rsync -av rsync://mirrors.ustc.edu.cn/centos/6/updates/x86_64/ /data/yum_data/centos/6/updates/x86_64/

epel源
/usr/bin/rsync -av --exclude=debug rsync://mirrors.ustc.edu.cn/epel/6/x86_64/ /data/yum_data/epel/6/x86_64/

原文地址:https://blog.51cto.com/12083623/2353178

时间: 2024-11-06 09:36:32

搭建内网yum仓库的相关文章

RadHat搭建内网YUM源服务器

前言:随着内网linux服务器越来越多,在每台服务器上安装软件,都要先把安装盘上传上去,在配置本地yum服务,即麻烦又费时.可以在内网的一台linux服务器上安装yum服务,然后其他服务器直接修改repo文件使用yum服务就可以了.安装步骤如下: Linux系统环境 1.RHEL版本 [[email protected] pub]# cat /etc/issue Red Hat Enterprise Linux Server release 6.5 (Santiago) 2.内核版本 [[ema

搭建基于HTTP协议内网yum仓库

目录 1. 前言 2. 把rpm包下载到本地 3. 配置nginx对外提供服务 4. 配置本地repo文件 5. 生成repodata信息 6. 检查及使用 7. 对管理机器上的仓库进行更新 参考资料 环境:VMware-Workstation-12-Pro,Windows-10,CentOS-7.5,Xshell5 1. 前言 如果我们的yum仓库需要多台机器共同使用,此时把yum仓库做成本地的,然后一台台scp推送过去比较麻烦,此时可以考虑搭建一个基于HTTP协议,供给内网其它机器使用的本地

centos 7搭建内网yum源

搭建环境:各节点关闭防火墙,因情况而定. yum节点:172.16.169.136 测试节点:172.16.169.137 安装httpd服务,可视化 1.创建yum仓库 创建存放rpm的目录 mkdir -p /var/www/html/yum_repo/my/Packages 挂载本地光盘(光盘路径视环境锁定)mount /dev/sr0 /var/www/html/yum_repo/my/Packages/启动httpd服务service httpd start 测试节点只需关闭防火墙修改

Docker搭建内网 composer satis 代码仓库

搭建composer内网代码仓库 拉取 composer/satis 镜像 docker pull composer/satis 配置 composer 该步骤可跳过 目录结构 ├── auth.json ├── cache │ ├── files │ ├── repo │ └── vcs ├── composer.json └── config.json composer.json { } config.json { "config": { "secure-http&quo

搭建企业内部yum仓库(centos6+centos7+epel源)

yum仓库服务端配置 1. 创建yum仓库目录 mkdir -p /data/yum_data/cd /data/yum_data/#可以上传rpm包到此目录,此目录下面还可以包括文件夹 2. 安装createrepo软件[[email protected] yum_data]# yum -y install createrepo 3. 初始化repodata索引文件createrepo -pdo /data/yum_data/ /data/yum_data/ 4. 提供yum服务# 可以用Ap

debian下搭建内网centos源(apache2)

生产环境中有一些机器没外网 也不允许有外网 领导要求搭建内网centos源 涉及ip如下: 10.1.1.1(服务端) 10.1.1.2(客户端) 现服务端已有CentOS-6.5-x86_64-bin-DVD1.iso  cat /etc/debian_version  5.0.2 服务端(10.1.1.1) 1.创建iso挂载目录 mkdir /opt/iso/centos -p 2.挂载iso mount -o loop /opt/isos/CentOS-6.5-x86_64-bin-DV

搭建内网NTP时间服务器

          搭建内网的NTP时间服务器 需求:搭建一台时间服务器,使得无外网的服务器可以同步时间. 一.环境 1. [[email protected] ~]# cat /etc/redhat-release 2. CentOS release 6.8 (Final) 3. [[email protected] ~]# hostname -I 4. 10.0.0.61 172.16.1.61 5. #外网10.0.0.61;内网172.16.1.61 二.安装ntp并检查是否安装成功 1

使用Nginx制作内网yum镜像代理

使用Nginx制作内网yum镜像代理 使用Nginx制作内网yum镜像代理 1. 背景 2. 环境需求 3. Nginx安装配置 1. 背景 公司内网服务器不能直接通过Internet上网,但为了与外网通信和同步时间等,会指定那么几台服务器可以访问Internet.这里就是通过能上网的机器作为代理,制作内网使用的yum仓库. 2. 环境需求 内网dns(推荐,非必须,因为可使用IP代替) 一台能上Internet的服务器A 不能上Internet的服务器能与A服务器通信 这里示例为CentOS7

用NAT123搭建内网WCF服务并实现安卓APP访问附带站点简单的性能测试

以下原创,转转请注明出处,谢谢合作! 简介:NAT123是个很很强大的工具,而且使用非常简单,真正实现了帮用户无视内外网的建站服务. 这里简单介绍一下如何用NAT123建内网WCF服务,然后用一个安卓APP实现对它的调用,由于NAT123提供全端口映射(需要访问者支持),所以既可以做站点,APP后台,也可以做其他应用的服务器比如FTP等等,根据具体应用的需要而定.最后对所建的两个映射站点做了个简单的性能测试. 用NAT123搭建内网WCF服务:(由于文章主要是介绍NAT123,WCF相关内容自行