在阿里云容器服务上开发基于Docker的Spring Cloud微服务应用(九)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 阿里云的容器服务不但提供了语言无关的服务治理能力,同时对Spring Cloud应用也有很好的支持,还有很多对云应用动态管理的很多扩展。所有这些因素都使得阿里云容器服务部署运行微服务应用的一个完美平台。

服务的部署和发布策略

本文为阿里云容器服务Spring Cloud应用开发系列文章的第九篇。前文讨论了如何开发基于Spring Cloud微服务应用,所有代码通过标准的Dockerfile构建成为不同的镜像,我们还要写docker-compose.yml来描述容器启动参数和容器之间的关系,这个文件也就是我们常说的部署模版文件。

一、在阿里云容器服务上开发Spring Cloud微服务应用

二、部署Spring Cloud应用示例

三、服务发现

四、服务间通信与集成

五、服务智能路由

六、集中配置管理

七、高可用和容错

八、监控和日志

九、服务的部署和发布策略(本文)

部署服务

在示例代码中有两个docker compose文件,一个是docker-compose.yml,另外一个是docker-compose.acs.yml。它们两者的区别是docker-compose.yml中的数据库是MySQL容器,docker-compose.acs.yml中服务连接的是阿里云的RDS

version: "2"
services:
  discovery1:
    container_name: discovery1
    image: registry.aliyuncs.com/jingshanlb/discovery-server
    labels:
      # demo only, do not use it in production
      aliyun.routing.port_8761: http://eureka1
    environment:
      - ADDITIONAL_EUREKA_SERVER_LIST=http://discovery2:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud

  discovery2:
    container_name: discovery2
    image: registry.aliyuncs.com/jingshanlb/discovery-server
    environment:
      - ADDITIONAL_EUREKA_SERVER_LIST=http://discovery1:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud
      - affinity:service!=discovery1
      
  gateway:
    image: registry.aliyuncs.com/jingshanlb/gateway
    ports:
      - "8080:8080"
    labels:
      aliyun.scale: "2"
      aliyun.lb.port_8080: http://${slbname}:8080
    environment:
      - EUREKA_SERVER_LIST=http://discovery1:8761/eureka/,http://discovery2:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud
      - 'availability:az==2'

  mysql:
    image: registry.aliyuncs.com/acs-sample/mysql:5.7
    environment:
      - MYSQL_ROOT_PASSWORD=passw0rd
      - MYSQL_DATABASE=foodb
      - MYSQL_USER=user1
      - MYSQL_PASSWORD=passw0rd


  foo:
    image: registry.aliyuncs.com/jingshanlb/foo
    links:
      - mysql:mysql
    environment:
      - EUREKA_SERVER_LIST=http://discovery1:8761/eureka/,http://discovery2:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud
      - MYSQL_DATABASE=foodb
      - MYSQL_USERNAME=user1
      - MYSQL_PASSWORD=passw0rd

  bar:
    image: registry.aliyuncs.com/jingshanlb/bar
    environment:
      - EUREKA_SERVER_LIST=http://discovery1:8761/eureka/,http://discovery2:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud
      - SERVER_PORT=8080
      - MANAGEMENT_PORT=8081

  foobar:
    image: registry.aliyuncs.com/jingshanlb/foobar
    environment:
      - EUREKA_SERVER_LIST=http://discovery1:8761/eureka/,http://discovery2:8761/eureka/
      - SPRING_PROFILES_ACTIVE=cloud

两个Eureka Server组成的集群,容器名分别为discovery1discovery2,对于所有使用Eureka的其它服务来说,启动时的环境变量EUREKA_SERVER_LIST设置成这两个Eureka Server的URL,Eureka Client需要这个信息决定连接那个Eureka Server。

discovery1通过aliyun.routing.port_8761声明为对外可以访问,访问端点可以在控制台界面中的discovery1页面看到。

gateway服务通过aliyun.lb.port_8080配置为由SLB进行负载均衡。更多关于aliyun.lb和aliyun.routing的区别可以参见阿里云容器服务服务编排文档

foo的mysql:mysqllinks声明将mysql(容器)和mysql(foo代码使用的DNS地址)绑定起来,而且是跨主机的绑定。

模版部署文件中的其它内容已经都在前文中介绍过了,这里就不再重复了。

部署的过程在前面的文章已经讨论过了,这里把仅输入部署模版文件内容的部分再简单介绍一下。

拷贝docker-compose.yml内容,粘贴进入模版编辑器。注意其中的${slbname}将来会替换为前面创建的负载均衡名字或ID。

create_app02

点击创建并部署按钮,在对话框中输入负载均衡ID,确认后创建应用。
create_app03

服务升级

部署成功的应用如果镜像发生了变化,需要在对应用重新部署,如果docker-compose.yml内容发生了变化,需要执行变更配置

redeploy

发布策略

阿里云容器服务提供了多种发布策略,我们介绍一下这其中最简明的一种方式:rolling update发布,意思是在更新的服务时按顺序更新,只有当前一个服务更新成功后再做下一个服务的更新。这里的要求时需要用aliyun.scale标签声明容器实例数量,并且通过aliyun.probe声明了健康检查方式。

