Spring Boot 数据库操作Druid和HikariDataSource(二)

本文涉及的产品
云防火墙,500元 1000GB
简介: Spring Boot 数据库操作Druid和HikariDataSource

Durid 监控功能-Web 关联监控

需求: 配置Web 关联监控配置:Web 应用、URI 监控

官方文档

https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

Web 关联监控配置-Web 应用、URI 监控

DruidDataSourceConfig.java , 注入/ 增加WebStatFilter 用于采集web-jdbc 关联监控的数据

1. //配置WebStatFilter, 用于采集web-jdbc关联的监控数据
2. @Bean
3. public FilterRegistrationBean webStatFilter() {
4. //创建 WebStatFilter
5. WebStatFilter webStatFilter = new WebStatFilter();
6. 
7.         FilterRegistrationBean<WebStatFilter> filterRegistrationBean =
8. new FilterRegistrationBean<>(webStatFilter);
9. 
10. //默认对所有的url请求进行监控
11.         filterRegistrationBean.setUrlPatterns(Arrays.asList("/*"));
12. 
13. //排除指定的url
14.         filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
15. return filterRegistrationBean;
16.     }

为了测试方便,修改/WebConfig.java, 放行/sql 请求

重启项目,看看Web 应用和URI 监控页面

完成测试,重启项目,看看Web 应用和URI 监控是否生效

Durid 监控功能-SQL 防火墙

需求: 配置SQL 防火墙

官方文档https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

修改DruidDataSourceConfig.java ,加入防火墙监控

1. @ConfigurationProperties("spring.datasource")
2. @Bean
3. public DataSource dataSource() throws SQLException {
4. //1. 配置了 @ConfigurationProperties("spring.datasource")
5. //   就可以读取到application.yml的配置
6. //2. 我们就不需要调用DruidDataSource 对象的setXxx, 会自动关联
7. 
8. DruidDataSource druidDataSource = new DruidDataSource();
9. //加入监控功能, 加入了sql防火墙监控
10.         druidDataSource.setFilters("stat,wall");
11. return druidDataSource;
12.     }

完成测试,重启项目,看看SQL 防火墙监控是否生效

Durid 监控功能-Session 监控

需求: 配置Session 监控

官方文档https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

 

Session 监控

重启项目, 先登录管理系统

完成测试, 查看监控页需要输入用户名和密码, 点击Session 监控,可以看到相关信息

(注意要登录用户系统,才能看到Session 监控信息)

 

Druid Spring Boot Starter

基本介绍

1. 前面我们使用的是自己引入druid+配置类方式整合Druid 和监控

2. Druid Spring Boot Starter 可以让程序员在Spring Boot 项目中更加轻松集成Druid 和监控

修改pom.xml 注销druid 的依赖

注销DruidDataSourceConfig.java

这时测试,druid 失效

查看druid 文档https://github.com/alibaba/druid,引入druid starter

确认druid starter 引入哪些依赖

修改resources/application.yml 增加配置参数

1. spring:
2. servlet:
3. multipart:
4.       max-file-size: 10MB
5.       max-request-size: 50MB
6. datasource: #配置数据源
7. # 说明: 如果你没有指定useSSL=true ,启动项目会报红警告, 环境的问题,灵活处理
8. url: jdbc:mysql://localhost:3306/spring_boot?useSSL=true&useUnicode=true&characterEncoding=UTF-8
9. username: root
10. password: 自己的密码
11.     driver-class-name: com.mysql.jdbc.Driver
12. #配置druid和监控功能
13. druid:
14.       stat-view-servlet:
15. enabled: true
16.         login-username: jack
17.         login-password: 666
18.         reset-enable: false
19.       web-stat-filter: #配置web监控
20. enabled: true
21.         url-pattern: /*
22. exclusions: '*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*'
23. filter:
24. stat: #sql监控
25.           slow-sql-millis: 1000
26.           log-slow-sql: true
27. enabled: true
28. wall: #配置sql防火墙
29. enabled: true
30. config:
31.             drop-table-allow: false
32. select-all-column-allow: false

重启项目,完成测试

测试完成后,记得改回成原来的代码.(个人习惯) ...

目录
相关文章
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门 - 添加内存数据库H2
SpringBoot入门 - 添加内存数据库H2
85 3
SpringBoot入门 - 添加内存数据库H2
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
57 4
SpringBoot入门(4) - 添加内存数据库H2
|
2月前
|
Java 关系型数据库 数据库连接
使用 Spring Boot 执行数据库操作:全面指南
使用 Spring Boot 执行数据库操作:全面指南
151 1
|
3月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
39 2
SpringBoot入门(4) - 添加内存数据库H2
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
73 13
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
59 4
|
2月前
|
存储 安全 Java
springboot当中ConfigurationProperties注解作用跟数据库存入有啥区别
`@ConfigurationProperties`注解和数据库存储配置信息各有优劣,适用于不同的应用场景。`@ConfigurationProperties`提供了类型安全和模块化的配置管理方式,适合静态和简单配置。而数据库存储配置信息提供了动态更新和集中管理的能力,适合需要频繁变化和集中管理的配置需求。在实际项目中,可以根据具体需求选择合适的配置管理方式,或者结合使用这两种方式,实现灵活高效的配置管理。
28 0
|
3月前
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
257 2
|
12天前
|
Java 数据库连接 Maven
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
自动装配是现在面试中常考的一道面试题。本文基于最新的 SpringBoot 3.3.3 版本的源码来分析自动装配的原理,并在文未说明了SpringBoot2和SpringBoot3的自动装配源码中区别,以及面试回答的拿分核心话术。
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
|
19天前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
69 14