搭建内网开发环境(一)|基于docker快速部署开发环境
引言
最近因需要搭建一套简易版的纯内网的开发环境,服务器采用 centos8.0,容器化技术采用 docker 使用 docker-compose 进行容器编排。
该系列教程分为两大类:
- 软件安装和使用,这类是开发环境常用的软件部署和使用,涉及到的应用有:
- docker
- nexus
- gitea
- mysql
- redis
- minio
- 应用部署实战:通过实战将开发好的程序部署到搭建好的开发环境中
docker
安装
对于 docker 的安装分为两种情形,一种是服务器能够访问外网,这种安装比较简单,一种是不能访问外网,对于纯内网安装,需要提前准备好安装文件,复制到内网服务器上。
在线安装
- 卸载旧版本
sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine
- 设置 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
- 安装 docker enginer
- 安装最新版本
sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
- 指定版本安装
- 查看版本号:
yum list docker-ce --showduplicates | sort -r
- 查看版本号:
2. 选择版本号进行安装:`sudo yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io`
- 启动 docker
- 启动命令:
systemctl start docker
- 查看是否启动成功,通过
docker info
命令输出 docker 版本信息则安装成功
- 启动命令:
- 卸载 docker
- 删除安装包
yum remove docker
- 删除镜像、容器等相关文件
rm -rf /var/lib/docker
离线安装
如果服务器没有外网的情况下,如果通过在线直接获取安装包,这种情况下需要先将安装包准备好上传到服务器在进行安装。
下载安装包
- 进入官网下载页面进行选择对应的版本下载,页面链接https://download.docker.com/linux/static/stable/x86_64/
安装
- 解压安装包:
tar -zxvf docker-20.10.9.tgz
- 安装到 /usr/bin/:
mv /docker/* /usr/bin/
- 创建 docker 服务
- 编辑 /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
- 重启 docker 加载配置文件,并设置开启启动
- 重启:
sudo systemctl daemon-reload && sudo systemctl restart docker
- 设置开机启动:
sudo systemctl enable docker
- 重启:
- 查看docker是否启动成功,使用命令 systemctl status docker
设置镜像源
- 编辑 /etc/docker/daemon.json 文件,添加阿里云镜像源,内容如下:
{
"registry-mirrors": ["https://registry.cn-hangzhou.aliyuncs.com"]
}
- 重启 docker 使配置生效
sudo systemctl daemon-reload && sudo systemctl restart docker
纯内网如何下载镜像
如果是纯内网部署,且还搭建好私服(这个在后续的教程中会演示)如何获取 docker 镜像呢?
首先需要将部门需要的镜像提前准备好(后期部署好 docker 私服后可从私服下载镜像)先从一台外网机器下载好所需要的镜像,并导出镜像,发送到内网服务上,再在内网服务器上加载镜像到 docker 中;具体步骤如下:
- 在外网机器下载好需要的镜像文件
# 拉取 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
- 导出镜像文件
# 导出 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
- 发送到内网服务器
使用命令或者 FTP 工具将镜像文件拷贝到内网服务器
- 内网服务器加载镜像
# 加载 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 简化了容器应用程序之间的部署和管理过程,使得开发者可以快速的搭建应用,并且可以应用在不同的系统环境中,减少配置错误带来的问题。
安装
在线安装
- 执行安装命令
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
- 如需要安装其他版本的请替换上述命令的 v2.29.1 为想要的版本号,查看版本请前往https://github.com/docker/compose/releases
- 赋予可执行权限
sudo chmod +x /usr/bin/docker-compose
- 通过 docker-compose 验证是否安装成功
离线安装
- 下载安装包
点击前往官方下载安装文件,进入 https://github.com/docker/compose/releases,选择合适的版本进行下载
- 安装
- 将文件命名为 docker-compose 并将文件移动到 /usr/bin 中
sudo mv docker-compose-linux-x86_64 /usr/bin/docker-compose
- 赋予可执行权限
sudo chmod +x /usr/bin/docker-compose
- 通过 docker-compose 验证是否安装成功
卸载
通过 rm /usr/bin/docker-compose
删除
常用命令
docker-compose 的常用命令格式为 docker-compose [OPTIONS] COMMAND
,docker-compose 的命令与 docker 的命令非常相似,常用的命令有
- 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 文件中设置该选项 |
- docker-compose down
用于停止和删除容器、网络和卷,常用的参数有
参数 | 说明 |
---|---|
–rmi string | 删除服务关联的镜像,可选的参数有 all 删除所有镜像,local 删除本地镜像 |
-v, --volumes | 删除 compose 中声明的卷 |
–remove-orphans | 删除未在 compose 文件定义的容器 |
- docker-compose ps
查看由 docker-compose 管理的容器,默认使用当前目录下的 docker-compose.yml 文件可通过-f 指定 compose 文件,默认只显示正在运行的容器,可通过 docker-compose ps -a 查看所有容器
- docker-compose stats
查看对应 compose 文件管理的容器资源使用情况,默认查看正在运行的容器,通过 -a 参数查看所有
- docker-compose cp
在容器和宿主机之间复制文件
- 容器文件复制到宿主机
docker compose cp [OPTIONS] SERVICE:SRC_PATH DEST_PATH|-
- 宿主机文件复制到容器
docker compose cp [OPTIONS] SRC_PATH|- SERVICE:DEST_PATH
- docker-compose exec
在正在运行的容器中执行命令,格式为:docker compose exec [OPTIONS] SERVICE COMMAND [ARGS...]
- docker-compose start
启动对应 compose 文件对应的服务
- docker-compose restart
重启对应 compose 文件对应的服务
- docker-compose stop
停止对应 compose 文件对应的服务
实战 docker-compose 部署 mysql 、redis
mysql 和 redis 是常用的开发应用软件,本系列教程的后续多个应用也依赖于 mysql 和 redis,如果是纯内网可参考上述教程准备好镜像,在本教程后续会搭建 docker 私服,则不需要手动加载镜像
- 创建目录用于卷挂载
- mysql
- /opt/mysql/data:存放 mysql 数据
- /opt/mysql/conf.d/:存放 mysql 配置
- my.cnf 文件
- mysql
[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
- redis
- /opt/redis/data:存放 redis 数据
- /opt/redis/config:存放 redis 配置
- /opt/redis/logs:存放 redis 日志
- 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
- 创建网络:docker network create env-net
- 编写 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
- 启动,通过 sudo docker-compose up -d 启动,等待服务部署
- 查看是否部署成功,通过 docker-compose ps 查看容器状态
结语
本文介绍了 docker 和 docker-compose 在线和离线的两种方式,以及 docker-compose 的常见命令,最后实操如何利用 docker-compose 部署 mysql 和 redis。
相关文章:

搭建内网开发环境(一)|基于docker快速部署开发环境
引言 最近因需要搭建一套简易版的纯内网的开发环境,服务器采用 centos8.0,容器化技术采用 docker 使用 docker-compose 进行容器编排。 该系列教程分为两大类: 软件安装和使用,这类是开发环境常用的软件部署和使用,涉…...

MATLAB R2023b配置Fortran编译器
MATLAB R2023b配置Fortran编译器 引言1. 安装Visual Studio 20192. 安装Intel API20243. 配置xml文件文件4. 设置环境变量5. MATLAB编译Fortran 引言 当我们需要用到MATLAB编译Fortran代码后进行调用计算时,整个配置流程较繁琐。下面以MATLAB R2023b为例࿰…...

2024新型数字政府综合解决方案(七)
新型数字政府综合解决方案通过集成人工智能、大数据、区块链和云计算技术,创建了一个高度智能化和互联互通的政府服务平台,旨在全面提升行政效率、服务质量和透明度。该平台实现了跨部门的数据整合与实时共享,利用人工智能进行智能决策支持和…...
搭建高可用k8s集群
高可用 Kubernetes V1.28.10 安装 文章目录 1. 环境介绍2. 准备工作2.1 修改主机名称2.2 修改hosts文件2.3 关闭防火墙和SLinux2.4 配置SSH免密访问2.4.1 主机名称: k8s-master-01 操作 2.5 配置yum源2.6 禁用Swarp分区2.7 同步时间2.8 配置内核转发及网桥过滤2.9 安装 IPVS 3…...

完美解决html2canvas + jsPDF导出pdf分页内容截断问题
代码地址:https://github.com/HFQ12333/export-pdf.git html2canvas jspdf方案是前端实现页面打印的一种常用方案,但是在实践过程中,遇到的最大问题就是分页截断的问题:当页面元素超过一页A4纸的时候,连续的页面就会…...
14 地址映射
14 地址映射 1、地址划分2、相关函数2.1 ioremap/iounmap2.2 mmap地址映射 3、总结 1、地址划分 明确:在linux系统中,不管是应用程序还是驱动程序,都不允许直接访问外设的物理地址,要想访问必须将物理地址映射到用户虚拟地址或者内核虚拟地址࿰…...

Java Resilience4j-RateLimiter学习
一. 介绍 Resilience4j-RateLimiter 是 Resilience4j 中的一个限流模块,我们对 Resilience4j 的 CircuitBreaker、Retry 已经有了一定的了解,现在来学习 RateLimiter 限流器; 引入依赖; <dependency><groupId>io.g…...

Nginx--地址重写Rewrite
一、什么是Rewrite Rewrite对称URL Rewrite,即URL重写,就是把传入Web的请求重定向到其他URL的过程 URL Rewrite最常见的应用是URL伪静态化,是将动态页面显示为静态页面方式的一种技术。比如http://www.123.com/news/index.php?id123 使用U…...

webflux源码解析(1)-主流程
目录 1.关键实例的创建1.1 实例创建1.2 初始化 2.处理请求的关键流程2.1 从ReactorHttpHandlerAdapter开始2.1 DispatcherHandler的初始化2.2查找mapping handler2.3 处理请求(执行handler)2.4 返回结果处理 3.webflux的配置装配参考: WebFlux是Spring 5.0框架推出的…...
ipad作为扩展屏的最简单方式
将iPad用作扩展屏幕有几种简单而有效的方法。以下是几种常见的方式: 1. Sidecar(苹果官方功能) 适用设备:iPad和Mac(macOS Catalina及以上版本)。功能:Sidecar 是苹果官方的功能,可…...
【卡码网Python基础课 17.判断集合成员】
目录 题目描述与分析一、集合二、集合的常用方法三、代码编写 题目描述与分析 题目描述: 请你编写一个程序,判断给定的整数 n 是否存在于给定的集合中。 输入描述: 有多组测试数据,第一行有一个整数 k,代表有 k 组测…...

生物研究新范式!AI语言模型在生物研究中的应用
–https://doi.org/10.1038/s41592-024-02354-y 留意更多内容,欢迎关注微信公众号:组学之心 Language models for biological research: a primer 研究团队及研究单位 James Zou–Department of Biomedical Data Science, Stanford University, Stan…...
python语言day08 属性装饰器和property函数 异常关键字 约束
属性装饰器: 三个装饰器实现对私有化属性_creat_time的get,set,del方法; 三个装饰器下的方法名都一样,通过message.creat_time的不同操作实现调用get,set,del方法。 __inti__: 创建并…...
day01JS-数据类型-01
1. 浏览器内核 通常所谓的浏览器内核也就是浏览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。不同的浏览器内核对网页编写语法的解释也有不同,因此同一网页在不同的内核的浏览器里的渲染(显示)…...

MATLAB 手动实现一种高度覆盖值提取建筑物点云的方法(74)
专栏往期文章,包含本章 MATLAB 手动实现一种高度覆盖值提取建筑物点云的方法(74) 一、算法介绍二、算法实现1.代码2.效果总结一、算法介绍 手动实现一种基于高度覆盖值的建筑物点云提取方法,适用于高大的城市建筑物,比只利用高度提取建筑物的方法更加稳定和具有价值,主要…...

git的下载与安装(Windows)
Git是一个开源的分布式版本控制系统(Distributed Version Control System,简称DVCS),它以其高效、灵活和强大的功能,在现代软件开发中扮演着至关重要的角色。 git官网:Git (git-scm.com) 1.进入git官网 2…...

腾讯云AI代码助手 —— 编程新体验,智能编码新纪元
阅读导航 引言一、开发环境介绍1. 支持的编程语言2. 支持的集成开发环境(IDE) 二、腾讯云AI代码助手使用实例1. 开发环境配置2. 代码补全功能使用💻自动生成单句代码💻自动生成整个代码块 3. 技术对话3. 规范/修复错误代码4. 智能…...

使用 ESP32 和 TFT 屏幕显示实时天气信息 —— 基于 OpenWeatherMap API
实时监测环境数据是一个非常常见的应用场景,例如气象站、智能家居等。这篇博客将带你使用 ESP32 微控制器和一个 TFT 屏幕,实时显示当前城市的天气信息。通过 OpenWeatherMap API,我们能够获取诸如温度、天气情况以及经纬度等详细的天气数据&…...

高阶数据结构——B树
1. 常见的搜索结构 以上结构适合用于数据量相对不是很大,能够一次性存放在内存中,进行数据查找的场景。如果数据量很大,比如有100G数据,无法一次放进内存中,那就只能放在磁盘上了,如果放在磁盘上࿰…...

Vue2中watch与Vue3中watch对比和踩坑
上一节说到了 computed计算属性对比 ,虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时&#…...

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)
题目:3442. 奇偶频次间的最大差值 I 思路 :哈希,时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况,哈希表这里用数组即可实现。 C版本: class Solution { public:int maxDifference(string s) {int a[26]…...

微信小程序之bind和catch
这两个呢,都是绑定事件用的,具体使用有些小区别。 官方文档: 事件冒泡处理不同 bind:绑定的事件会向上冒泡,即触发当前组件的事件后,还会继续触发父组件的相同事件。例如,有一个子视图绑定了b…...
day52 ResNet18 CBAM
在深度学习的旅程中,我们不断探索如何提升模型的性能。今天,我将分享我在 ResNet18 模型中插入 CBAM(Convolutional Block Attention Module)模块,并采用分阶段微调策略的实践过程。通过这个过程,我不仅提升…...

Docker 运行 Kafka 带 SASL 认证教程
Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...
测试markdown--肇兴
day1: 1、去程:7:04 --11:32高铁 高铁右转上售票大厅2楼,穿过候车厅下一楼,上大巴车 ¥10/人 **2、到达:**12点多到达寨子,买门票,美团/抖音:¥78人 3、中饭&a…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...

安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲
文章目录 前言第一部分:体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分:体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...

处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
ubuntu22.04 安装docker 和docker-compose
首先你要确保没有docker环境或者使用命令删掉docker sudo apt-get remove docker docker-engine docker.io containerd runc安装docker 更新软件环境 sudo apt update sudo apt upgrade下载docker依赖和GPG 密钥 # 依赖 apt-get install ca-certificates curl gnupg lsb-rel…...