springCloud 整合druid

背景

通过前面的文章已经讲述了SpringCloud+nacos服务的搭建:传送门springCloud alibaba+nacos模块化项目搭建
当搭建好基础服务后,肯定会有数据库操作。目前常用的连接池,springboot自带的hicari-CP连接池和阿里巴巴的Druid连接池。Druid连接池提供了可视化的监控界面,因此我选择了Druid。当然hicari-CP也提供了插件感兴趣可以去了解一下:p6spy插件。hicari-CP的性能是高于druid的。感兴趣的可以去百度相关文章了解一下,我就不在这多说。接下来直接上干货。此文章跳过了对mybatis的集成

pom依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
</dependency>

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

配置文件

spring:
  #数据库配置
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/zhuiri?useUnicode=true&useSSL=false&characterEncoding=utf-8&serverTimezone=UTC
    username: root
    password: root
    # 使用druid数据源
    name: mysql
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.jdbc.Driver
    #连接池初始化大小,最小值,最大值,
    initial-size: 5
    min-idle: 5
    max-active: 100
    #获取连接超时时间,单位:毫秒
    max-wait: 10000
    #是否缓存preparedStatement,对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭
    pool-prepared-statements: false
    #间隔多久检测一次需要关闭的空闲连接,单位:毫秒
    time-between-eviction-runs-millis: 10000
    #用来检测连接是否有效的sql
    validation-query: SELECT 1 FROM DUAL
    #检测连接是否有效的超时时间, 单位:秒
    validation-query-timeout: 3
    test-while-idle: true
    #开启此配置会降低性能
    test-on-borrow: false
    test-on-return: false
    #配置监控统计filter,去掉后监控界面sql无法统计,'wall'用于防火墙
    filters: stat
    #配置监控统计filter的慢sql参数
  filter:
    stat:
      log-slow-sql: true
      slow-sql-millis: 80
      merge-sql: true
  servlet:
    multipart:
      max-file-size: 20MB
      max-request-size: 50MB

可视化监控配置

@Configuration
public class DruidConfiguration {


    /**
     * 注册一个StatViewServlet
     *
     * @return
     */
    @Bean
    public ServletRegistrationBean DruidStatViewServle2() {
        //org.springframework.boot.context.embedded.ServletRegistrationBean提供类的进行注册.
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");
        servletRegistrationBean.addUrlMappings("/druid/*");
        //白名单:
        servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
        //IP黑名单 (存在共同时,deny优先于allow) : 如果满足deny的话提示:Sorry, you are not permitted to view this page.
        servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
        //登录查看信息的账号密码.
        servletRegistrationBean.addInitParameter("loginUsername", "admin");
        servletRegistrationBean.addInitParameter("loginPassword", "admin");
        //是否能够重置数据.
        servletRegistrationBean.addInitParameter("resetEnable", "false");
        return servletRegistrationBean;
    }

    /**
     * 注册一个:filterRegistrationBean
     *
     * @return
     */
    @Bean
    public FilterRegistrationBean druidStatFilter2() {
        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
        //添加过滤规则.
        filterRegistrationBean.addUrlPatterns("/*");
        //添加不需要忽略的格式信息.
        filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid2/*");
        return filterRegistrationBean;
    }

	@ConfigurationProperties(prefix = "spring.datasource")
    @Bean
    public DataSource druid(){
       return new DruidDataSource();
    }

}

到这就集成好了,启动项目访问地址:http://localhost:8080/druid/login.html

在这里插入图片描述
剩下的登录进去,根据导航栏就可以解锁druid的功能啦!

如有问题,希望大家评论区留言多多指教!如觉得写得还可以,就给一个赞吧!

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: Spring Cloud整合Seata可以实现分布式事务的管理,Seata是一个开源的分布式事务解决方案,可以支持多种分布式场景下的事务管理。Spring Cloud是一个开源的微服务框架,可以帮助开发者快速构建分布式系统。 在Spring Cloud中,我们可以通过引入Seata的依赖来实现分布式事务的管理。具体步骤如下: 1. 引入Seata的依赖 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>io.seata</groupId> <artifactId>seata-all</artifactId> <version>1.4.2</version> </dependency> ``` 2. 配置Seata 在application.yml文件中添加以下配置: ``` spring: cloud: alibaba: seata: tx-service-group: my_test_tx_group # 事务组名称,需要与Seata Server中的配置一致 enable-auto-data-source-proxy: true # 开启数据源代理,用于自动注册分布式事务代理 application-id: ${spring.application.name} # 应用ID,用于在Seata Server中标识应用 tx-service: group: ${spring.cloud.alibaba.seata.tx-service-group} enable-auto-data-source-proxy: ${spring.cloud.alibaba.seata.enable-auto-data-source-proxy} application-id: ${spring.cloud.alibaba.seata.application-id} use-jdk-proxy: true # 使用JDK动态代理 use-cloud-storage: true # 使用云存储模式 use-local-storage: false # 不使用本地存储模式 use-file-lock: false # 不使用文件锁模式 use-dubbo: false # 不使用Dubbo模式 use-rm: true # 使用RM模式 use-tx-log: true # 使用事务日志模式 use-undo-log: true # 使用撤销日志模式 undo-log-serializer: jackson # 撤销日志序列化方式 undo-log-serialization: json # 撤销日志序列化格式 undo-log-table: undo_log # 撤销日志表名 undo-log-sql: mysql # 撤销日志SQL语句 undo-log-batch-delete-size: 100 # 撤销日志批量删除大小 undo-log-batch-insert-size: 100 # 撤销日志批量插入大小 undo-log-batch-update-size: 100 # 撤销日志批量更新大小 undo-log-batch-commit-size: 100 # 撤销日志批量提交大小 undo-log-batch-rollback-size: 100 # 撤销日志批量回滚大小 undo-log-batch-delete-interval: 100 # 撤销日志批量删除间隔时间 undo-log-batch-insert-interval: 100 # 撤销日志批量插入间隔时间 undo-log-batch-update-interval: 100 # 撤销日志批量更新间隔时间 undo-log-batch-commit-interval: 100 # 撤销日志批量提交间隔时间 undo-log-batch-rollback-interval: 100 # 撤销日志批量回滚间隔时间 ``` 3. 配置数据源代理 在数据源的配置中添加以下配置: ``` spring: datasource: url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false username: root password: root driver-class-name: com.mysql.jdbc.Driver type: com.alibaba.druid.pool.DruidDataSource filters: stat,wall,log4j maxActive: 20 initialSize: 1 maxWait: 60000 minIdle: 1 timeBetweenEvictionRunsMillis: 60000 minEvictableIdleTimeMillis: 300000 validationQuery: select 1 from dual testWhileIdle: true testOnBorrow: false testOnReturn: false poolPreparedStatements: true maxPoolPreparedStatementPerConnectionSize: 20 useGlobalDataSourceStat: true # 配置数据源代理 proxy-filters: - io.seata.rm.datasource.DataSourceProxy ``` 4. 配置分布式事务代理 在需要管理分布式事务的方法上添加@GlobalTransactional注解: ``` @Service public class OrderServiceImpl implements OrderService { @Autowired private OrderMapper orderMapper; @Autowired private AccountService accountService; @Autowired private StorageService storageService; @GlobalTransactional @Override public void create(Order order) { // 创建订单 orderMapper.create(order); // 扣减库存 storageService.decrease(order.getProductId(), order.getCount()); // 扣减账户余额 accountService.decrease(order.getUserId(), order.getMoney()); // 修改订单状态 orderMapper.update(order.getUserId(), ); } } ``` 以上就是Spring Cloud整合Seata的基本步骤,通过Seata可以实现分布式事务的管理,保证数据的一致性和完整性。 ### 回答2: Spring Cloud与Seata是目前非常流行的云原生技术,两者的结合可以极大地简化分布式系统下的数据库事务管理。下面将详细阐述Spring Cloud如何整合Seata。 1. Seata简介 Seata是阿里巴巴开源的分布式事务解决方案,它提供了一套完整的分布式事务解决方案,包括本地事务和分布式事务两种模式,并支持多种协议和语言。Seata支持全局事务的分布式管理,能够解决微服务架构下的分布式事务问题。 2. Spring Cloud整合Seata Spring Cloud已经提供了Seata的整合支持,只需要引入相应的依赖,配置一下Seata的相关信息即可。 (1)引入依赖 在pom.xml文件中添加如下依赖: ``` <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-seata</artifactId> <version>${seata.version}</version> </dependency> ``` (2)配置文件 在Spring Cloud的配置文件中,需要添加如下Seata相关的配置信息: ``` spring.application.name=seata-order-service spring.cloud.alibaba.seata.tx-service-group=my_test_tx_group mybatis.configuration.map-underscore-to-camel-case=true ``` 其中,“spring.cloud.alibaba.seata.tx-service-group”表示Seata的事务组名称,可以根据实际情况进行配置。 (3)Seata代理设置 最后,需要在Seata服务器和业务应用之间设置Seata代理服务,以实现事务的分布式管理。Seata代理服务的部署可以使用Docker等方式进行。Seata提供了官方的Docker镜像,可以直接使用。 3. 使用示例 下面以订单服务为例,演示如何使用Spring Cloud整合Seata实现分布式事务。 (1)定义事务服务接口 在订单服务中,首先需要定义一个分布式事务服务接口,用来统一处理业务逻辑和Seata分布式事务管理。 ``` public interface OrderService { @GlobalTransactional void createOrder(Order order); } ``` 其中,“@GlobalTransactional”注解表示该方法需要进行全局分布式事务管理。 (2)业务逻辑编写 在“createOrder”方法中,需要编写订单创建的业务逻辑,同时需要进行Seata全局事务管理。代码示例如下: ``` @Service public class OrderServiceImpl implements OrderService { @Autowired private OrderMapper orderMapper; @Autowired private AccountClient accountClient; @Override public void createOrder(Order order) { // 1.创建订单 orderMapper.createOrder(order); // 2.调用账户服务扣除订单金额 accountClient.decreaseAccount(order.getUserId(), order.getMoney()); // 模拟异常 int i = 1 / 0; // 3.修改订单状态 order.setStatus(1); orderMapper.updateOrder(order); } } ``` (3)Seata代理设置 最后,需要在Seata服务器和业务应用之间设置Seata代理服务。在Docker中启动Seata代理服务: ``` docker run -p 8091:8091 -v /data/seata:/data seataio/seata-server:1.5.1 ``` 接下来,在启动订单服务的时候,加上以下JVM参数: ``` -Dio.seata.tm.deployment.transaction.manager.type=server -Dio.seata.server.host=127.0.0.1 -Dio.seata.server.port=8091 -Dio.seata.config.file=/data/config.txt ``` 其中,“io.seata.config.file”表示Seata配置文件的路径,在本地可以使用文件系统,也可以使用远程配置中心。 4. 总结 Spring Cloud整合Seata可以为分布式系统带来完整的事务解决方案,可以轻松应对微服务下的分布式事务管理。同时,在使用Seata之前,也需要了解其实现原理和使用方法,以更好地掌握这种分布式事务解决方案。 ### 回答3: 随着互联网技术的发展,分布式系统架构设计方式逐渐受到大家的重视。然而,分布式事务依然是分布式架构中存在的难点之一,因此,分布式事务解决方案日益成为企业级架构设计必备的技术。 在分布式微服务架构中,Spring Cloud 和 Seata 都是被广泛采用的开源项目。那么,如何将这两个项目进行整合呢? 首先,需要了解 Seata 的设计原理。Seata 是一个跨多个系统跨多个数据源进行事务管理的分布式事务解决方案。它是由阿里巴巴公司提供的一种基于 XA 协议的全局事务解决方案,可以保证不同系统、不同数据源之间的事务一致性。 其次,Spring Cloud 的微服务架构的核心思想是基于 RESTful API 接口的微服务调用。通过使用 Spring Cloud 与 Seata 的分布式事务管理,可以实现 Spring Cloud 微服务架构中的各个服务之间的事务一致性,进一步提高微服务架构中的整体性能和可靠性。 如何整合? Seata 的基本原理是将一次分布式事务拆分成多个阶段,使用不同的锁机制对各个参与者的不同阶段的操作进行记录和管理。具体实现包括以下步骤: 1. 在 Spring Cloud 微服务架构中,使用 Seata 的 AT 模式,并将需要进行分布式事务管理的微服务注册到 Seata 服务器中,这样可以实现对微服务之间的事务进行管理。 2. 在 Seata 服务器中定义全局事务 ID,并进行事务状态的管理和存储。在进行分布式事务时,各个参与者首先需要向 Seata 服务器申请分配一个全局事务 ID,以便进行后续操作的记录和管理。 3. 使用 Seata 的 TC (Transaction Coordinator) 机制,对分布式事务中各个参与者的操作进行管理和协调。TC 主要负责分布式事务的整个生命周期的协调,确保各个参与者的事务操作都能够顺利进行,以便达到事务一致性的目的。 4. 使用 Seata 的 RM (Resource Manager) 机制,对事务涉及到的各个资源进行管理和保护,如数据库表、消息队列等。RM 主要负责协调分布式事务中各个参与者的数据操作,以保证数据的完整性和一致性。 总的来说,Spring Cloud 的微服务架构和 Seata 的分布式事务管理方案完美结合,通过使用 Seata 来解决分布式事务一致性问题,同时保留了 Spring Cloud 的轻量级、模块化和易拓展性等优点,为企业提供了可靠、高效、灵活的分布式架构解决方案。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值