前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day2 全网最快最全

黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day2 全网最快最全

作者头像
Qiuner
发布2024-07-19 16:03:12
80
发布2024-07-19 16:03:12
举报
文章被收录于专栏:杂烩

2024最新SpringCloud微服务开发与实战,java黑马商城项目微服务实战开发(涵盖MybatisPlus、Docker、MQ、ES、Redis高级等)

Day 2

你好,我是Qiuner. 为记录自己编程学习过程和帮助别人少走弯路而写博客 这是我的 github https://github.com/Qiuner ⭐️ ​ gitee https://gitee.com/Qiuner 🌹 如果本篇文章帮到了你 不妨点个吧~ 我会很高兴的 😄 (^ ~ ^) 想看更多 那就点个关注吧 我会尽力带来有趣的内容 😎

因为centOS7在2024年6月停服,因此我选择使用Ubunt来完成安装使用Docker

  • 博主发现自己经过多种方式后都没有成功将乌班图连接上ssh工具,加上最近很忙很忙很忙在加上已学过微服务,于是放弃了使用乌班图,而是用官方的linux。不然肯定狠狠调研下,写一篇博客
  • 有小伙伴想用乌班图来做可以在下面留言,我会看情况再用乌班图过一遍

CentOS 7 版本

容器与镜像

image-20240504143511404
image-20240504143511404
命令解读
代码语言:javascript
复制
docker run -d \
--name mysql \
-p 3306:3306 \
-e TZ=Asia/Shanghai \
-e MYSQL_ROOT_PASSWORD=123 \
mysql
image-20240504144012615
image-20240504144012615
image-20240504144050520
image-20240504144050520
image-20240504144114236
image-20240504144114236

Docker常用命令

image-20240504144630302
image-20240504144630302
  • 容易拥有自己的ip内存什么的 每次使用docker run是再重复创建容器
其余常见命令
  1. 容器生命周期管理
    • docker run: 运行一个新容器。
    • docker start: 启动一个停止的容器。
    • docker stop: 停止一个运行中的容器。
    • docker restart: 重启一个运行中的容器。
    • docker pause: 暂停容器中的所有进程。
    • docker unpause: 恢复暂停的容器中的所有进程。
    • docker kill: 强制停止一个运行中的容器。
    • docker rm: 删除一个或多个容器。
    • docker ps: 列出正在运行的容器。
    • docker ps -a: 列出所有容器,包括停止的容器。
  2. 镜像管理
    • docker images: 列出本地的镜像。
    • docker pull: 从仓库中拉取一个镜像。
    • docker build: 根据 Dockerfile 构建一个镜像。
    • docker tag: 给镜像打标签。
    • docker rmi: 删除一个或多个镜像。
  3. 容器操作
    • docker exec: 在运行中的容器中执行命令。
    • docker attach: 进入一个正在运行的容器。
    • docker cp: 在容器和本地文件系统之间复制文件或目录。
    • docker inspect: 显示容器的详细信息。
  4. 网络
    • docker network ls: 列出 Docker 网络。
    • docker network create: 创建一个 Docker 网络。
    • docker network connect: 将容器连接到网络。
    • docker network disconnect: 将容器从网络断开连接。
  5. 数据卷
    • docker volume ls: 列出 Docker 数据卷。
    • docker volume create: 创建一个 Docker 数据卷。
    • docker volume rm: 删除一个或多个 Docker 数据卷。
  6. Docker Compose(用于定义和运行多容器的应用):
    • docker-compose up: 构建并启动应用的所有服务。
    • docker-compose down: 停止并移除应用的所有服务。
    • docker-compose build: 重新构建服务。
    • docker-compose logs: 查看服务的日志。

Docker小案例

image-20240504160126861
image-20240504160126861
代码语言:javascript
复制
docker pull nginx
  • 这里介绍了开发很重要的东西 找文档。
  • 前后端开发太庞大了,需要有不懂就查的能力 也不知道面试面那些有啥用🤧 招的是能解决问题的人 而不是八股
image-20240511222139277
image-20240511222139277
  • 这一步代码只是创建了容器,还需要运行

Docker基础命令实践

起别名
image-20240516205730798
image-20240516205730798
代码语言:javascript
复制
vi ~/.bashrc
代码语言:javascript
复制
alias dps='docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"'
  • docker ps 列出当前运行的 Docker 容器。
  • --format 选项用于自定义输出格式。
  • table 指定输出应为表格格式。
  • {{.ID}}{{.Image}}{{.Ports}}{{.Status}}{{.Names}} 是 Docker 容器的各个属性。
代码语言:javascript
复制
alias dis='docker images'
  • 然后点击ESC键 输入 :wq 来退出
  • 再输入 source ~/.bashrc
image-20240516213235887
image-20240516213235887
  • 如此 成功修改命令别名
数据卷挂载
image-20240516215527055
image-20240516215527055
代码语言:javascript
复制
 cd /usr/share/nginx/html
/usr/share/nginx/html# ll
  • 因为容器为了精简,只保存最小化运行的内容,没有vi 因此不能通过vi来编辑index.html
image-20240516220033227
image-20240516220033227
  • 就相当于Vue中的双向绑定一样,在绑定的一边修改也会影响到另一边
  • 创建Nginx文件的时候,会在docker中也创建一个目录来存放这个容器的相应内容
image-20240516220309350
image-20240516220309350
  • 使用 docker volume --help
image-20240516220441837
image-20240516220441837
代码语言:javascript
复制
先移除已有的,因为只能在创建这个容器时实现数据数据绑定
docker rm -f nginx

再次创建,这样创建能够实现将数据绑定
docker run -d --name nginx -p 80:80 -v html:/usr/share/nginx/html nginx
image-20240516221135631
image-20240516221135631
代码语言:javascript
复制
docker volume ls 

docker volume inspect html

cd /var/lib/docker/volumes/html/_data
image-20240516223914233
image-20240516223914233
为什么你能在主浏览器访问虚拟机配置的Nginx?
image-20240517090005826
image-20240517090005826
  • 原因是虚拟机与主机处于同一网络中,并且 Docker 容器的端口映射允许虚拟机的特定端口流量被转发到容器内的 Nginx 服务。确保虚拟机的 IP 地址和 Docker 端口映射配置正确,这样就可以成功访问容器内的服务。
使用MobaXterm来进行编辑
image-20240517090726572
image-20240517090726572
  • 就可以在这里直接修改
  • 也可以将外部资源直接拖进来
image-20240517090858924
image-20240517090858924
本地目录挂载
image-20240517092116228
image-20240517092116228
代码语言:javascript
复制
docker run -d \
--name mysql \
-p 3306:3306 \
-e TZ=Asia/Shanghai \
-e MYSQL_ROOT_PASSWORD=123 \
-v /root/mysql/data:/var/lib/mysql \
-v /root/mysql/init:/docker-entrypoint-initdb.d \
-v /root/mysql/conf:/etc/mysql/conf.d \
mysql
  • 在执行这段命令之前需要先进行创建文件夹
  • 使用cd ~ 切换目录 然后使用mkdir 创建目录
image-20240517092906976
image-20240517092906976
image-20240517093807962
image-20240517093807962
制作自定义镜像
  • 镜像和容器的关系就是类和实例
image-20240517094512070
image-20240517094512070
  • JRE,全称 Java Runtime Environment(Java 运行时环境),是用于运行 Java 应用程序的一个软件平台。它包含了 Java 虚拟机(JVM)、Java 类库和其他必要的组件,允许用户在其计算机上运行用 Java 编写的程序。JRE 是 Java 开发工具包(JDK)的一个子集,专注于运行 Java 应用程序,而不包括编译和开发工具。

**第一步 ** 准备Linux运行环境 这里因为不知道java运行要哪些东西,因此把乌班图全部拿过来了

image-20240517094708482
image-20240517094708482

第二步 安装JRE

image-20240517094739813
image-20240517094739813

第三步

image-20240517094807675
image-20240517094807675

第四步 编写脚本并启动

image-20240517094859910
image-20240517094859910

大功搞成

image-20240517094921271
image-20240517094921271
镜像在docker中的结构
image-20240517095611828
image-20240517095611828
  • 这样分层的好处是 制作完乌班图所需要依赖镜像后,可以将其上传,然后下次要制作其他时,直接在这个镜像基础上开始制作
  • 而且镜像也会有差不多的地方,因此可以减少所用空间
image-20240517095537033
image-20240517095537033
Dockerfile
image-20240517095847342
image-20240517095847342
  • 构建镜像的方式
image-20240517100101448
image-20240517100101448
  • 按照视频操作后变成docker
代码语言:javascript
复制
docker load -i jdk.tar
  • 构建docker镜像
代码语言:javascript
复制
docker build -t docker-demo .
image-20240517101123313
image-20240517101123313
代码语言:javascript
复制
docker run -d --name dd -p 8080:8080 docker-demo
image-20240517102742631
image-20240517102742631
image-20240517102913948
image-20240517102913948
Docker网络知识
image-20240517103204605
image-20240517103204605
  • 这里的网络ip是分配的 因此会出现每次服务启动ip都有变化的情况
  • 虚拟网桥(virtual bridge)是一个虚拟网络设备,它的作用类似于物理交换机,用于在不同的网络接口之间进行转发数据包。在 Docker 中,虚拟网桥主要用于连接宿主机和容器,使它们能够相互通信并与外部网络进行通信。
image-20240517110638922
image-20240517110638922
  • 不是查看当前网桥,是列出docker当前存在的所有网络
image-20240517103349926
image-20240517103349926
Docker操作
  • 这里内容比较复杂 建议看视频进行操作
代码语言:javascript
复制
ip addr
image-20240517111446058
image-20240517111446058
image-20240517111819695
image-20240517111819695
  • 使用docker inspect dd 来查看容器
image-20240517112041565
image-20240517112041565

docker exec -it dd bash

命令解析
  1. docker exec:
    • docker exec 是用于在运行中的容器内执行命令的 Docker 命令。
  2. -it:
    • -i(interactive): 选项使得容器保持标准输入(STDIN)打开,从而可以交互式地输入命令。
    • -t(tty): 选项分配一个伪终端,提供一个终端接口。这两个选项通常一起使用,允许用户在容器中进行交互式的命令行操作。
  3. dd:
    • dd 是目标容器的名称或 ID。这个名称或 ID 标识了你希望进入的运行中的容器。
  4. bash:
    • bash 是你希望在目标容器中运行的命令。在这里,它启动一个 Bash shell,这样你就可以在容器内进行命令行操作。
整体作用

综上所述,docker exec -it dd bash 命令的作用是在名称为 dd 的运行中的 Docker 容器中启动一个交互式 Bash shell。执行该命令后,你将进入容器的命令行环境,能够像在普通的 Linux 终端中一样输入和执行命令。

image-20240517112350588
image-20240517112350588
image-20240517112454792
image-20240517112454792
  • 现在就能实现直接ping 容器名
  • 两个容器加入了一个网络 就能通过容器名互相访问,只有在自定义网络才能实现

Docker部署项目后端

注意事项
image-20240517205940090
image-20240517205940090
  • 在这里注意 需要修改成你的相应配置
  • 只要你是按照视频走的 那那么docker中的mysql密码就是123 不需要改
image-20240517171838037
image-20240517171838037

项目打包前的介绍

image-20240517220053512
image-20240517220053512
image-20240517203421360
image-20240517203421360

在Docker中

使用以下命令进行构建

代码语言:javascript
复制
docker build -t hmall .
image-20240517220721616
image-20240517220721616

这里我的网络创建的是 Qiuner

代码语言:javascript
复制
docker build -t hmall .
代码语言:javascript
复制
 docker run -d --name hm -p 8080:8080 --network heima hmall
 
 docker run -d --name hm -p 8080:8080 --network Qiuner hmall
  • 这里的网络要填写你自己创建的
代码语言:javascript
复制
docker logs -f hm
  • 查看
出现以下页面
image-20240517223208750
image-20240517223208750
  • 这里要注意 你的mysql docker容器也是要跑起来的 不然就是会报错
image-20240517223516355
image-20240517223516355
  • 如果出现这个情况 请注意你要检查路径名是否写对

Docker部署项目前端

  • 这里部署前端的时候注意要修改Nginx.conf文件
