基于华为云欧拉操作系统(HCE OS)容器化部署传统应用(Redis+Postgresql+Git+SpringBoot+Nginx)

写在前面


  • 博文内容为 华为云欧拉操作系统入门级开发者认证(HCCDA – Huawei Cloud EulerOS)实验笔记整理
  • 认证地址:https://edu.huaweicloud.com/certificationindex/developer/9bf91efb086a448ab4331a2f53a4d3a1
  • 博文内容涉及一个传统 Springboot 应用HCE部署, 以及相关数据库 Redis、Postgresql、Nginx 的容器化部署
  • 理解不足小伙伴帮忙指正

不必太纠结于当下,也不必太忧虑未来,当你经历过一些事情的时候,眼前的风景已经和从前不一样了。——村上春树


当前默认已经安装了 docker 而且配置了仓库地址

redis 容器化部署

下载最新 Redis 镜像

[root@ecs-hce hce-x86-server]# cd ~ && docker pull redis
Using default tag: latest
latest: Pulling from library/redis
6f28985ad184: Pull complete
60e8b46025d8: Pull complete
122fe26e50b0: Pull complete
de3ca1eb2e20: Pull complete
4813a7e5bd57: Pull complete
99dd8d3a66f2: Pull complete
Digest: sha256:c82cacd2eee119e912ad61abe2a60b2ee728ef06fbb3c0fa1555728e4188bc69
Status: Downloaded newer image for redis:latest

查看镜像

[root@ecs-hce ~]# docker images
REPOSITORY           TAG                 IMAGE ID            CREATED             SIZE
hce/hce-x86-server   202401              7b8fb730c9f6        2 minutes ago       518MB
redis                latest              a617c1c92774        2 years ago         105MB

启动 Redis 容器,注意这里我们指定了运行容器名字为redis-sys,默认情况下,同一网络,docker 会自动把当前容器名字写入 DNS 映射。

[root@ecs-hce ~]# docker run -itd  --name redis-sys -p 6379:6379 redis
97cf7d59fd8a40ccb370c3c899e680d744bbcc38b621182fad4c1e33fe81907c

查看容器

[root@ecs-hce ~]# docker ps
CONTAINER ID        IMAGE                       COMMAND                  CREATED             STATUS              PORTS                    NAMES
97cf7d59fd8a        redis                       "docker-entrypoint.s…"   5 seconds ago       Up 4 seconds        0.0.0.0:6379->6379/tcp   redis-sys
ad84d6222925        hce/hce-x86-server:202401   "/bin/bash"              2 minutes ago       Up 2 minutes                                 festive_matsumoto

进入 Redis 容器,进入 Redis 客户端,Redis 部署成功确认

[root@ecs-hce ~]# docker exec -it redis-sys /bin/bash
root@97cf7d59fd8a:/data# redis-cli
127.0.0.1:6379>
root@97cf7d59fd8a:/data# exit
[root@ecs-hce ~]#

Postgresql 容器化部署

拉取 Postgresql 镜像

[root@ecs-hce ~]# cd ~ &&docker pull postgres:13
13: Pulling from library/postgres
6f28985ad184: Already exists
163a60947b3a: Pull complete
1791984387e5: Pull complete
ccf9c39579c4: Pull complete
1d8dd50a5ee9: Pull complete
3991abc55a94: Pull complete
4cf2cdef0857: Pull complete
ed1bec410498: Pull complete
0930368b9a14: Pull complete
a9302936fdb5: Pull complete
bb3d505cd0cb: Pull complete
4f1bb2dd6f16: Pull complete
8d3f6ff7b2da: Pull complete
687caf1b1f9b: Pull complete
Digest: sha256:b94ab3a31950e7d25654d024044ac217c2b3a94eff426e3415424c1c16ca3fe6
Status: Downloaded newer image for postgres:13

查看镜像

[root@ecs-hce ~]# docker images | grep po
postgres             13                  c5ec7353d87d        2 years ago         314MB

创建容器,这里需要我们添加的变量,不同的镜像版本变量略有不同,同样通过 name 指定 DNS 域名映射。

