搭建内网开发环境(一)|基于docker快速部署开发环境

引言

最近因需要搭建一套简易版的纯内网的开发环境,服务器采用 centos8.0,容器化技术采用 docker 使用 docker-compose 进行容器编排。
该系列教程分为两大类:

  • 软件安装和使用,这类是开发环境常用的软件部署和使用,涉及到的应用有:
    • docker
    • nexus
    • gitea
    • mysql
    • redis
    • minio
  • 应用部署实战:通过实战将开发好的程序部署到搭建好的开发环境中

docker

安装

对于 docker 的安装分为两种情形,一种是服务器能够访问外网,这种安装比较简单,一种是不能访问外网,对于纯内网安装,需要提前准备好安装文件,复制到内网服务器上。

在线安装

  1. 卸载旧版本
sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine
  1. 设置 docker 仓库,方便安装和更新 docker,由于官方的源比较慢,可以使用第三方的源
# 安装所需要的软件包# 使用官方源
sudo yum-config-manager \--add-repo \https://download.docker.com/linux/centos/docker-ce.repo
# 阿里云第三方源
sudo yum-config-manager \--add-repo \https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 清华大学第三方源
sudo yum-config-manager \--add-repo \https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/centos/docker-ce.repo
  1. 安装 docker enginer
    1. 安装最新版本

sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin

  1. 指定版本安装
    1. 查看版本号:yum list docker-ce --showduplicates | sort -r

image.png

  2. 选择版本号进行安装:`sudo yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io`
  1. 启动 docker
    1. 启动命令:systemctl start docker
    2. 查看是否启动成功,通过 docker info 命令输出 docker 版本信息则安装成功

image.png

  1. 卸载 docker
    1. 删除安装包

yum remove docker

  1. 删除镜像、容器等相关文件

rm -rf /var/lib/docker

离线安装

如果服务器没有外网的情况下,如果通过在线直接获取安装包,这种情况下需要先将安装包准备好上传到服务器在进行安装。

下载安装包
  1. 进入官网下载页面进行选择对应的版本下载,页面链接https://download.docker.com/linux/static/stable/x86_64/

image.png

安装
  1. 解压安装包:tar -zxvf docker-20.10.9.tgz
  2. 安装到 /usr/bin/:mv /docker/* /usr/bin/
  3. 创建 docker 服务
    1. 编辑 /etc/systemd/system/docker.service,内容如下
[Unit]
Description=Docker Service
After=network.target
[Service]
ExecStart=/usr/bin/dockerd
ExecReload=/bin/kill -S HUP $MAINPID
Restart=on-failure
RestartSec=5
[Install]
WantedBy=multi-user.target
  1. 重启 docker 加载配置文件,并设置开启启动
    1. 重启:sudo systemctl daemon-reload && sudo systemctl restart docker
    2. 设置开机启动:sudo systemctl enable docker
  2. 查看docker是否启动成功,使用命令 systemctl status docker

设置镜像源

  1. 编辑 /etc/docker/daemon.json 文件,添加阿里云镜像源,内容如下:
{
"registry-mirrors": ["https://registry.cn-hangzhou.aliyuncs.com"]
}
  1. 重启 docker 使配置生效

sudo systemctl daemon-reload && sudo systemctl restart docker

纯内网如何下载镜像

如果是纯内网部署,且还搭建好私服(这个在后续的教程中会演示)如何获取 docker 镜像呢?
首先需要将部门需要的镜像提前准备好(后期部署好 docker 私服后可从私服下载镜像)先从一台外网机器下载好所需要的镜像,并导出镜像,发送到内网服务上,再在内网服务器上加载镜像到 docker 中;具体步骤如下:

  1. 在外网机器下载好需要的镜像文件
# 拉取 mysql 镜像
docker pull mysql:8.4.2
# 拉取 redis 镜像
docker pull redis:latest
# 拉取 minio 镜像
docker pull minio/minio:latest 
# 拉取 nexus 镜像
docker pull sonatype/nexus3:latest
# 拉取 gitea 镜像
docker pull gitea/gitea:latest
  1. 导出镜像文件
# 导出 mysql 镜像
docker save -o mysql.tar mysql:8.4.2
# 导出 redis 镜像
docker save -o redis.tar redis:latest
# 导出 minio 镜像
docker save -o minio.tar minio/minio:latest
# 导出 nexus3 镜像
docker save -o nexus3.tar sonatype/nexus3:latest
# 导出 mysql 镜像
docker save -o gitea.tar gitea/gitea:latest
  1. 发送到内网服务器

使用命令或者 FTP 工具将镜像文件拷贝到内网服务器

  1. 内网服务器加载镜像
# 加载 mysql 镜像
docker load -i mysql.tar
# 加载 redis 镜像
docker load -i redis.tar 
# 加载 minio 镜像
docker load -i minio.tar 
# 加载 nexus3 镜像
docker load -i nexus3.tar 
# 加载 mysql 镜像
docker load -i gitea.tar

docker-compose

简介

docker-compose 是 docker 官方的开源项目,用于定义和运行多个容器应用程序的工具,它允许用户通过 YAML 文件来配置应用程序服务,并通过 docker-compose 命令来启动、停止和管理整个应用程序。
docker-compsoe 简化了容器应用程序之间的部署和管理过程,使得开发者可以快速的搭建应用,并且可以应用在不同的系统环境中,减少配置错误带来的问题。

安装

在线安装

  1. 执行安装命令

sudo curl -L "[https://github.com/docker/compose/releases/download/v2.29.1/docker-compose-$(uname](https://github.com/docker/compose/releases/tag/v2.29.1) -s)-$(uname -m)" -o /usr/bin/docker-compose

  1. 如需要安装其他版本的请替换上述命令的 v2.29.1 为想要的版本号,查看版本请前往https://github.com/docker/compose/releases
  2. 赋予可执行权限

sudo chmod +x /usr/bin/docker-compose

  1. 通过 docker-compose 验证是否安装成功

离线安装

  1. 下载安装包

点击前往官方下载安装文件,进入 https://github.com/docker/compose/releases,选择合适的版本进行下载
image.png

  1. 安装
    1. 将文件命名为 docker-compose 并将文件移动到 /usr/bin 中

sudo mv docker-compose-linux-x86_64 /usr/bin/docker-compose

  1. 赋予可执行权限

sudo chmod +x /usr/bin/docker-compose

  1. 通过 docker-compose 验证是否安装成功

image.png

卸载

通过 rm /usr/bin/docker-compose删除

常用命令

docker-compose 的常用命令格式为 docker-compose [OPTIONS] COMMAND,docker-compose 的命令与 docker 的命令非常相似,常用的命令有

  1. docker-compose up

用于根据指定文件创建和启动容器,如果没有指定文件默认为当前目录下的 docker-compose.yml 文件,常用的参数有:

参数说明
-f指定 compose 编排文件
-d后台执行
–force-recreate强制重新创建容器,即使未发生改动
–no-recreate如果容器存在,不重新创建,不能与–force-recreate 同时使用
–remove-orphans删除没有在 compose 文件中定义的容器
–build在启动容器前构建镜像
–no-build不自动构建镜像
–no-start创建服务后不启动
–scale将服务实例扩容到指定数量,会覆盖在 compose 文件中设置该选项
  1. docker-compose down

用于停止和删除容器、网络和卷,常用的参数有

参数说明
–rmi string删除服务关联的镜像,可选的参数有 all 删除所有镜像,local 删除本地镜像
-v, --volumes删除 compose 中声明的卷
–remove-orphans删除未在 compose 文件定义的容器
  1. docker-compose ps

查看由 docker-compose 管理的容器,默认使用当前目录下的 docker-compose.yml 文件可通过-f 指定 compose 文件,默认只显示正在运行的容器,可通过 docker-compose ps -a 查看所有容器

  1. docker-compose stats

查看对应 compose 文件管理的容器资源使用情况,默认查看正在运行的容器,通过 -a 参数查看所有

  1. docker-compose cp

在容器和宿主机之间复制文件

  1. 容器文件复制到宿主机

docker compose cp [OPTIONS] SERVICE:SRC_PATH DEST_PATH|-

  1. 宿主机文件复制到容器

docker compose cp [OPTIONS] SRC_PATH|- SERVICE:DEST_PATH

  1. docker-compose exec

在正在运行的容器中执行命令,格式为:docker compose exec [OPTIONS] SERVICE COMMAND [ARGS...]

  1. docker-compose start

启动对应 compose 文件对应的服务

  1. docker-compose restart

重启对应 compose 文件对应的服务

  1. docker-compose stop

停止对应 compose 文件对应的服务

实战 docker-compose 部署 mysql 、redis

mysql 和 redis 是常用的开发应用软件,本系列教程的后续多个应用也依赖于 mysql 和 redis,如果是纯内网可参考上述教程准备好镜像,在本教程后续会搭建 docker 私服,则不需要手动加载镜像

  1. 创建目录用于卷挂载
    1. mysql
      1. /opt/mysql/data:存放 mysql 数据
      2. /opt/mysql/conf.d/:存放 mysql 配置
      3. my.cnf 文件
[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8
default-storage-engine=INNODB
sql_mode="ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
max_allowed_packet=7096M
lower_case_table_names=1
  1. redis
    1. /opt/redis/data:存放 redis 数据
    2. /opt/redis/config:存放 redis 配置
    3. /opt/redis/logs:存放 redis 日志
    4. redis.conf 文件
################################## NETWORK #####################################
port 6379
tcp-keepalive 300
################################# GENERAL #####################################
daemonize no
supervised no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
databases 16
always-show-logo yes
################################ SNAPSHOTTING  ################################
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbchecksum yes
dbfilename dump.rdb
rdb-del-sync-files no
dir ./
################################# REPLICATION #################################
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
################################## SECURITY ################################################################ LAZY FREEING ####################################
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
############################## APPEND ONLY MODE ###############################
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-use-rdb-preamble yes
################################ LUA SCRIPTING  ###############################
lua-time-limit 5000
notify-keyspace-events ""
############################### ADVANCED CONFIG ###############################
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
########################### ACTIVE DEFRAGMENTATION #######################
jemalloc-bg-thread yes
  1. 创建网络:docker network create env-net
  2. 编写 docker-compose.yml
version: "3.8"networks:env-net:driver: bridge
services:db:image: mysql:8.4.2restart: on-failurecontainer_name: mysqlenvironment:- TZ=Asia/Shanghai- MYSQL_ROOT_PASSWORD=root- INSTALL4J_ADD_VM_PARAMS=-Xms128m -Xmx1024m -XX:MaxDirectMemorySize=512m- MYSQL_USER=gitea- MYSQL_PASSWORD=gitea- MYSQL_DATABASE=giteaports:- "3306:3306"networks:- env-netvolumes:- /opt/mysql/data/:/var/lib/mysql/- /opt/mysql/conf.d/my.cnf:/etc/mysql/my.cnfprivileged: trueredis:image: redis:latestcontainer_name: redisrestart: on-failureports:- "6379:6379"command:redis-server /etc/redis/redis.confvolumes:- /opt/redis/data:/data- /opt/redis/config/redis.conf:/etc/redis/redis.conf- /opt/redis/logs:/logsnetworks:- env-netprivileged: true
  1. 启动,通过 sudo docker-compose up -d 启动,等待服务部署
  2. 查看是否部署成功,通过 docker-compose ps 查看容器状态

结语

本文介绍了 docker 和 docker-compose 在线和离线的两种方式,以及 docker-compose 的常见命令,最后实操如何利用 docker-compose 部署 mysql 和 redis。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/401546.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Oracle VM VirtualBox虚拟机内存不够用的解决方案

一、 前言 在使用Oracle VM VirtualBox虚拟机的过程中&#xff0c;随着时间的推移&#xff0c;我们会感觉我们的内存越来越不够用&#xff0c;今天就来给大家分享一下我们如何解决虚拟机内存不够用的问题。 二、解决方法 1.虚拟机碎片化整理 我们第一步要做的是碎片整理&…

VScode找python环境 (conda)

CtrlshiftP 会弹出如下框&#xff1a; 框里输入&#xff1a; Python:Select Interpreter 会得到&#xff1a;

24/8/15算法笔记 dp策略迭代 价值迭代

策略迭代&#xff1a; 策略迭代从某个策略开始&#xff0c;计算该策略下的状态价值函数。它交替进行两个步骤&#xff1a;策略评估&#xff08;Policy Evaluation&#xff09;和策略改进&#xff08;Policy Improvement&#xff09;。在策略评估阶段&#xff0c;计算给定策略下…

模电实验3 - 单电源集成运放交流耦合放大器

实验目标 学习集成运放的单电源使用。掌握交流耦合单电源集成运放放大器的测试方法。了解交流耦合单电源集成运放放大器的特点。 实验器材 ADALM2000 1kΩ 电阻 (1/4 W) x 1 10 kΩ 电阻 (1/4 W) x 1 100kΩ 电阻 (1/4 W) x 3 0.1μF电容 x 1 1μF电容 …

【深度学习】单层神经网络

单层神经网络 神经元感知机 1943年&#xff0c;心理学家McCulloch和数学家Pitts共同发表了神经网络的开山之作A Logical Calculus of the Ideas Immanent in Nervours Activity1&#xff0c;提出了神经网络的第一个数学模型——MP模型。该模型也成为了人工神经网络的基础。 神经…

7 数据存储单位,整型、浮点型、字符型、布尔型数据类型,sizeof 运算符

目录 1 数据类型的分类 2 数据存储单位 2.1 位 2.2 字节 2.3 其余单位 3 整数类型 3.1 基本介绍 3.2 整型的类型 3.2.1 整数类型多样性的原因 3.2.2 整型类型之间的相对大小关系 3.3 整型注意事项 3.4 字面量后缀 3.5 格式占位符 3.6 案例&#xff1a;声明并输出…

无参数读文件

目录 代码 代码解析 如何绕过获取flag 第一种方法(在apache中) ​编辑 第二种方法 首先获取目录下文件 代码 <?php highlight_file(__FILE__); if(; preg_replace(/[^\W]\((?R)?\)/, , $_GET[code])) { eval($_GET[code]); } ?> 代码解析 [^\W]\((?R)?…

接口优化笔记

索引 添加索引 where条件的关键自动或者order by后面的排序字段可以添加索引加速查询 索引只能通过删除新增进行修改&#xff0c;无法直接修改。 # 查看表的索引 show index from table_name; show create table table_name; # 添加索引 alter table table_name add index …

C/C++开发---全篇

1、统筹 学习目标&#xff1a; C/C、python精通。 就业匹配方向&#xff1a;专精一个领域&#xff0c;延长职业生涯。 &#xff08;1&#xff09;适配行业&#xff1b; &#xff08;2&#xff09;量化&#xff1b; &#xff08;3&#xff09;安全&#xff1b; &#xff08;4&…

华为od统一考试B卷【比赛】python实现

def split_params(param_str): return list(map(int, param_str.split(,))) def main(): # 获取输入 target_str input().strip() # 输入验证&#xff0c;拆分并转换为整数 try: m, n split_params(target_str) except ValueError: print(-1) return # 检查 M 和 …

react的pdf转图片格式上传到后端

这个东西做的我真的是头昏脑涨 主要需求是&#xff0c;upload上传pdf&#xff0c;pdf转图片格式展示&#xff0c;以图片格式上传到后端 封装了组件代码 父组件直接放就可以了 使用的插件pdfjs-dist&#xff0c;版本是 "pdfjs-dist": "2.5.207", impor…

高性能跨平台网络通信框架 HP-Socket v6.0.2

项目主页 : http://www.oschina.net/p/hp-socket开发文档 : https://www.docin.com/p-4592706661.html下载地址 : https://github.com/ldcsaa/HP-SocketQQ Group: 44636872, 663903943 v6.0.2 更新 一、主要更新 优化Linux通信组件多路复用处理架构&#xff0c;避免“惊群”问…

计算机的错误计算(六十三)

摘要 计算机的错误计算&#xff08;五十六&#xff09;探讨了大数的正切函数值的错误计算。本节讨论大数的余切函数的计算精度问题。 例1. 已知 计算 不妨用 3种方法计算。 (1) 在 Python 中利用 直接贴图&#xff1a; (2) 在 Java 中利用 若运行下列代码 import ja…

高密度互连HDI

HDI&#xff08;High Density Interconnector&#xff0c;高密度互连&#xff09;是一种先进的PCB技术&#xff0c;在有限的空间内&#xff0c;通过使用微细过孔和精细的布线来提高电路板的集成度。 特点&#xff1a; 微细过孔&#xff08;Microvias&#xff09;&#xff1a;…

城V4系列版本开源前后端uniapp代码

本文来自&#xff1a;智慧同城V4系列版本开源前后端uniapp代码 - 源码1688 应用介绍 演示地址&#xff1a;https://tongchengsaas.88881111.icu/ 账号&#xff1a;ceshi 密码&#xff1a;12345678 前端演示&#xff1a; 测试环境 php7.2mysql5.6ningx 安装拓展 ioncube&#x…

来看看设计日志组件SDK的基操

一、总览 设计一个日志组件来监控业务中的流程节点&#xff1b;我们需要分三步&#xff1b; 获取数据整理数据上传数据 二、获取数据 日常项目中使用的日志组件有&#xff1a;logback log4j: 优点&#xff1a;成熟稳定&#xff0c;灵活性高&#xff0c;性能良好&#xff0…

Windows平台RTSP|RTMP播放器如何实时调节音量

我们在做Windows平台RTSP、RTMP播放器的时候&#xff0c;有这样的技术需求&#xff0c;特别是多路监控的时候&#xff0c;并不是每一路audio都需要播放出来的&#xff0c;所以&#xff0c;这时候&#xff0c;需要有针对音量调节的设计&#xff1a; /** smart_player_sdk.cs* C…

★ C++基础篇 ★ 栈和队列

Ciallo&#xff5e;(∠・ω< )⌒☆ ~ 今天&#xff0c;我将继续和大家一起学习C基础篇第八章----栈和队列 ~ 目录 一 容器适配器 二 deque的简单介绍 2.1 deque的原理介绍 2.2 deque vector list 的优缺点 2.2.1 vector 2.2.2 list 2.2.3 deque 2.3 为什么选择deq…

ECMAScript性能优化技巧与陷阱

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言 ECMAScript&#xff0c;即JavaScript&#xff0c;是一种广泛应用于Web开发中的脚本语言。随着现代Web应用的复杂度日益增加&#xff0c;如何优化JavaScript的性能变得至关重要。性能优化不仅能提高应用的响应速度&#x…

排序算法【冒泡排序】

一、原理 冒泡排序的原理比较简单&#xff0c;就是将待排序区域的数值挨个向后对比&#xff0c;直到比较到已排序的边界&#xff0c;就纳入已排序区域。 二、代码如下所示&#xff1a; #include <stdio.h> #include "test.h"/* 冒泡排序 */ void bubble_sort(…