Docker Swarm运行Spring Cloud应用(一):部署

简介: Docker Swarm Mode集群和传统的Swarm集群最大的差异是利用引擎内置的集群管理能力,取消了对KVStore依赖,简化了Docker集群的创建和管理。随着商业化产品的步伐加快,Docker企业版也已经支持了Swarm Mode。

Docker Swarm Mode集群和传统的Swarm集群最大的差异是利用引擎内置的集群管理能力,取消了对KV Store依赖,简化了Docker集群的创建和管理。随着商业化产品的步伐加快,Docker企业版也已经支持了Swarm Mode。今天,我们就和大家一起看一下如何利用这些最新特性在Swarm Mode集群中部署Spring Cloud应用。

极简版Spring Cloud应用

云应用(Cloud Native Application)的一个重要特点是动态。运行在云上的应用,其实例可能随时生灭,随着负载的变化,数目也会增减。为适应这个变化,应用需要借助于服务发现来相互定位。开源的微服务框架Spring Cloud中封装了Netflix的服务发现Eureka,一个极简的Spring Cloud应用可以是如下结构:

springcloud_tiny

Web应用在访问时会调用BookService,宣布两个服务都正常。

curl http://web:8080/
Web+BOOK Service Available.

Web对BookService服务调用参见ApplicationController.java代码。

    @RequestMapping("/")
    public String getIndex(){
        String message = restTemplate.getForObject("http://bookservice/",String.class);
        return "Web+" + message;
    }

可以看到restTemplate访问"http://bookservice/",从Eureka服务中检索到名为bookservice服务的所有实例地址和端口号,利用客户端负载机制选择其中一个实例进行访问。

BookService服务在启动的时候会自动向Eureka注册。Eureka Server的地址配置在application.properties文件中:

server.port=0
eureka.client.serviceUrl.defaultZone=http://${EUREKA_SERVER_ADDRESS}:8761/eureka/

bootstrap.properties文件中声明服务名:

spring.application.name=bookservice

如果大家查看Web服务的相应文件,也会看到类似的配置,只不过声明自己的服务名不同。

Spring Cloud对Eureka Server和Eureka Client做了很好的封装,一个应用只需通过如下标注即可成为Eureka Server:

...
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
   ...
}

Eureka Client的声明如下:

...
@SpringBootApplication
@EnableDiscoveryClient
public class BookserviceApplication {
   ...
}

构建镜像

构建镜像分两个步骤,Gradle编译生成Spring Boot JAR;然后利用Dockerfile创建Docker镜像。

./gradlew build
docker build -t <镜像名>:<标签> .

示例Dockerfile是针对Gradle编译出来的目录结构的。如果使用Maven编译,请更改JAR目录位置。

