SpringCloud Alibaba微服务实战十五 - SpringCloud 容器化部署

简介: SpringCloud Alibaba微服务实战十五 - SpringCloud 容器化部署

SpringCloud Alibaba 系列文章已经写了 16 篇了,基本框架大体完成,业务相关的逻辑还需要根据项目本身的业务进行梳理改造。今天将是本系列的最后一篇 - SpringCloud 容器化部署(理论上最后一篇,不排除后面会对相关组件进行升级)

看在写了这么多的份上是不是应该点个在看呢?


开启 Docker 远程访问


由于我是在 windows 上进行开发没有安装 docker,所以需要找一台安装好 docker 的服务器并开启远程访问。使用 mac 的同学请忽略。

  • 打开 docker 配置文件
    vi /lib/systemd/system/docker.service
  • 开放 2376 端口
    找到ExecStart=/usr/bin/dockerd所在行,在后面追加-H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock,修改完成的效果如下:
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock
  • 重启 docker 服务
systemctl daemon-reload
systemctl restart docker.service

docker-maven-plugin 构建 docker 镜像

在开始打包之前一定要先在bomcommon模块执行mvn clean install命令,否则打包不成功。

看过本系列文章的人一定也知道 docker 和 docker-compose 的相关指令了,这里就不再说明。

  • 在需要构建组件的模块引入 docker-maven-plugin 插件
<plugin>
  <groupId>com.spotify</groupId>
  <artifactId>docker-maven-plugin</artifactId>
  <version>1.2.2</version>
  <configuration>
    <imageName>${project.artifactId}</imageName>
    <imageTags>
      <imageTag>latest</imageTag>
    </imageTags>
    <!--指定Dockerfile路径-->
    <dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
    <dockerHost>http://xxx.xx.xx.xx:2376</dockerHost>
    <resources>
      <resource>
        <targetPath>/</targetPath>
        <!--${project.basedir}/target-->
        <directory>${project.build.directory}</directory>
        <!--${project.artifactId}-${project.version}-->
        <include>${project.build.finalName}.jar</include>
      </resource>
    </resources>
  </configuration>
</plugin>

这里端口与前面开放的端口保持一致。

  • 在模块的 src/main/docker 目录下建立 Dockerfile 文件
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD cloud-gateway-1.0.0.jar app.jar
RUN sh -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

每个模块需要自行修改 ADD 指令

  • 在模块下执行如下命令构建 docker 镜像
mvn clean package docker:build -DskipTests

执行效果如下:

  • 构建完成后登陆服务器查看 docker 镜像docker images
  • 启动镜像,带上--rm 指令便于删除容器。
docker run -d -p 5000:5000  --rm auth-service
docker run -d -p 8010:8010  --rm account-service
docker run -d -p 8090:8090  --rm cloud-gateway
  • 查看是否正常启动
  • 使用 postman 进行测试

服务正常响应!


使用 docker-compose 启动


  • 创建 cloud-service.yml 文件编排镜像
version:"3"
services:
  auth-service:
    container_name:auth-service
    image:auth-service:latest
    ports:
      -"5000:5000"
    restart:always
  cloud-gateway:
    container_name:cloud-gateway
    image:cloud-gateway:latest
    ports:
      -"8090:8090"
    restart:always
  account-service:
    container_name:account-service
    image:account-service:latest
    ports:
      -"8010:8010"
    restart:always
  • 将文件上传至服务器,使用如下脚本启动服务
    docker-compose -f cloud-service up
  • 使用 postman 进行测试服务正常响应!

SpringCloud 的容器化部署还是比较简单的,你还不来试一下?


好了,各位朋友们,本期的内容到此就全部结束啦,能看到这里的同学都是优秀的同学,下一个升职加薪的就是你了!

目录
相关文章
|
1月前
|
算法 Java 微服务
【SpringCloud(1)】初识微服务架构:创建一个简单的微服务;java与Spring与微服务;初入RestTemplate
微服务架构是What?? 微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。 每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。 每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
435 126
|
1月前
|
负载均衡 算法 Java
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
1. 什么是服务治理? SpringCloud封装了Netfix开发的Eureka模块来实现服务治理 在传统pc的远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册
230 0
|
1月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
2月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
205 1
|
2月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
408 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
3月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
785 108
|
4月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
413 57

热门文章

最新文章

下一篇
oss云网关配置