商务服务
Spring Boot数据源配置及数据库连接池的概念
2024-12-04 02:52


Spring中配置数据源的几种方式

Spring Boot数据源配置及数据库连接池的概念

  • 通过在JDBC驱动程序定义的数据源;
  • 通过JNDI查找的数据源;
  • 连接池的数据源;

 

对于Sping应用来说需要手动配置

Spring boot中帮我们自动配置好了,只需要在application.properties中声明指定jndiName就可以了。

因为Spring boot自带web容器,因此JNDI方式只适用于将war发布到独立的web容器启动的方式。

啥是连接池?

  数据库连接池是web容器(比如Tomcat)提供的一个数据库连接管理的容器,连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个。

 为什么要用它?

   数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。  一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的性能低下。 数据库连接池的解决方案是在应用程序启动时建立足够的数据库连接,并讲这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库联接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。 连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。 

在Spring Boot中怎么用?

配置连接池参数

  • 最小连接数:是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费.
  • 最大连接数:是连接池能申请的最大连接数,如果数据库连接请求超过次数,后面的数据库连接请求将被加入到等待队列中,这会影响以后的数据库操作
  • 最大空闲时间: 超出这个时间,该连接将被销毁
  • 获取连接超时时间: 超出时间程序将会返回连接超时异常
  • 超时重试连接次数: 超时后重新连接的次数

 

Spring Boot2.0默认使用HikariCP连接池管理数据源

 

HikariCP的特点是快,

常用HkariCP配置

更多配置去官网https://github.com/brettwooldridge/HikariCP

这样就搞定了,Spring Boot帮我们把数据源创建、事务管理、JdbcTemplate创建都搞定了。

 

Alibaba Druid 连接池(https://github.com/alibaba/druid)

 

Durid通过Filter来扩展和定制连接池操作的细节

Filter 配置
• spring.datasource.druid.filters=stat,config,wall,log4j (全部使?默认值) 
密码加密
• spring.datasource.password=<加密密码>
• spring.datasource.druid.filter.config.enabled=true
• spring.datasource.druid.connection-properties=config.decrypt=true;config.decrypt.key=<public-key>
SQL 防注?
• spring.datasource.druid.filter.wall.enabled=true
• spring.datasource.druid.filter.wall.db-type=h2
• spring.datasource.druid.filter.wall.config.delete-allow=false  // 是否允许执行delete
• spring.datasource.druid.filter.wall.config.drop-table-allow=false // 是否允许执行drop table

实现Filter

 

 

 

在Sring boot中配置多数据源需要写多套配置,例如创建两个数据源

分别用Java Config 为不同的配置创建数据源Bean。

首先让Spring boot取消自动配置

然后手动配置DataSource和TransactionManager,@Primary注解指明当有两个类实现同一接口的时候该采用哪个实现类进行@Autowried,另外可以在实现类上用@Qualifier("className")指定名称,后面@Autowried的时候也用@Qualifier指定注入哪个类。

 

到此我们可以使用DataSource了

 

 

    以上就是本篇文章【Spring Boot数据源配置及数据库连接池的概念】的全部内容了,欢迎阅览 ! 文章地址:http://fabua.ksxb.net/news/3549.html 
     文章      相关文章      动态      同类文章      热门文章      栏目首页      网站地图      返回首页 海之东岸资讯移动站 http://fabua.ksxb.net/mobile/ , 查看更多   
最新文章
消失的手机:曾经的模块化鼻祖,外观设计大师退出市场模块化手机「消失的手机:曾经的模块化鼻祖,外观设计大师退出市场」
在智能手机全面向触屏时代迈进以后,大约在2013年-2016年之间,国内的智能手机品牌可以说是百花齐放,国产智能手机品牌很多也是
华硕手机应用商店手机应用商城「华硕手机应用商店」
华硕手机应用商店是一个方便、快捷且易于使用的软件应用商店。在华硕手机应用商店中,您可以根据您要下载的软件类别进行,相应的
堪比职业玩家的电竞体验,vivo S7游戏魔盒竟有如此妙用vivo游戏手机「堪比职业玩家的电竞体验,vivo S7游戏魔盒竟有如此妙用」
玩游戏,讲究的不仅仅只是技术,主要离不开的还是硬件设备的支持。大家平日里用玩游戏总会觉得不过瘾。有的时候,欠缺的未必是技
美防长敦促日本强化防卫能力
参考消息网3月31日报道 据《日本经济新闻》3月30日报道,30日,日本防卫相中谷元在防卫省与来访的美国国防部长赫格塞思举行特朗
短剧人抱团出海,争抢唯一确定的增量
文 | 新声Pro,作者 | 王珊珊(北京)「我们整个公司的重心,包括我个人的重心,现在都放在海外。」短剧出海厂牌 Crest Pte.Ltd
快速教你玩转手机备忘录手机备忘录「快速教你玩转手机备忘录」
手机中有一个叫“备忘录”的APP,大家应该经常会用到,对这个功能应该也不陌生了,这里就说说几个大家有可能未发现的功能,用起
佛经上说释迦牟尼佛有三十二相,具体是哪些相?佛手机「佛经上说释迦牟尼佛有三十二相,具体是哪些相?」
佛教,就是佛陀的教育。我们在经上常常看到说,释迦牟尼佛有三十二相,这些相也是为表法所用,代表圆满到极处。每一种相都是由一
A股的估值现在贵不贵?
伴随“四月决断”的到来,市场风格逐渐从题材投资回归价值投资,而价值投资的一大核心理念就在于股价和企业基本面的适配程度——
劳力士都不保值了?为啥奢侈品手表都不值钱了?
在世界奢侈品市场上,有一类奢侈品被视为保值增值的标的,比如说大名鼎鼎的爱马仕和香奈儿的香包,再比如说知名的奢侈品手表劳力
《不思异:志怪》大结局意犹未尽,“中式志怪”细节拉满
由搜狐视频出品,兔狲文化制作,出品人张朝阳,总制片人曹迪、邱其虎,席文婷执导,袁哲总编剧,何昶希、赵嘉敏、袁梓铭、薛卉葳