[root@ecs-hce ~]# docker run -p 5432:5432 -it --name postgres --restart always -e POSTGRES_PASSWORD=123456 -e ALLOW_IP_RANGE=0.0.0.0/0 -v /home/postgres/data:/var/lib/postgresql -d postgres:13
8743d3c98d38c8c42db3beeb9745c4b182c9378e8a6f907a27d70709418a5390

进入数据库容器,创建数据库

[root@ecs-hce ~]# docker exec -it postgres bash
root@8743d3c98d38:/# psql -U postgres -W
Password:
psql (13.2 (Debian 13.2-1.pgdg100+1))
Type "help" for help.postgres=# create database oasys;
CREATE DATABASE
postgres=# \q
root@8743d3c98d38:/# exit

拷贝 pg_hba.conf 配置文件至本机

[root@ecs-hce ~]# sudo docker cp postgres:/var/lib/postgresql/data/pg_hba.conf /home

修改 pg_hba.conf 文件,在# IPv4 local connections:后添加以下内容,并保存

pg_hba.conf 文件用于配置客户端对 PostgreSQL 数据库的连接权限,最后一行配置了一条规则,允许来自任意 IP 地址(0.0.0.0/0)的所有用户(all)以 “trust” 方式进行身份验证访问所有的数据库(all)

[root@ecs-hce ~]# vi /home/pg_hba.conf
[root@ecs-hce ~]# tail -1 /home/pg_hba.conf
host    all             all             0.0.0.0/0               trust

将 pg_hba.conf 文件拷贝回容器,进入容器,重启 postgresql 并使配置生效

[root@ecs-hce ~]# sudo docker cp /home/pg_hba.conf postgres:/var/lib/postgresql/data
[root@ecs-hce ~]# docker exec -it postgres bash
root@8743d3c98d38:/# su postgres
postgres@8743d3c98d38:/$ ./usr/lib/postgresql/13/bin/pg_ctl restart
waiting for server to shut down....[root@ecs-hce ~]#
[root@ecs-hce ~]#

安装 git,获取项目数据

[root@ecs-hce ~]# yum install -y git >> /dev/null
Failed to set locale, defaulting to C.UTF-8

创建 code 目录并进入,拉取代码及数据文件

[root@ecs-hce ~]# mkdir /home/code
[root@ecs-hce ~]# cd /home/code
[root@ecs-hce code]# git clone https://codehub.devcloud.cn-north-4.huaweicloud.com/oasys00001/oasys.git
Cloning into 'oasys'...
remote: Enumerating objects: 1238, done.
remote: Counting objects: 100% (1238/1238), done.
remote: Compressing objects: 100% (971/971), done.
remote: Total 1238 (delta 213), reused 1212 (delta 202), pack-reused 0
Receiving objects: 100% (1238/1238), 39.24 MiB | 58.15 MiB/s, done.
Resolving deltas: 100% (213/213), done.

拷贝 SQL 数据文件至 PG 容器,并且进入容器导入数据

[root@ecs-hce code]# sudo docker cp ./oasys/oasys-pgsql-data.sql postgres:/var/lib/postgresql/data
[root@ecs-hce code]# sudo docker cp ./oasys/oasys-pgsql-table.sql postgres:/var/lib/postgresql/data
[root@ecs-hce code]# docker exec -it postgres bash
root@8743d3c98d38:/# psql -U postgres -d oasys -a -f /var/lib/postgresql/data/oasys-pgsql-table.sql
root@8743d3c98d38:/# psql -U postgres -d oasys -a -f /var/lib/postgresql/data/oasys-pgsql-data.sql

部署 Springboot 项目

下载 JDK 和 HCE 镜像包

[root@ecs-hce code]# mkdir /usr/java && cd /usr/java
[root@ecs-hce java]# wget https://sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com/20220411/jdk-8u321-linux-x64.tar.gz
--2024-02-07 00:37:07--  https://sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com/20220411/jdk-8u321-linux-x64.tar.gz
Resolving sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com (sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com)... 114.115.192.98, 114.115.192.27, 114.115.192.163
Connecting to sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com (sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com)|114.115.192.98|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 146815279 (140M) [application/gzip]
Saving to: 'jdk-8u321-linux-x64.tar.gz'jdk-8u321-linux-x64.tar.gz   100%[===========================================>] 140.01M  1.24MB/s    in 39s2024-02-07 00:37:46 (3.59 MB/s) - 'jdk-8u321-linux-x64.tar.gz' saved [146815279/146815279][root@ecs-hce java]# tar -zxf jdk-8u321-linux-x64.tar.gz
[root@ecs-hce java]# mv jdk1.8.0_321 jdk1.8

获取 Java 程序包

[root@ecs-hce java]#  wget https://sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com/20220412/oasys-0.0.1-SNAPSHOT.jar
--2024-02-07 00:39:11--  https://sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com/20220412/oasys-0.0.1-SNAPSHOT.jar
Resolving sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com (sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com)... 114.115.192.163, 114.115.192.98, 114.115.192.27
Connecting to sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com (sandbox-expriment-files.obs.cn-north-1.myhuaweicloud.com)|114.115.192.163|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 43206230 (41M) [application/java-archive]
Saving to: 'oasys-0.0.1-SNAPSHOT.jar'oasys-0.0.1-SNAPSHOT.jar     100%[===========================================>]  41.20M   184MB/s    in 0.2s2024-02-07 00:39:12 (184 MB/s) - 'oasys-0.0.1-SNAPSHOT.jar' saved [43206230/43206230]

创建 Docker 网络

创建了一个名为 “oa-net” 的 Docker 网络。该命令返回一个长字符串作为网络标识符

[root@ecs-hce java]# docker network create oa-net
8858411315a892cd61bbe8b31411595dd8b013792fd05ab68806f3ca5572c3a7
[root@ecs-hce java]# docker network connect oa-net postgres
[root@ecs-hce java]# docker network connect oa-net redis-sys

将名为 “postgres” 的容器连接到 “oa-net” 网络中。这将使 “postgres” 容器能够与 “oa-net” 网络中的其他容器进行通信。

将名为 “redis-sys” 的容器连接到 “oa-net” 网络中。这样, “redis-sys” 容器也可以与 “oa-net” 网络中的其他容器进行通信。

通过上面的方式连接之后,即可以通过容器名字作为域名直接访问容器对应的服务,在最开始的版本中,docker 会在 hosts 文件主动写入映射关系,从 Docker 1.11 版本开始,Docker 不再将容器的 DNS 映射关系写入宿主机的 /etc/hosts 文件

修改 jar 包配置文件,使用 vim 打开 jar 包,这里主要修改对应的 PGredis 地址

[root@ecs-hce java]# vim oasys-0.0.1-SNAPSHOT.jar
[root@ecs-hce java]# vim oasys-0.0.1-SNAPSHOT.jar
[root@ecs-hce java]#

输入 /application.properties 搜索该文件,并敲回车键2次进入该文件

在这里插入图片描述

修改spring.datasource.url地址为jdbc:postgresql://postgres:5432/oasys,修改spring.redis.host 地址为redis-sys

在这里插入图片描述

### 创建Dockerfile

[root@ecs-hce java]# vim Dockerfile
[root@ecs-hce java]# cat Dockerfile
FROM hce/hce-x86-server:202401
WORKDIR /home
COPY jdk1.8  /home/java
COPY oasys-0.0.1-SNAPSHOT.jar /home
ENV  JAVA_HOME=/home/java
ENV PATH=$JAVA_HOME/bin:$PATH
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tool.jarEXPOSE 8088
CMD [ "java","-jar","oasys-0.0.1-SNAPSHOT.jar"]

输入以下命令,创建docker镜像

[root@ecs-hce java]# docker build -t hce/hce_java_oa:202401 .
Sending build context to Docker daemon  556.2MB
Step 1/9 : FROM hce/hce-x86-server:202401---> 7b8fb730c9f6
Step 2/9 : WORKDIR /home---> Running in 54517151e09c
Removing intermediate container 54517151e09c---> 315f482c8b50
Step 3/9 : COPY jdk1.8  /home/java---> a2fb5d6132d2
Step 4/9 : COPY oasys-0.0.1-SNAPSHOT.jar /home---> 1f96dbcdbcba
Step 5/9 : ENV  JAVA_HOME=/home/java---> Running in 0bc3c8cc82fd
Removing intermediate container 0bc3c8cc82fd---> 778b1bc77f3d
Step 6/9 : ENV PATH=$JAVA_HOME/bin:$PATH---> Running in 559dea2ff7d0
Removing intermediate container 559dea2ff7d0---> 4817d8859121
Step 7/9 : ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tool.jar---> Running in b0ab0b19ad6d
Removing intermediate container b0ab0b19ad6d---> 34250c614a8c
Step 8/9 : EXPOSE 8088---> Running in a927aa883de0
Removing intermediate container a927aa883de0---> 78ca8e81d9af
Step 9/9 : CMD [ "java","-jar","oasys-0.0.1-SNAPSHOT.jar"]---> Running in 7b8757fd2ff4
Removing intermediate container 7b8757fd2ff4---> fbc537581fd1
Successfully built fbc537581fd1
Successfully tagged hce/hce_java_oa:202401

查看镜像

[root@ecs-hce java]# docker images
REPOSITORY           TAG                 IMAGE ID            CREATED             SIZE
hce/hce_java_oa      202401              fbc537581fd1        27 seconds ago      927MB
hce/hce-x86-server   202401              7b8fb730c9f6        21 minutes ago      518MB
redis                latest              a617c1c92774        2 years ago         105MB
postgres             13                  c5ec7353d87d        2 years ago         314MB

启动镜像

[root@ecs-hce java]# docker run -itd --name=oa-java --network=oa-net -p 8088:8088 hce/hce_java_oa:202401
5d8e571ddb52f3951d2c066664b4e10fde1cee8505a95cf64c60824e9c7655c3a

这里需要注意下 --network=oa-net 参数,用于将容器连接到名为 “oa-net” 的网络。

确实启动结果

[root@ecs-hce java]# docker exec -it oa-java /bin/bash
[root@5d8e571ddb52 home]# jps
1 jar
63 Jps
[root@5d8e571ddb52 home]# exit
[root@ecs-hce java]#

浏览器访问oa,输入eip:8088访问,账号soli,密码123456(eip可在华为云控制台获取)

在这里插入图片描述

Nginx容器化部署并配置反向代理

[root@ecs-hce java]# docker images|grep nginx
nginx                latest              298ec0e28760        2 years ago         133MB

这里需要注意下,同样 --network=oa-net 参数,用于将容器连接到名为 “oa-net” 的网络。

[root@ecs-hce java]# docker run -d --network=oa-net --name=nginx  -p 80:80 nginx
e0a0d8fd0a3489740e234cd9b409ffb5cfea436e76fe51e23d6b80fe3163673a
[root@ecs-hce java]# docker ps | grep ng
e0a0d8fd0a34        nginx                       "/docker-entrypoint.…"   About a minute ago   Up 59 seconds       0.0.0.0:80->80/tcp       nginx

添加反向代理配置

