利用Docker轻松实现云原生应用: Spring Boot + Redis分布式会话

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 前文谈到了云原生应用在部署架构中需要考虑的重要问题。文本将介绍一个常见的应用架构模式来提升应用的可用性和可伸缩性 - 分布式会话管理。并利用Docker和阿里云容器服务在本地和云端进行了示例应用的部署和验证。

14808310188670

本文为利用Docker和容器服务轻松实现云原生应用系列的第二篇

前文谈到了云原生应用在部署架构中需要考虑的重要问题。文本将介绍一个常见的应用架构模式来提升应用的可用性和可伸缩性 - 分布式会话管理。

随着业务增长,Web应用也从单节点部署演变为集群部署。这时候除了需要为应用服务器增加负载均衡之外,也要解决会话(session)管理的问题。Session在应用中常被用于存储用户相关的数据。在高可用系统中,如果一台应用服务宕机,其他服务器需要能够接管当前活跃的会话,继续为用户提供服务。所以我们必须提供分布式的会话管理能力。

Spring/Spring Boot应用中利用Spring Session配合Redis是一个流行的分布式的会话管理方案,它有如下几个优点:

  • 将session所持久化状态从应用服务器本地内存卸载到外部Redis服务中,可以提升应用的可用性
  • 应用服务器是无状态的,满足 12-factor 的要求,可以更好地支持应用水平扩展

关于 Spring Session 的信息可以从官方文档获得

利用Docker来本地测试Spring Boot + Redis会话存储

首先从Github获得示例代码

git clone https://github.com/denverdino/docker-spring-boot-sample-session-redis
cd docker-spring-boot-sample-session-redis

本工程基于Spring Boot使用Redis会话存储的官方示例,并做简单调整如下:

其中 /src/main/resources/application.properties 内容:

spring.session.store-type=redis
server.session.timeout=5
spring.redis.host=redis
spring.redis.port=6379

它会配置基于Redis的分布式会话存储支持,会话超时时间为“5”秒,Redis服务域名为“redis”,端口 “6379”。

我们再查看项目的Maven配置文件pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <!-- Your own application should inherit from spring-boot-starter-parent -->
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.1.RELEASE</version>
    </parent>
    <artifactId>spring-boot-sample-session-redis</artifactId>
    <name>Spring Boot Session Redis Sample</name>
    <description>Spring Boot Session Redis Sample</description>
    <url>http://projects.spring.io/spring-boot/</url>
    <organization>
        <name>Pivotal Software, Inc.</name>
        <url>http://www.spring.io</url>
    </organization>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>0.4.13</version>
                <configuration>
                    <imageName>registry.cn-hangzhou.aliyuncs.com/denverdino/spring-boot-session-redis</imageName>
                    <baseImage>openjdk:8-jre</baseImage>
                    <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint>
                    <resources>
                       <resource>
                         <targetPath>/</targetPath>
                         <directory>${project.build.directory}</directory>
                         <include>${project.build.finalName}.jar</include>
                       </resource>
                    </resources>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

其中它除了声明了对Spring Boot框架的支持,还添加了来自Spotifydocker-maven-plugin构建应用的Docker镜像

我们可以来用maven命令来构建Spring Boot示例应用(参数是为了跳过单元测试)

mvn package -Dmaven.test.skip=true

也可以利用maven命令构建示例应用的Docker镜像

mvn package docker:build -Dmaven.test.skip=true

注:关于“docker-maven-plugin”插件的更多信息,可以参考容器化Spring Boot应用一文

构建镜像完成,可以使用如下docker-compose.yml模板来在本地部署和测试应用。其中web服务会启动Spring Boot测试应用,并利用容器链接通过“redis”别名来访问redis服务中的Redis容器

web:
  image: registry.cn-hangzhou.aliyuncs.com/denverdino/spring-boot-session-redis
  ports:
    - 8080:8080
  links:
    - redis:redis
redis:
  image: redis:3

执行 docker-compose up 命令之后,我们就会看到“redis”容器和“web”应用容器相继启动

我们可以通过浏览器来访问http://localhost:8080/测试应用。如果会话不存在或会话超时(5秒钟),应用会生成一个UUID保存在会话中并返回;如果会话存在,则会直接返回会话中保存的UUID。

利用容器服务来部署分布式会话管理应用

阿里云容器服务提供了对分布式的Docker应用的部署和管理能力。我们可以简单地扩展之前的Docker Compose模板来在云端部署应用。

web:
  image: registry.cn-hangzhou.aliyuncs.com/denverdino/spring-boot-session-redis
  labels:
    aliyun.scale: "3"
    aliyun.routing.port_8080: spring-boot
  links:
    - redis:redis
redis:
  image: redis:3

注:

  • 通过aliyun.xxx标签声明了,web应用由3个容器组成应用集群,并可以通过虚拟域名“spring-boot”进行访问
  • 通过路由服务来访问应用是无需使用 ports 对容器端口进行宿主机端口映射的

部署之后,web服务在控制台的截图如下,可以直接点击访问端点来验证应用。

14808300491575

总结

在云原生应用中,分布式会话管理是一个重要的应用模式。本文利用Docker和阿里云容器服务在本地和云端进行了示例应用的部署和验证。

如果大家有兴趣,还可以将容器模板中的Redis镜像替换成阿里云提供的Redis服务,这样可以在生产系统中提供更好的可用性和和可伸缩性。可以参考在阿里云容器服务中使用RDS

想了解更多容器服务内容,请访问 https://www.aliyun.com/product/containerservice

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
19天前
|
存储 消息中间件 NoSQL
Redis数据类型详解:选择合适的数据结构优化你的应用
Redis数据类型详解:选择合适的数据结构优化你的应用
|
27天前
|
NoSQL Java Redis
如何通俗易懂的理解Redis分布式锁
在多线程并发的情况下,我们如何保证一个代码块在同一时间只能由一个线程访问呢?
36 2
|
26天前
|
NoSQL Redis Docker
Docker中Redis数据迁移到本地
Docker中Redis数据迁移到本地
18 1
|
1月前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
90 0
|
4天前
|
监控 数据挖掘 Docker
《Docker 简易速速上手小册》第8章 Docker 在企业中的应用(2024 最新版)
《Docker 简易速速上手小册》第8章 Docker 在企业中的应用(2024 最新版)
21 0
|
26天前
|
NoSQL 关系型数据库 MySQL
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
123 1
|
26天前
|
敏捷开发 监控 前端开发
Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构
Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构
61 0
|
30天前
|
Cloud Native NoSQL 数据管理
Serverless 应用引擎常见问题之首次启动获取不到redis连接如何解决
Serverless 应用引擎(Serverless Application Engine, SAE)是一种完全托管的应用平台,它允许开发者无需管理服务器即可构建和部署应用。以下是Serverless 应用引擎使用过程中的一些常见问题及其答案的汇总:
28 3
Serverless 应用引擎常见问题之首次启动获取不到redis连接如何解决
|
1月前
|
NoSQL 关系型数据库 MySQL
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
206 0
|
1月前
|
NoSQL Redis 数据安全/隐私保护
在Docker中设置Redis的密码
在Docker中设置Redis的密码
99 0