下面部署模版演示了如何使用rolling update模式发布(例子来源:服务编排文档)。

web:
  image: wordpress
  ...
  labels:
    aliyun.probe.url: http://container/license.txt
    aliyun.probe.initial_delay_seconds: '10'
    aliyun.routing.port_80: http://wordpress
    aliyun.rolling_updates: 'true'
    aliyun.scale: '2'

阿里云容器服务的服务治理能力

在本系列文章中我们讨论了如何利用SpringCloud构建一个微服务应用,以及如何在阿里云容器服务上部署微服务应用。阿里云容器服务在完全兼容Docker API的前提提供了服务治理能力,这些服务治理能力都是和语言无关的,比如服务的注册、发现和绑定,服务健康检查,高可用保证,服务接入路由,多重服务发布策略,服务的管控等。

后续会有相关的文章详细介绍这些功能。

总结

容器技术的应用隔离和一致性交付能力使得它成为微服务架构的最佳实践之一。由于封装了互联网级别的Netfix开源产品,Spring Cloud成为Java语言实现微服务应用的成熟框架。

阿里云的容器服务不但提供了语言无关的服务治理能力,同时对Spring Cloud应用也有很好的支持,还有很多对云应用动态管理的很多扩展。所有这些因素都使得阿里云容器服务部署运行微服务应用的一个完美平台。

相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
18小时前
|
存储 安全 文件存储
如何在群辉NAS使用Docker搭建容器魔方并实现无公网ip远程访问
如何在群辉NAS使用Docker搭建容器魔方并实现无公网ip远程访问
9 0
|
18小时前
|
JavaScript Java 开发者
Spring Boot中的@Lazy注解:概念及实战应用
【4月更文挑战第7天】在Spring Framework中,@Lazy注解是一个非常有用的特性,它允许开发者控制Spring容器的bean初始化时机。本文将详细介绍@Lazy注解的概念,并通过一个实际的例子展示如何在Spring Boot应用中使用它。
9 2
|
19小时前
|
关系型数据库 Java 数据库
docker部署postgresql数据库和整合springboot连接数据源
docker部署postgresql数据库和整合springboot连接数据源
4 0
|
1天前
|
传感器 人工智能 前端开发
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式
智慧校园电子班牌,坐落于班级的门口,适合于各类型学校的场景应用,班级学校日常内容更新可由班级自行管理,也可由学校统一管理。让我们一起看看,电子班牌有哪些功能呢?
36 4
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式
|
1天前
|
监控 安全 数据安全/隐私保护
【Docker专栏】Docker容器安全:防御与加固策略
【5月更文挑战第7天】本文探讨了Docker容器安全,指出容器化技术虽带来便利,但也存在安全隐患,如不安全的镜像、容器逃逸、网络配置不当等。建议采取使用官方镜像、镜像扫描、最小权限原则等防御措施,并通过安全的Dockerfile编写、运行时安全策略、定期更新和访问控制等加固容器安全。保持警惕并持续学习安全实践至关重要。
【Docker专栏】Docker容器安全:防御与加固策略
|
1天前
|
前端开发 API 数据库
【Docker专栏】Docker Compose实战:编排多容器应用
【5月更文挑战第7天】Docker Compose是Docker的多容器管理工具,通过YAML文件简化多容器应用部署。它能一键启动、停止服务,保证开发、测试和生产环境的一致性。安装后,创建`docker-compose.yml`文件定义服务,如示例中的web和db服务。使用`docker-compose up -d`启动服务,通过`docker-compose ps`、`stop`、`down`和`logs`命令管理服务。
【Docker专栏】Docker Compose实战:编排多容器应用
|
1天前
|
应用服务中间件 持续交付 nginx
【Docker专栏】Docker入门指南:快速构建你的第一个容器
【5月更文挑战第7天】Docker 入门指南:容器化应用利器。了解 Docker 核心概念——镜像、容器和仓库。安装 Docker 后,运行官方 `hello-world` 验证安装,再尝试运行 `nginx` Web 服务器。通过端口映射访问容器内服务,学习管理容器命令。创建自定义镜像,编写 Dockerfile,实现 Python Web 应用容器化。Docker 助力高效开发与运维,探索更多自动化部署与微服务场景。
【Docker专栏】Docker入门指南:快速构建你的第一个容器
|
1天前
|
运维 Linux Apache
Docker详解(十二)——Docker容器权限问题
Docker详解(十二)——Docker容器权限问题
15 5
|
1天前
|
存储 运维 Linux
Docker详解(十)——Docker容器CPU资源限额配置
Docker详解(十)——Docker容器CPU资源限额配置
11 3
|
1天前
|
前端开发 算法 数据中心
Docker consul的容器服务更新与发现
服务注册与发现解决分布式架构中服务定位和管理问题,允许动态更新与发现服务网络位置,减少配置维护。Consul是Google开源的多数据中心、高可用服务管理工具,提供服务发现、健康检查和配置共享功能。采用Raft算法确保高可用性,节点运行Agent,有Server和Client两种模式。Server模式负责信息持久化和同步,而Client模式只转发服务。每个数据中心推荐3-5个Server节点以保证数据安全和选举稳定性。

相关产品

  • 容器计算服务