[root@ecs-hce java]# docker exec -it nginx /bin/bash
root@e0a0d8fd0a34:/# cd /etc/nginx/conf.d/
root@e0a0d8fd0a34:/etc/nginx/conf.d# apt-get update
root@e0a0d8fd0a34:/etc/nginx/conf.d# apt-get install -y vim
root@e0a0d8fd0a34:/etc/nginx/conf.d# vim default.conf
 location / {#root   /usr/share/nginx/html;#index  index.html index.htm;proxy_pass http://120.46.64.191:8088;}

验证文件是否配置正常, 重启Nginx容器

root@e0a0d8fd0a34:/etc/nginx/conf.d# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
root@e0a0d8fd0a34:/etc/nginx/conf.d# exit
[root@ecs-hce java]# docker restart nginx
nginx
[root@ecs-hce java]#

访问测试

在这里插入图片描述

博文部分内容参考

© 文中涉及参考链接内容版权归原作者所有,如有侵权请告知 😃


https://edu.huaweicloud.com/certificationindex/developer/9bf91efb086a448ab4331a2f53a4d3a1


© 2018-2024 liruilonger@gmail.com, All rights reserved. 保持署名-非商用-相同方式共享(CC BY-NC-SA 4.0)

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

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

相关文章

软件价值7-万花筒

模拟一个万花筒,鼠标点击可以变换图形 import pygame import sys import math import randompygame.init()# 设置窗口大小 WIDTH, HEIGHT 800, 600 CENTER (WIDTH // 2, HEIGHT // 2)# 设置颜色 BLACK (0, 0, 0)# 初始化屏幕 screen pygame.display.set_mode((…

Springboot 整合 Elasticsearch(二):使用HTTP请求来操作ES

📁前情提要:Springboot整合Elasticsearch(一):Linux下安装 Elasticsearch 8.x 目录 一、使用 elasticsearch-head 插件连接 1、下载压缩包 2、在 chrome 浏览器中添加扩展程序 3、修改IP地址,点击连接 …

【GAMES101】Lecture 20 光场

目录 光场(Light Field / Lumigraph) 广场照相机 光场(Light Field / Lumigraph) 我们在三维的世界中从一个观测点出发看到这么一幅二维的画面 如果有这么一副画布可以完美的显示出从观察点看到的画面,那用这幅画布…

Java LinkedList 实现栈和队列

Java LinkedList 实现栈和队列 package com.zhong.collection;import java.util.LinkedList;public class LinkedListDemo {public static void main(String[] args) {// LinkedList 创建一个队列LinkedList<String> queue new LinkedList<>();// 进队System.out…

三、设计模式相关理论总结

一、面向对象编程 1.1 概述 简称Object Oriented Program(OOP)&#xff0c;指以类或对象作为基础组织单元&#xff0c;遵循封装、继承、多态以及抽象等特性&#xff0c;进行编程。其中面向对象不一定遵循封装、继承、封装和多态等特性&#xff0c;只是前人总结的套路规范&…

备战蓝桥杯---动态规划之经典背包问题

看题&#xff1a; 我们令f[i][j]为前i个物品放满容量为j的背包的最大价值。 f[i][j]max(f[i-1][j],f[i-1][j-c[i]]w[i]); 我们开始全副成负无穷。f[0][0]0;最后循环最后一行求max; 负无穷&#xff1a;0xc0c0c0c0;正无穷&#xff1a;0x3f3f3f3f 下面是v12,n6的图示&#xff…

TCP的连接和断开详解

目录 1.TCP基础知识 1.1.TCP 头格式 1.2.TCP协议介绍 1.3.UDP协议介绍 1.4.TCP 和 UDP 区别 1.5.TCP 和 UDP 应用场景 1.6.计算机网络相关术语&#xff08;缩写&#xff09; 2.TCP 连接建立&#xff1a;三次握手 2.1.TCP 三次握手过程 2.2.三次握手原理 2.3.异常分析…

我主编的电子技术实验手册(02)——仪表与电源

本专栏是笔者主编教材&#xff08;图0所示&#xff09;的电子版&#xff0c;依托简易的元器件和仪表安排了30多个实验&#xff0c;主要面向经费不太充足的中高职院校。每个实验都安排了必不可少的【预习知识】&#xff0c;精心设计的【实验步骤】&#xff0c;全面丰富的【思考习…

机器学习系列——(二十)密度聚类

引言 在机器学习的无监督学习领域&#xff0c;聚类算法是一种关键的技术&#xff0c;用于发现数据集中的内在结构和模式。与传统的基于距离的聚类方法&#xff08;如K-Means&#xff09;不同&#xff0c;密度聚类关注于数据分布的密度&#xff0c;旨在识别被低密度区域分隔的高…

力扣刷题之旅:进阶篇(六)—— 图论与最短路径问题

力扣&#xff08;LeetCode&#xff09;是一个在线编程平台&#xff0c;主要用于帮助程序员提升算法和数据结构方面的能力。以下是一些力扣上的入门题目&#xff0c;以及它们的解题代码。 --点击进入刷题地址 引言 在算法的广阔天地中&#xff0c;图论是一个非常重要的领域。…

林浩然与杨凌芸的Java异常处理大冒险

林浩然与杨凌芸的Java异常处理大冒险 Lin Haoran and Yang Lingyun’s Java Exception Handling Adventure 在一个阳光明媚的午后&#xff0c;编程世界的英雄——林浩然和杨凌芸坐在Java王国的咖啡馆里&#xff0c;一边品尝着香醇的代码咖啡&#xff0c;一边探讨着他们的最新挑…

Excel——高级筛选匹配条件提取数据

一、筛选多条件 Q&#xff1a;筛选多个条件&#xff0c;并将筛选出的内容复制到其他区域 点击任意一个单元格 点击【数据】——【筛选】——【高级筛选】 选择【将筛选结果复制到其他位置】——在【列表区域】 鼠标选择对应的区域位置&#xff0c;条件区域一定要单独写出来&a…

ChatGPT学习第一周

&#x1f4d6; 学习目标 掌握ChatGPT基础知识 理解ChatGPT的基本功能和工作原理。认识到ChatGPT在日常生活和业务中的潜在应用。 了解AI和机器学习的基本概念 获取人工智能&#xff08;AI&#xff09;和机器学习&#xff08;ML&#xff09;的初步了解。理解这些技术是如何支撑…

Flink从入门到实践(一):Flink入门、Flink部署

文章目录 系列文章索引一、快速上手1、导包2、求词频demo&#xff08;1&#xff09;要读取的数据&#xff08;2&#xff09;demo1&#xff1a;批处理&#xff08;离线处理&#xff09;&#xff08;3&#xff09;demo2 - lambda优化&#xff1a;批处理&#xff08;离线处理&…

【机器学习】数据清洗之识别缺失点

&#x1f388;个人主页&#xff1a;甜美的江 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;机器学习 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步…

[神奇代码岛】皮肤功能使用

前言 最近有很多人在制作地图的时候&#xff0c;因该会用到皮肤的功能&#xff0c;但是皮肤操作只知道UI操作&#xff0c;但缺点是&#xff0c;只能设置地图默认皮肤&#xff0c;根本都做不到想要的什么皮肤购买功能&#xff0c;自主穿戴功能&#xff0c;而API官方又放在非常隐…

老胡的周刊(第128期)

老胡的信息周刊[1]&#xff0c;记录这周我看到的有价值的信息&#xff0c;主要针对计算机领域&#xff0c;内容主题极大程度被我个人喜好主导。这个项目核心目的在于记录让自己有印象的信息做一个留存以及共享。 &#x1f3af; 项目 coze-discord-proxy[2] 代理 Discord-Bot 对…

微服务OAuth 2.1扩展额外信息到JWT并解析(Spring Security 6)

文章目录 一、简介二、重写UserDetailsService三、Controller解析JWT获取用户信息四、后记 一、简介 VersionJava17SpringCloud2023.0.0SpringBoot3.2.1Spring Authorization Server1.2.1Spring Security6.2.1mysql8.2.0 Spring Authorization Server 使用JWT时&#xff0c;前…

PbootCMS采集插件使用教程

这篇Pboot采集教程教你使用PbootCMS采集插件&#xff0c;自动批量采集网页文章数据&#xff0c;并发布到PbootCMS系统&#xff0c;快速丰富网站的内容。 1. 下载并安装PbootCMS采集插件 1-1&#xff09;PbootCMS采集插件免费下载&#xff1a;Pboot采集插件-PbootCMS发布模块下…

【Docker】私有仓库

目录 1.搭建 2. 上传镜像 3.拉取镜像 1.搭建 1.拉取私有仓库的镜像 docker pull registry 2.创建私有仓库容器 docker run -id --nameregistry -p 5000:5000 registry 3.打开浏览器,输入地址&#xff08;http:私有仓库服务器ip:5000/v2/_catalog&#xff09; 出现如图表示私…