百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

内网离线安装docker-ce工具,带你来了解!

nanshan 2025-03-11 19:19 13 浏览 0 评论

虽然通常我们都是使用网络来安装 docker 的,但是对于安全要求比较高的业务或者用户来说,部署产品需要在内网部署,而内网通常是无法访问外部网络的,所以就需要通过内网进行安装了。

1. yum 离线安装包获取方法

下载软件包

这里以 CentOS7 为例进行说明

# 替换并更新软件源

$ curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo


# 生成缓存

$ yum makecache

# 添加docker-ce软件源

$ curl -o /etc/yum.repos.d/docker-ce.repo https://download.docker.com/linux/centos/docker-ce.repo


生成缓存

$ yum makecache

# 前提条件

$ yum install -y yum-plugin-downloadonly


# 下载rpm安装包,我这里以docker-ce为例说明

$ yum install --downloadonly --downloaddir=./ docker-ce

这里以 Ubuntu18.04 为例进行说明

# 会存放在/var/cache/apt/archives目录下面

$ sudo apt-get install --download-only pppoe

2. yum 离线安装 docker-ce 工具

安装软件包

如果我们发现原有的操作系统已经安装了 docker 工具,但是对应版本并不能

满足我们的需要,可以将其卸载之后再次安装即可。

# 搜索已经安装的docker安装包

$ sudo yum list installed | grep docker

docker.x86_64 2:1.12.6-16.el7.centos @extras


# 分别删除安装包

$ sudo yum –y remove docker.x86_64

使用我们打好的 docker-ce 的安装包,执行安装命令的时候报错。

# 安装时一并安装对应依赖