FROM java:8-jre-alpine
VOLUME /tmp
ADD build/libs/*.jar app.jar
RUN sh -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

全部构建完成后查看新生成的Docker镜像:

$ docker image ls
REPOSITORY         TAG         IMAGE ID       CREATED      SIZE
demo-web           latest      281e25e4c72c   2 days ago   180 MB
demo-bookservice   latest      249a93dfe3c6   2 days ago   180 MB
demo-eurekaserver  latest      2cfeb50cf373   2 days ago   204 MB

在本地运行

在compose目录下有一个V3版本的部署描述文件springcloud-demo.yml。如果你的计算机上有docker-compose,可以运行如下命令启动全部服务:

$ cd compose
$ docker-compose -f springcloud-demo.yml up -d

找到Eureka和Web的所对应的端口。

$ docker-compose -f springcloud-demo.yaml ps
        Name                       Command               State            Ports
----------------------------------------------------------------------------------------
compose_bookservice_1   java -Djava.security.egd=f ...   Up
compose_eureka_1        java -Djava.security.egd=f ...   Up      0.0.0.0:8761->8761/tcp
compose_web_1           java -Djava.security.egd=f ...   Up      0.0.0.0:32771->8080/tcp

访问Eureka Server

eureka_screenshot

从上面的输出可以看到Web和BookService服务各有一个实例注册上了。下面访问Web服务:

web_screenshot

部署到Swarm Mode集群

Docker 1.12开始Swarm Mode集群模式,相关的文章可以参考云栖文章。读者登录到任意Swarm管理节点,执行部署命令。

docker stack deploy -f all-in-one.yml springcloud-demo

示例springcloud-demo.yml采用Compose V3格式,新格式和V2的差别讨论间云栖文章。我们在这里没有使用V3特有的内容,贴在这里供大家参考:

version: '3'
services:
  eureka:
    image: XXX/demo-eurekaserver
    ports:
      - "8761:8761"
  web:
    image: XXX/demo-web
    environment:
      - EUREKA_SERVER_ADDRESS=eureka
    ports:
      - "8080"
  bookservice:
    image: XXX/demo-bookservice
    environment:
      - EUREKA_SERVER_ADDRESS=eureka

部署到Docker Datacenter

Docker公司的商业版集群管理软件Docker Datacenter支持了Swarm Mode模式集群。有关Docker商业版的内容可以参考云栖文章:DockerCon2017前瞻 - Docker企业版体验

最新的Docker Datacenter 2.1上用户可以通过界面上的Compose编辑器输入Compose模版完成部署,效果和上面用docker stack命令一样。

在2.0版上没有Compose模版编辑界面,读者可以登录进入任何一个管理节点,通过命令行执行同样命令部署:

docker stack deploy -f all-in-one.yml springcloud-demo

讨论

本文的示例代码在github上。在生产环境中部署SpringCloud应用还要涉及到高可用,日志、监控等配置在以后的系列文章中会介绍相应内容,敬请关注。

Docker Swarm运行Spring Cloud(二):Eureka高可用

小结

本文讨论了如何在Docker Swarm Mode集群上部署一个Spring Cloud应用,可以看出Docker Swarm的优雅之处在于集群管理和Docker API一致以及优异的开发者体验。阿里云容器服务除了在共有云上提供了CaaS能力能力也会很快支持Swarm Mode,了解更多阿里云容器服务内容,请访问 https://www.aliyun.com/product/containerservice

相关文章
|
人工智能 Java Serverless
【MCP教程系列】搭建基于 Spring AI 的 SSE 模式 MCP 服务并自定义部署至阿里云百炼
本文详细介绍了如何基于Spring AI搭建支持SSE模式的MCP服务,并成功集成至阿里云百炼大模型平台。通过四个步骤实现从零到Agent的构建,包括项目创建、工具开发、服务测试与部署。文章还提供了具体代码示例和操作截图,帮助读者快速上手。最终,将自定义SSE MCP服务集成到百炼平台,完成智能体应用的创建与测试。适合希望了解SSE实时交互及大模型集成的开发者参考。
12505 60
|
3月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
471 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
5月前
|
Java Linux 网络安全
Linux云端服务器上部署Spring Boot应用的教程。
此流程涉及Linux命令行操作、系统服务管理及网络安全知识,需要管理员权限以进行配置和服务管理。务必在一个测试环境中验证所有步骤,确保一切配置正确无误后,再将应用部署到生产环境中。也可以使用如Ansible、Chef等配置管理工具来自动化部署过程,提升效率和可靠性。
569 13
|
8月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
530 70
|
5月前
|
Prometheus 监控 Cloud Native
Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务
Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务实现步骤
562 0
|
9月前
|
SQL 数据库 Docker
【赵渝强老师】在Docker中运行达梦数据库
本文介绍了在Docker容器中部署达梦数据库(DM 8)的具体步骤,包括创建文件夹、下载安装包、导入镜像、启动容器、登录数据库及查看状态等操作。同时,通过视频讲解辅助理解。文中还分析了将数据库服务容器化的潜在问题,如数据安全性、硬件资源争用、网络带宽占用和额外隔离带来的挑战,指出数据库服务在生产环境中可能不适合容器化的原因。
692 4
【赵渝强老师】在Docker中运行达梦数据库
|
8月前
|
NoSQL Redis 数据库
Docker平台上的Redis镜像运行
这就是如何在Docker平台上运行Redis镜像的全部过程。走进Docker和Redis的世界,探索更多可能!
479 10
|
11月前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
2692 17
Spring Boot 两种部署到服务器的方式
|
11月前
|
前端开发 应用服务中间件 nginx
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
973 25
|
9月前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?