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

本文涉及的产品
RDS Agent(兼容OpenClaw),2核4GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day2 全网最快最全(下)

黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day2 全网最快最全(上):https://developer.aliyun.com/article/1548622


Dockerfile

  • 构建镜像的方式

  • 按照视频操作后变成docker
docker load -i jdk.tar
  • 构建docker镜像
docker build -t docker-demo .

docker run -d --name dd -p 8080:8080 docker-demo

Docker网络知识

  • 这里的网络ip是分配的 因此会出现每次服务启动ip都有变化的情况
  • 虚拟网桥(virtual bridge)是一个虚拟网络设备,它的作用类似于物理交换机,用于在不同的网络接口之间进行转发数据包。在 Docker 中,虚拟网桥主要用于连接宿主机和容器,使它们能够相互通信并与外部网络进行通信。

  • 不是查看当前网桥,是列出docker当前存在的所有网络

Docker操作
  • 这里内容比较复杂 建议看视频进行操作
ip addr

  • 使用docker inspect dd 来查看容器

docker exec -it dd bash

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

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

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

Docker部署项目后端

注意事项

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

项目打包前的介绍

在Docker中

使用以下命令进行构建

docker build -t hmall .

这里我的网络创建的是 Qiuner

docker build -t hmall .
docker run -d --name hm -p 8080:8080 --network heima hmall
 
 docker run -d --name hm -p 8080:8080 --network Qiuner hmall
  • 这里的网络要填写你自己创建的
docker logs -f hm
  • 查看

出现以下页面

  • 这里要注意 你的mysql docker容器也是要跑起来的 不然就是会报错

  • 如果出现这个情况 请注意你要检查路径名是否写对

Docker部署项目前端

  • 这里部署前端的时候注意要修改Nginx.conf文件
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;
        }
    }
}
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://ucc.alicdn.com/images/user-upload-01/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 -

添加 Docker 的 apt 仓库:

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

更新 apt 软件包索引:

sudo apt update

删除之前的

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

安装 Docker:

sudo apt install docker-ce

验证 Docker 是否安装成功:

sudo docker --version

## 使用
1. **启动 Docker 服务:**
• 1
• 2
• 3
• 4
• 5

sudo systemctl start docker

1. **停止 Docker 服务:**

sudo systemctl stop docker

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

sudo systemctl restart docker

1. **设置 Docker 开机自启:**

sudo systemctl enable docker

1. **检查 Docker 是否启动成功:**

sudo docker ps

![image-20240424222747377](https://ucc.alicdn.com/images/user-upload-01/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://ucc.alicdn.com/images/user-upload-01/img_convert/0bc287150d5a6a38a36fc34a539119f2.png)

docker run -d

–name mysql

-p 3306:3306

-e TZ=Asia/Shanghai

-e MYSQL_ROOT_PASSWORD=123

mysql

##  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://ucc.alicdn.com/images/user-upload-01/img_convert/fb244bc2ccd9ea84c04db0dfaf15ba6b.png)
+ 这个错误提示表明当前用户缺少执行 Docker 命令的权限
#### 方法一 添加当前用户到 docker 用户组:将当前用户添加到 docker 用户组中,以便其可以直接运行 Docker 命令,而不需要使用 sudo 权限。

sudo usermod -aG docker $USER

然后注销并重新登录以使更改生效。
#### 方法二 使用 sudo 权限:在每个 Docker 命令前面加上 sudo,以提升权限。

sudo docker run -d

–name mysql

-p 3306:3306

-e TZ=Asia/Shanghai

-e MYSQL_ROOT_PASSWORD=123

mysql

## 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

然后注销并重新登录以使更改生效。
#### 方法二 使用 sudo 权限:在每个 Docker 命令前面加上 sudo,以提升权限。

sudo docker run -d

–name mysql

-p 3306:3306

-e TZ=Asia/Shanghai

-e MYSQL_ROOT_PASSWORD=123

mysql

## 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博
相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
7月前
|
算法 Java 微服务
【SpringCloud(1)】初识微服务架构:创建一个简单的微服务;java与Spring与微服务;初入RestTemplate
微服务架构是What?? 微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。 每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。 每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
655 126
|
7月前
|
负载均衡 算法 Java
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
1. 什么是服务治理? SpringCloud封装了Netfix开发的Eureka模块来实现服务治理 在传统pc的远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册
420 0
|
9月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
1320 3
|
人工智能 安全 Java
智慧工地源码,Java语言开发,微服务架构,支持分布式和集群部署,多端覆盖
智慧工地是“互联网+建筑工地”的创新模式,基于物联网、移动互联网、BIM、大数据、人工智能等技术,实现对施工现场人员、设备、材料、安全等环节的智能化管理。其解决方案涵盖数据大屏、移动APP和PC管理端,采用高性能Java微服务架构,支持分布式与集群部署,结合Redis、消息队列等技术确保系统稳定高效。通过大数据驱动决策、物联网实时监测预警及AI智能视频监控,消除数据孤岛,提升项目可控性与安全性。智慧工地提供专家级远程管理服务,助力施工质量和安全管理升级,同时依托可扩展平台、多端应用和丰富设备接口,满足多样化需求,推动建筑行业数字化转型。
412 5
|
7月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
8月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
485 1
|
8月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
947 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
8月前
|
Kubernetes Java 微服务
Spring Cloud 微服务架构技术解析与实践指南
本文档全面介绍 Spring Cloud 微服务架构的核心组件、设计理念和实现方案。作为构建分布式系统的综合工具箱,Spring Cloud 为微服务架构提供了服务发现、配置管理、负载均衡、熔断器等关键功能的标准化实现。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
678 0
|
10月前
|
IDE Java API
Java 17 新特性与微服务开发的实操指南
本内容涵盖Java 11至Java 17最新特性实战,包括var关键字、字符串增强、模块化系统、Stream API、异步编程、密封类等,并提供图书管理系统实战项目,帮助开发者掌握现代Java开发技巧与工具。
599 1