$ sudo yum install ./*.rpm

--> Finished Dependency Resolution

Error: Package: audit-libs-python-2.8.1-3.el7.x86_64 (/audit-libs-python-2.8.1-3.el7.x86_64)

Requires: audit-libs(x86-64) = 2.8.1-3.el7

Installed: audit-libs-2.8.1-3.el7_5.1.x86_64 (@updates)

audit-libs(x86-64) = 2.8.1-3.el7_5.1

Available: audit-libs-2.8.1-3.el7.x86_64 (base)

audit-libs(x86-64) = 2.8.1-3.el7

You could try using --skip-broken to work around the problem

You could try running: rpm -Va --nofiles --nodigest


# 安装的时候忽略以问题

$ rpm -ivh --force --nodeps ./*.rpm

可以发现可能为系统已经安装了对应的包,将其移出目录外之后再次安装。

# 移动到上级目录

$ mv audit-libs-2.8.1-3.el7.x86_64.rpm ..

$ mv audit-libs-python-2.8.1-3.el7.x86_64.rpm ..

如果有缺少依赖的问题,就到下面网站中找对应缺失的相关依赖镜像。

# CentOS

https://centos.pkgs.org/

总结下:虽然操作系统的大版本是一致的,但是对应小版本不一致可能会存在对应 rpm 包小版本的不一致,而导致存在依赖问题,导致安装时失败。

3. pip 离线安装包获取方法

下载软件包

Python 环境安装 package 的方法,一般是采用 pip 命令在线从 PyPI 网站上面下载安装的,这也是最为方便的途径。但是在某些情况下,要为一台离线的机器安装 package 依赖包,其根本无法访问外网环境。当然,一般大厂都会有内网 PyPI 代理,只要改一下 --index-url 参数即可。若无代理的情况下,只能将所有依赖到的 package 离线下载下来,放到离线的机器上安装,即可。

由于手动下载所有依赖是一件非常痛苦的事情,所以我发现了 pip download 命令可以很好的解决这个问题。

# (1)确认需要的依赖包 - 外部第三方库

$ sudo vim requirements.txt

alembic


# (2)确认需要的依赖包 - 内部第三方库

$ sudo vim requirements.txt

--index-url https://admin:111111@pypi.escapelife.com:4874/simple

love_grilfriend


# (3)通过如下命令下载依赖

$ sudo pip download -d /root/packages -r requirements.txt


4. pip 离线安装 package 方法

需要注意的是,

存在 onlineoffline 机器架构完全相同,也可能架构不相同。

[1] 架构相同

# 直接在online机器执行如下命令下载所有依赖package到当前目录

$ sudo pip download tensorflow


# 将目录内容拷贝到目标offline机器并目标offline机器执行

$ pip install --no-index --find-links=file:/data/tensorflow_package_dir tensorflow


# 不依赖其他库强制安装

$ pip install --no-deps tensorflow-1.2.3-cp36-cp36m-linux_x86_64.whl


[2] 架构不同

# pyenv+docker

# 架构不同的情况下,可以使用docker创建一个和目标机器相同的系统

# 然后,使用上面这中方式进行下载和安装就可以了,也是很简单的,哈哈


# pyenv

# 通过pyenv安装指定版本的python

$ curl -L https://github.com/pyenv/pyenv-installer/raw/master/bin/pyenv-installer | bash pyenv install 3.7.13

# 切换Python版本

$ pyenv global 2.7.13


# docker

# 先启动目标系统的docker镜像

$ docker run -it -v /offline_tensorflow_py3:/package ubuntu /bin/bash

# 在容器内安装python

$ apt-get update && apt-get install python python-pip

# 使用和相同架构的操作步骤


[3] 存在问题 - 导致下文pip download失败的原因

PyPIpackage 有好几种格式,不幸的是 PiPY 并没有规定一个 package 必须提供的安装格式,有的只有 wheel 没有源文件,有的只有源文件没有 wheelegg

源文件(一般是.tar.gz 或.zip 文件,用 pip 安装,与机器架构无关,但某些 package 可能涉及到 C/C++编译)

wheel 文件(二进制文件,拓展名为.whl,用 pip 安装,无需编译,但与机器架构相关)

.egg 文件(二进制文件,用 easy_install 安装,无需编译,但与机器架构相关)

# 只要指定
--platform/--python-version/--implementation/--abi即可

pip download with the --platform, --python-version, --implementation, and --abi options provides the ability to fetch dependencies for an interpreter and system other than the ones that pip is running on.


--only-binary=:all: or --no-deps is required when using any of these options. It is important to note that these options all default to the current system/interpreter, and not to the most restrictive constraints (e.g. platform any, abi none, etc).


To avoid fetching dependencies that happen to match the constraint of the current interpreter (but not your target one), it is recommended to specify all of these options if you are specifying one of them. Generic dependencies (e.g. universal wheels, or dependencies with no platform, abi, or implementation constraints) will still match an over- constrained download requirement.

# 下载TensorFlow的pip包

pip download \

--only-binary=:all: \ # 只下载二进制package(即wheel或egg)

--platform linux_x86_64 \ # 说明是linux 64位架构

--python-version 27 \ # Python 2.7

--implementation cp \ # Cython 一般都是这个

--abi cp27mu # 解释器和系统的依赖关系的能力

tensorflow # 要下载的package名


5. 离线升级 Linux 内核的方法

这里主要是由CentOS 的操作系统进行演示说明

[1] 事件起因

CentOS7.3 的系统上面部署 NFS 服务的时候,发现跨主机使用的话,需要开通多个端口才能保证正常的使用。但是,我之前在 Ubuntu18.04 的系统上使用 NFS 服务却只需要使用到默认的一个端口即可,这个端口就是 2049 了。看了 NFS 服务的版本号也是相同的,一直没有找到问题的原因,最后还是我的 leader 发现是因为 Linux 操作系统的版本不一致导致的。

我们安装 CentOS7.3 的裸机,系统默认的内核版本为 3.10,属于比较老的版本,导致部分功能无法使用。现在,最新稳定的系统内核为 4.12 版本,所以需要将我们现在的系统内核版本升级到最新的版本,即可解决上述问题。

[2] 升级准备

# 备份重要数据

如果是虚拟机的话,使用快照进行备份

针对重要程序数据进行备份,例如 MySQL、Apache、Nginx等


# 检查当前CentOS系统版本

$ cat /etc/redhat-release

> CentOS Linux release 7.3.1611 (Core)


# 检查当前CentOS系统内核版本

# 版本性质: 主分支ml(mainline),稳定版(stable),长期维护版lt(longterm)

$ uname -r

> 3.10.0-514.el7.x86_64


[3] 升级步骤 - 在线安装

# 升级CentOS7.X内核并且启用ELRepo仓库

# RedHat只允许使用yum升级内核,CentOS允许使用ELRepo第三方仓库升级内核

$ rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org

$ rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-2.el7.elrepo.noarch.rpm


# 安装最新的主线稳定内核

$ yum --enablerepo=elrepo-kernel install kernel-ml


# 设置GRUB默认的内核版本

# 修改含义: GRUB初始化页面的第一个内核将作为默认内核

$ vi /etc/default/grub

> GRUB_DEFAULT=0


# 重新创建内核配置

$ grub2-mkconfig -o /boot/grub2/grub.cfg


# 重启机器并查看系统当前内核版本

$ uname -sr

> Linux 4.12.0-1.el7.elrepo.x86_64


# 查看系统中全部的内核RPM包(可选操作)

$ rpm -qa | grep kernel

> kernel-tools-3.10.0-514.26.2.el7.x86_64

> kernel-devel-3.10.0-514.10.2.el7.x86_64

> kernel-3.10.0-514.26.2.el7.x86_64

> kernel-3.10.0-327.el7.x86_64

> kernel-ml-4.12.0-1.el7.elrepo.x86_64

> kernel-headers-3.10.0-514.26.2.el7.x86_64

> kernel-devel-3.10.0-514.26.2.el7.x86_64

> kernel-tools-libs-3.10.0-514.26.2.el7.x86_64


# 删除旧内核的RPM包(可选操作)

$ yum remove \

kernel-tools-3.10.0-514.26.2.el7.x86_64 \

kernel-devel-3.10.0-514.10.2.el7.x86_64 \

kernel-3.10.0-514.26.2.el7.x86_64 \

kernel-3.10.0-327.el7.x86_64 \

kernel-headers-3.10.0-514.26.2.el7.x86_64 \

kernel-devel-3.10.0-514.26.2.el7.x86_64 \

kernel-tools-libs-3.10.0-514.26.2.el7.x86_64


# 重启系统

$ reboot


[4] 升级步骤 - 离线安装

# 无法上网的服务器或者需要安装指定版本内核的需求

# 我们可以把对应kernel的image的rpm包下载下来安装

官方CentOS6地址:
http://elrepo.org/linux/kernel/el6/x86_64/RPMS/

官方CentOS7地址:
http://elrepo.org/linux/kernel/el7/x86_64/RPMS/


# 当然配置了ELRepo仓库之后也是可以下载离线安装包的

$ yum install -y yum-plugin-downloadonly

$ yum install --downloadonly --downloaddir=./ kernel-ml


# 将rpm包下载上传到服务器上并使用下面的命令安装即可

$ yum -y install kernel-ml-4.12.4-1.el7.elrepo.x86_64.rpm

$ yum -y install kernel-ml-devel-4.12.4-1.el7.elrepo.x86_64.rpm


6. pip 工具的相关问题汇总

汇总日常使用 pip 工具的常见错误和对应处理方法!

[1: 问题] 在使用新版的 pip 工具(在21+的版本之后)安装某些库的时候,由于依赖库版本的不一致,pip 会不断尝试和、以此安装已经存在的各个版本,来确实是否符合要求,且安装期间不会抛出错误。这就导致,如果是 CI 工具触发的话,短时间之内并不会停止(一个小时后自动被工具终止),导致问题不易排出且浪费机器性能。

# 循环安装

$ pip install tensorflow


[1: 答案] 可以在手动处理的时候,加上如下参数,就可以在安装之后,迅速抛出异常。这样我们就可以根据抛出的异常冲突版本,来修改 requirements.txt 文件,最后解决该问题。

# --use-deprecated=legacy-resolver

$ pip3 install -r ./requirements.txt --upgrade --use-deprecated=legacy-resolver


[2: 问题] 安装 psycopg2 依赖包的时候,提示如下问题:

# 报错信息

$ pip3 install psycopg2==2.8.4

creating pip-egg-info\psycopg2.egg-info

writing pip-egg-info\psycopg2.egg-info PKG-INFO

writing top-level names to pip-egg-info psycopg2.egg-info top_level.txt

writing dependency_links to pip-egg-info psycopg2.egg-info dependency_links.txt

writing manifest file 'pip-egg-info\psycopg2.egg-info\SOURCES.txt'

warning: manifest_maker: standard file '-c' not found

Error: pg_config executable not found.


Please add the directory containing pg_config to the PATH

or specify the full executable path with the option:

python setup.py build_ext --pg-config /path/to/pg_config build ...


or with the pg_config option in 'setup.cfg'.

----------------------------------------

Command python setup.py egg_info failed with error code 1


[2: 答案] 后来在这个 StackOverflow 才知道了问题的原因,原来是系统少一个依赖包,导致的。

# 前提条件

$ sudo apt install postgresql-client


# Ubuntu - Python3

$ sudo apt install libpq-dev python3-dev


# Ubuntu - Python2

$ sudo apt install libpq-dev python-dev

$ sudo apt install build-essential


新的一年

新的征程

新的活动来袭~

等你来学!

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: