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

news2025/1/22 15:51:18

引言

最近因需要搭建一套简易版的纯内网的开发环境,服务器采用 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.2
    restart: on-failure
    container_name: mysql
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=root
      - INSTALL4J_ADD_VM_PARAMS=-Xms128m -Xmx1024m -XX:MaxDirectMemorySize=512m
      - MYSQL_USER=gitea
      - MYSQL_PASSWORD=gitea
      - MYSQL_DATABASE=gitea
    ports:
      - "3306:3306"
    networks:
      - env-net
    volumes:
      - /opt/mysql/data/:/var/lib/mysql/
      - /opt/mysql/conf.d/my.cnf:/etc/mysql/my.cnf
    privileged: true
  redis:
    image: redis:latest
    container_name: redis
    restart: on-failure
    ports:
      - "6379:6379"
    command:
      redis-server /etc/redis/redis.conf
    volumes:
      - /opt/redis/data:/data
      - /opt/redis/config/redis.conf:/etc/redis/redis.conf
      - /opt/redis/logs:/logs
    networks:
      - env-net
    privileged: true
  1. 启动,通过 sudo docker-compose up -d 启动,等待服务部署
  2. 查看是否部署成功,通过 docker-compose ps 查看容器状态

结语

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue框架学习笔记-8

Vue中的跨域问题 在Vue项目中遇到跨域问题&#xff0c;通常是因为前端&#xff08;Vue&#xff09;和后端&#xff08;如Node.js, Django, Spring Boot等&#xff09;部署在不同的域名或端口上&#xff0c;浏览器出于安全考虑&#xff0c;会阻止跨域请求。解决Vue中的跨域问题…

获取专项练习

文章目录 1.sun-club-practice-api1.vo构建1.SpecialPracticeVO.java2.SpecialPracticeCategoryVO.java3.SpecialPracticeLabelVO.java 2.SubjectInfoTypeEnum.java 2.sun-club-practice-server1.PracticeSetController.java2.service1.PracticeSetService.java2.PracticeSetSe…

基于SpringBoot的秒杀系统设计与实现

TOC springboot193基于SpringBoot的秒杀系统设计与实现 第1章 绪论 1.1 研究背景 互联网时代不仅仅是通过各种各样的电脑进行网络连接的时代&#xff0c;也包含了移动终端连接互联网进行复杂处理的一些事情。传统的互联网时代一般泛指就是PC端&#xff0c;也就是电脑互联网…

开放式耳机怎么样好用吗?六个专业好招教你选!

传统入耳式耳机容易滑落&#xff0c;而且戴久了耳朵疼&#xff0c;近段时间&#xff0c;耳机圈开始流行开放式耳机。开放式耳机的出现就避免了这个问题的出现&#xff0c;本文就为大家推荐几款使用感较好的开放式耳机&#xff0c;一起来看看吧~现在开放式耳机太多了&#xff0c…

IO进程(学习)2024.8.15

目录 重定向打开文件 文件IO 概念 特点 函数 1.打开文件 2.关闭文件 3.读写文件 read write 4.文件定位操作 重定向打开文件 FILE * freopen(const char *pathname, const char *mode, FILE* fp) 功能&#xff1a;将指定的文件流重定向到打开的文件中 参数&#…

离散数学概论

目录 一、引言 二、离散数学的主要内容 1. 集合论 1.1 集合的基本概念 1.2 集合的运算 集合运算总结表格 2. 数理逻辑 2.1 命题逻辑 2.2 逻辑推理 2.3 逻辑等价 逻辑联结词与逻辑等价总结表格 3. 组合数学 3.1 计数原理 3.2 排列与组合 3.3 容斥原理 组合数学总…

15.基于session实现登录 前端项目部署

前端项目nginx部署 nginx配置文件 worker_processes 1;events {worker_connections 1024; }http {include mime.types;default_type application/json;sendfile on;keepalive_timeout 65;server {listen 8080;server_name localhost;# 指定前端项目所…

手把手教你CNVD漏洞挖掘 + 资产收集

0x1 前言 挖掘CNVD漏洞有时候其实比一般的edusrc还好挖&#xff0c;但是一般要挖证书的话&#xff0c;还是需要花时间的&#xff0c;其中信息收集&#xff0c;公司资产确定等操作需要花费一定时间的。下面就记录下我之前跟一个师傅学习的一个垂直越权成功的CNVD漏洞通杀&#…

【案例42】“”引发的“血案”--建表带双引号

问题现象 数据抽取工具报错。 研发排查后发现&#xff0c;这条语句不执行导致。转来让解决此问题。 问题分析 与研发沟通发现。是因为在user_segments 中一直有FIP_OPERATINGLOG_copy1 造成的。 询问可以直接drop掉相关表&#xff0c; drop table FIP_OPERATINGLOG_copy1 ; …

十一、实现逻辑层

系列文章目录&#xff1a;C asio网络编程-CSDN博客 1、服务器架构设计 2、单例模板类 我们的LogicSystem类为单例类&#xff0c;可以只把这个类写为单例&#xff0c;也可以写一个单例模板类&#xff0c;让其它类继承它就可以形成单例。这里选择第二种&#xff0c;因为后面可能…

Python利用openpyxl复制Excel文件且保留样式—另存为副本(附完整代码)

目录 专栏导读库的介绍库的安装前言结果预览目录结构完整代码总结专栏导读 🌸 欢迎来到Python办公自动化专栏—Python处理办公问题,解放您的双手 🏳️‍🌈 博客主页:请点击——> 一晌小贪欢的博客主页求关注 👍 该系列文章专栏:请点击——>Python办公自动化专…

配电房动环监控系统 温湿度环境、供配电、UPS集中管控@卓振思众

在现代电力网络中&#xff0c;配电房作为供电系统的核心节点&#xff0c;承担着至关重要的角色。为了保障电力供应的稳定性与可靠性&#xff0c;配电房的管理与监控显得尤为重要。随着技术的不断进步&#xff0c;【卓振思众】智能的配电房动环监控系统应运而生&#xff0c;成为…

# Spring Cloud Alibaba Nacos_配置中心与服务发现(四)

Spring Cloud Alibaba Nacos_配置中心与服务发现&#xff08;四&#xff09; 一、Nacos 配置管理-集群部署 1、 把 nacos 应用程序包&#xff0c;复制3份&#xff0c;分别命名为 nacos1, nacos2, nacos3 分别在 conf 目录下&#xff0c;修改 application.properties 配置文件…

【大模型LLMs】LLMs-based Summarization研究进展梳理

【大模型LLMs】LLMs-based Summarization方法梳理 Survey1 Knowledge Distillation from LLMsRefereeInheritSumm 2 Prompt Engineering2.1 Template EngineeringOdSum 2.2 CoTSumCoTCoDSuReSliSumRefiner 梳理基于大模型的摘要总结方案&#xff0c;持续汇总中&#xff08;更关…

数据埋点系列 9|数据伦理与隐私-在合规与创新间寻找平衡

在数据驱动决策的时代&#xff0c;数据伦理和隐私保护已成为至关重要的议题。组织必须在利用数据创新和保护用户隐私之间找到平衡。本文将探讨数据伦理的核心原则、隐私保护的技术实现&#xff0c;以及如何在合规和创新之间取得平衡。 目录 1. 数据伦理的核心原则1.1 透明度1…

【机器学习】卷积神经网络简介

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 卷积神经网络简介1. 引言2. CNN的基本概念2.1 什么是卷积神经网络2.2 CNN与传统…

uniprot数据库转换ID功能

1.登入uniprot数据库 uniprot 2. 选择ID mapping&#xff0c;输入P31946和P62258等uniprot数据库中的蛋白质ID 然后在To database选项中选择&#xff1a;sequence databases---RefSeq Protein---map 显示已完成&#xff0c;点击ID MAPPING 下方的网址&#xff0c;则可以看到uni…

「12月·长沙」第三届传感、测量、通信和物联网技术国际会议(SMC-IoT 2024)

第三届传感、测量、通信和物联网技术国际会议&#xff08;SMC-IoT 2024&#xff09;将于2024年11月29日-2024年12月1日召开&#xff0c;由湖南涉外经济学院主办。会议中发表的文章将会被收录, 并于见刊后提交EI核心索引。 会议旨在围绕传感、测量、通信和物联网技术等相关研究…

mysql数据库 行级锁,间隙锁和临键锁详解

目录 准备 查看锁命令 演示 普通的select语句 共享锁与排他锁 无索引行锁升级为表锁 间隙锁&临键锁 索引上的等值查询(索引为唯一索引) 索引上的等值查询(索引为普通索引) 索引上的范围查询(唯一索引) 准备 我的mysql版本是8。 CREATE TABLE user (id int unsi…

.NET 8 跨平台高性能边缘采集网关

目录 前言 项目介绍 通道 插件 设备 变量 项目特点 可视化操作 脚本支持 自定义插件支持 性能 断线缓存 完整可商用的边缘网关 项目插件 采集插件 业务插件 项目展示 1、ThingsGateway 演示地址 2、登录页面 3、系统首页 4、网关管理 5、网关状态 6、网关…