代码语言:javascript
复制
worker_processes  1;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/json;

    sendfile        on;
    
    keepalive_timeout  65;

    server {
        listen       18080;
        # 指定前端项目所在的位置
        location / {
            root /usr/share/nginx/html/hmall-portal;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        location /api {
            rewrite /api/(.*)  /$1 break;
            proxy_pass http://hm:8080;
        }
    }
    server {
        listen       18081;
        # 指定前端项目所在的位置
        location / {
            root /usr/share/nginx/html/hmall-admin;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        location /api {
            rewrite /api/(.*)  /$1 break;
            proxy_pass http://hm:8080;
        }
    }
}
代码语言:javascript
复制
docker run --name nginx \
  -p 18080:18080 \
  -p 18081:18081 \
  -v /root/nginx/html:/usr/share/nginx/html \
  -v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \
  --network heima \
  nginx


```## Docker部署项目小结

+ 本次使用Nginx来部署前段资源,使用java来构建后端



![image-20240519160901754](https://cdn.jsdelivr.net/gh/Qiuner/Drawing-bed/imgs/202405/202405191609842.png)





+ 构建前端所需要
+ ![image-20240519160941926](https://cdn.jsdelivr.net/gh/Qiuner/Drawing-bed/imgs/202405/202405191609978.png)



+ 这里的前端文件

## 项目部署 DockerCompose



![image-20240519161423354](https://cdn.jsdelivr.net/gh/Qiuner/Drawing-bed/imgs/202405/202405191614436.png)





![image-20240519162025075](https://cdn.jsdelivr.net/gh/Qiuner/Drawing-bed/imgs/202405/202405191620166.png)


![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/31136525aa98473d92c6f9583470fbae.png#pic_center)








# 乌班图版本

## Docker安装

> Docker 的 yum 库是指 Docker 官方提供的用于在 CentOS、Fedora、Red Hat Enterprise Linux(RHEL)等基于 RPM 包管理的系统上安装 Docker 的软件仓库。
>
> 这个 yum 库包含了 Docker 的软件包以及相关的依赖项,使得在这些系统上安装 Docker 变得更加简单方便。通过将 Docker 的 yum 库添加到系统的软件源列表中,用户可以使用 yum 包管理器来轻松地安装、更新和管理 Docker 软件。
>
> 通过 yum 安装 Docker,用户可以方便地从官方源获取 Docker 的最新版本,并获得官方支持和更新。这样就可以确保系统上安装的 Docker 版本是最新的,并且能够及时获取到安全更新和 bug 修复。

+ 在乌班图中,不需要这个


在 Ubuntu 中,Docker 使用的是 apt 包管理器,而不是 yum。因此,你不会使用 Docker 的 yum 库来安装 Docker,而是使用 Docker 的官方 apt 库。

要在 Ubuntu 上安装 Docker,你可以按照以下步骤操作:

添加 Docker 的官方 GPG 密钥:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

代码语言:javascript
复制
添加 Docker 的 apt 仓库:

sudo add-apt-repository “deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable”

代码语言:javascript
复制
更新 apt 软件包索引:

sudo apt update

代码语言:javascript
复制
删除之前的

sudo apt-get remove docker docker-engine docker.io containerd runc

代码语言:javascript
复制
安装 Docker:

sudo apt install docker-ce

代码语言:javascript
复制
验证 Docker 是否安装成功:

sudo docker --version

代码语言:javascript
复制
## 使用

1. **启动 Docker 服务:**

sudo systemctl start docker

代码语言:javascript
复制
1. **停止 Docker 服务:**

sudo systemctl stop docker

代码语言:javascript
复制
1. **重启 Docker 服务:**

sudo systemctl restart docker

代码语言:javascript
复制
1. **设置 Docker 开机自启:**

sudo systemctl enable docker

代码语言:javascript
复制
1. **检查 Docker 是否启动成功:**

sudo docker ps

代码语言:javascript
复制
![image-20240424222747377](https://img-blog.csdnimg.cn/img_convert/906bffd73118e642a4362fd76fc0ed31.png)

+ 这表示docker正在运行但是没有容器

## 配置阿里云

+ 然后就是跟着官方文档操作了
+ [‍‬‬‌⁡⁤‌⁡⁣⁢‌⁢‬‬⁢⁡‍‍‍⁡⁣‍⁡‬⁣⁡‬⁢⁣⁢⁢⁢‬‬⁣安装Docker - 飞书云文档 (feishu.cn)](https://b11et3un53m.feishu.cn/wiki/Rfocw7ctXij2RBkShcucLZbrn2d)

ARC(Artifact Repository Container)是一个容器镜像仓库服务。它允许用户存储、管理和共享容器镜像。ARC 提供了一个集中式的存储库,用于存储各种容器镜像,用户可以通过网络访问这些镜像。

ARC 具有以下主要功能和特点:

1. **镜像存储和管理:** ARC 允许用户将容器镜像上传到存储库中,并对这些镜像进行管理,包括上传、下载、删除、编辑标签等操作。
2. **版本控制:** ARC 支持对容器镜像进行版本控制,用户可以上传多个版本的镜像,并随时切换到特定版本。
3. **权限管理:** ARC 允许管理员设置访问权限,以控制用户对镜像的访问权限,确保镜像的安全性和保密性。
4. **镜像共享:** 用户可以将自己的镜像分享给其他用户或团队,以便于合作和开发。
5. **私有和公共存储库:** ARC 支持私有存储库和公共存储库。用户可以选择将镜像保存在私有存储库中,以保护其知识产权,也可以选择将镜像发布到公共存储库中,与其他人共享。

![image-20240424224433771](https://img-blog.csdnimg.cn/img_convert/0bc287150d5a6a38a36fc34a539119f2.png)

docker run -d –name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123 mysql

代码语言:javascript
复制
##  docker: permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Head "http://%2Fvar%2Frun%2Fdocker.sock/_ping": dial unix /var/run/docker.sock: connect: permission denied.
See 'docker run --help'.

![image-20240424225017419](https://img-blog.csdnimg.cn/img_convert/fb244bc2ccd9ea84c04db0dfaf15ba6b.png)

+ 这个错误提示表明当前用户缺少执行 Docker 命令的权限

#### 方法一 添加当前用户到 docker 用户组:将当前用户添加到 docker 用户组中,以便其可以直接运行 Docker 命令,而不需要使用 sudo 权限。

sudo usermod -aG docker $USER

代码语言:javascript
复制
然后注销并重新登录以使更改生效。

#### 方法二 使用 sudo 权限:在每个 Docker 命令前面加上 sudo,以提升权限。

sudo docker run -d –name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123 mysql

代码语言:javascript
复制
## MobaXterm无法连接无法与主机连接

+ 先看这个视频

[桥接模式下虚拟机ping不通主机?主机却可以ping通虚拟机,不妨看看这个视频_哔哩哔哩_bilibili](https://www.bilibili.com/video/BV14Y41197pB/?spm_id_from=333.337.search-card.all.click&vd_source=077127c579b82c23164b07dbc24cd570)

[超详细虚拟机与主机网络连接以及互Ping不通问题的解决_桥接模式windows2008虚拟机ping主机-CSDN博客](https://blog.csdn.net/weixin_41538012/article/details/115325944)
用户缺少执行 Docker 命令的权限

#### 方法一 添加当前用户到 docker 用户组:将当前用户添加到 docker 用户组中,以便其可以直接运行 Docker 命令,而不需要使用 sudo 权限。

sudo usermod -aG docker $USER

代码语言:javascript
复制
然后注销并重新登录以使更改生效。

#### 方法二 使用 sudo 权限:在每个 Docker 命令前面加上 sudo,以提升权限。

sudo docker run -d –name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123 mysql

代码语言:javascript
复制
## MobaXterm无法连接无法与主机连接

+ 先看这个视频

[桥接模式下虚拟机ping不通主机?主机却可以ping通虚拟机,不妨看看这个视频_哔哩哔哩_bilibili](https://www.bilibili.com/video/BV14Y41197pB/?spm_id_from=333.337.search-card.all.click&vd_source=077127c579b82c23164b07dbc24cd570)

[超详细虚拟机与主机网络连接以及互Ping不通问题的解决_桥接模式windows2008虚拟机ping主机-CSDN博客](https://blog.csdn.net/weixin_41538012/article/details/115325944)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-06-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2024最新SpringCloud微服务开发与实战,java黑马商城项目微服务实战开发(涵盖MybatisPlus、Docker、MQ、ES、Redis高级等)
  • Day 2
  • CentOS 7 版本
    • 容器与镜像
      • 命令解读
    • Docker常用命令
      • 其余常见命令
    • Docker小案例
      • Docker基础命令实践
        • 起别名
        • 数据卷挂载
        • 为什么你能在主浏览器访问虚拟机配置的Nginx?
        • 使用MobaXterm来进行编辑
        • 本地目录挂载
        • 制作自定义镜像
        • 镜像在docker中的结构
        • Dockerfile
        • Docker网络知识
      • Docker部署项目后端
        • 注意事项
        • 出现以下页面
      • Docker部署项目前端
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档