微服务架构学习SpringBoot集成Druid

本文介绍了在微服务架构中,SpringBoot如何集成Druid数据源,包括Druid的基本特性、数据源配置、监控配置。通过设置初始化大小、最大连接数等参数,确保数据库连接池的高效运行。同时,详细讲述了如何开启Druid的数据源监控功能,提供了一个便捷的Web界面用于查看数据库连接状态。
摘要由CSDN通过智能技术生成

微服务架构学习SpringBoot集成Druid


Druid简介

  • Java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,又不得不使用数据库连接池。

  • Druid 是阿里巴巴开源平台上一个数据库连接池实现,结合了 C3P0、DBCP 等 DB 池的优点,同时加入了日志监控。

  • Druid 可以很好的监控 DB 池连接和 SQL 的执行情况,天生就是针对监控而生的 DB 连接池。

  • Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署的严苛考验。

  • Spring Boot 2.0 以上默认使用 Hikari 数据源,可以说 Hikari 与 Driud 都是当前 Java Web 上最优秀的数据源,我们来重点介绍 Spring Boot 如何集成 Druid 数据源,如何实现数据库监控。

  • Github地址:github.com/alibaba/dru…

com.alibaba.druid.pool.DruidDataSource 基本配置参数如下:

配置 缺省值 说明
name 配置这个属性的意义在于,如果存在多个数据源,监控的时候可以通过名字来区分开来。 如果没有配置,将会生成一个名字,格式是:“DataSource-” + System.identityHashCode(this)
jdbcUrl 连接数据库的url,不同数据库不一样。例如: mysql : jdbc:mysql://10.20.153.104:3306/druid2 oracle : jdbc:oracle:thin:@10.20.149.85:1521:ocnauto
username 连接数据库的用户名
password 连接数据库的密码。如果你不希望密码直接写在配置文件中,可以使用ConfigFilter。详细看这里:github.com/alibaba/dru…
driverClassName 根据url自动识别 这一项可配可不配,如果不配置druid会根据url自动识别dbType,然后选择相应的driverClassName(建议配置下)
initialSize 0 初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getConnection时
maxActive 8 最大连接池数量
maxIdle 8 已经不再使用,配置了也没效果
minIdle 最小连接池数量
maxWait 获取连接时最大等待时间,单位毫秒。配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁。
poolPreparedStatements false 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭。
maxOpenPreparedStatements -1 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100
validationQuery 用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用。
validationQueryTimeout 单位:秒,检测连接是否有效的超时时间。底层调用jdbc
Statement对象的void setQueryTimeout(int secon
### 回答1: Se是一款分布式事务解决方案,可以帮助开发人员简化分布式事务的开发和管理。在SpringBoot集成Seata可以帮助我们更方便地使用Seata。 下面是集成Seata的步骤: 1. 添加Seata依赖 在pom.xml中添加Seata的依赖: ``` <dependency> <groupId>io.seata</groupId> <artifactId>seata-all</artifactId> <version>1.4.2</version> </dependency> ``` 2. 配置Seata 在SpringBoot的配置文件中,配置Seata的相关参数: ``` spring: application: name: xxx-service cloud: alibaba: seata: tx-service-group: my_test_tx_group # 事务组名称,需要与seata-server中的配置一致 enabled: true # 启用seata application-id: ${spring.application.name} # 应用ID,需要与seata-server中的配置一致 tx-service-group: my_test_tx_group # 事务组名称,需要与seata-server中的配置一致 config: type: nacos # 配置中心类型,可以是nacos、file、apollo等 nacos: server-addr: ${seata.server.ip}:${seata.server.port} # nacos配置中心地址,需要配置seata.server.ip和seata.server.port group: SEATA_GROUP # nacos配置中心中的group namespace: ${seata.namespace} # nacos配置中心中的namespace file: name: file.conf # 配置文件名称,需要与seata-server中的文件名一致 apollo: appId: ${seata.appId} # apollo的AppId namespace: ${seata.namespace} # apollo的namespace config-service-url: ${seata.configServiceUrl} # apollo的配置中心地址 cluster-name: ${seata.clusterName} # apollo的集群名称 namespace: ${seata.namespace} # apollo的namespace ``` 3. 配置数据源 在使用Seata时,我们需要使用Seata提供的数据源来管理分布式事务。因此,在配置数据源时,我们需要使用Seata提供的数据源。 ``` @Bean @ConfigurationProperties(prefix = "spring.datasource") public DataSource dataSource() { return new DruidDataSource(); } @Bean public DataSourceProxy dataSourceProxy(DataSource dataSource) { return new DataSourceProxy(dataSource); } ``` 4. 配置Mybatis 在使用Mybatis时,我们需要配置Mybatis的拦截器,以便Seata能够拦截到Mybatis的事务操作。 ``` @Configuration public class MybatisConfig { @Bean public ConfigurationCustomizer configurationCustomizer() { return configuration -> configuration.addInterceptor(new SeataInterceptor()); } } ``` 5. 配置Seata事务管理器 在SpringBoot中,我们可以使用Seata提供的注解来管理分布式事务。因此,我们需要配置Seata事务管理器。 ``` @Bean public GlobalTransactionScanner globalTransactionScanner() { return new GlobalTransactionScanner("xxx-service", "my_test_tx_group"); } ``` 以上就是在SpringBoot集成Seata的步骤。通过集成Seata,我们可以更方便地管理分布式事务,提高应用的可靠性和稳定性。 ### 回答2: Spring Boot是一种用于简化创建基于Spring框架的应用程序的框架,而Seata是一种分布式事务解决方案。集成Seata可以帮助我们在分布式环境下更好地处理事务问题。 首先,要将Seata集成Spring Boot中,我们需要在项目的pom.xml文件中添加Seata的依赖。然后,在Spring Boot的配置文件中,我们需要配置Seata的相关属性,如注册中心的地址、数据源的代理等。 一旦配置完成,我们就可以在Spring Boot应用程序中使用Seata来处理分布式事务了。在需要进行事务处理的方法上,我们可以使用Seata提供的@Transactional注解来标识,这样Seata就会自动为我们管理事务。此外,Seata还提供了一些其他的注解,如@Compensable注解用于标识可补偿的方法。 当我们使用Seata进行分布式事务处理时,事务管理器会自动将所有涉及到的数据源和资源加入到同一个事务中。如果任何一个操作失败,Seata会自动回滚整个事务,保证数据的一致性。 此外,Seata还提供了一些其他的功能,如分布式事务的日志记录和补偿机制。通过这些功能,我们可以更好地管理分布式事务,并且保证数据的可靠性和一致性。 总之,通过将Seata集成Spring Boot应用程序中,我们可以更好地处理分布式环境下的事务问题。Seata提供了一系列的功能和注解,帮助我们管理分布式事务,并且保证数据的一致性。 ### 回答3: Spring Boot是一种使用Java编写的开源框架,用于快速构建独立的、可部署的、生产级的应用程序。而Seata是一个开源的分布式事务解决方案,可用于解决微服务架构下的数据一致性问题。下面将介绍如何将Seata集成Spring Boot中。 首先,在Spring Boot项目中添加Seata的依赖项。可以通过在项目的构建配置文件pom.xml中添加相应的依赖来实现。这些依赖将引入Seata的核心组件,例如分布式事务协调器、代理等。 然后,配置Seata的相关属性。通过在Spring Boot项目的配置文件中添加Seata相关的配置,如事务组名称、事务日志存储模式、代理类型等。这些配置将告诉Seata如何与项目进行交互和协作。 接下来,编写业务逻辑。在Spring Boot项目中,编写业务逻辑的方式与平常一样,不同之处在于需要在涉及到数据库操作的地方添加Seata的分布式事务注解。这些注解将告诉Seata哪些操作需要参与到分布式事务中,以保证数据的一致性。 最后,启动项目并验证集成效果。在项目启动后,Seata会根据配置信息自动启动并创建相应的事务组。在执行业务逻辑时,Seata将根据注解的配置来管理事务的开启、提交和回滚,以保证数据的一致性和可靠性。 综上所述,通过以上步骤,我们可以将Seata集成Spring Boot项目中,实现分布式事务的管理和控制。这对于构建高可靠性的微服务架构是非常有帮助的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值