mysql数据库连接(有界面配置路径,账号密码等),后台代码中使用BasicDataSource连接池,然后将连接池放在map缓存中(map<string,BasicDataSource>)方便直接获取连接池对象查询数据库,如果长时间没用到这个map去获取连接池,是否会出问题呢,比如内存回收问题等,如果不放在map中,比如说放redis,BasicDataSource对象存放与获取比较麻烦??还有什么可以用的缓存框架吗(像map可以存放object)
3条回答 默认 最新
- CSDN专家-Time 2021-06-01 02:13关注
长时间没有map去获取连接池是不会影响程序的。
连接池的目的就是开辟内存空间 当连接需求进来的时候,不用再new Connection,这么做的好处是,当数据库处于非常多的用户访问情景下,数据连接池可以有条不紊的租还连接,从而防止数据库因为过量的连接导致失去服务。内存回收是需要在连接池里写全的。
连接池的连接是高可用的。把连接放在redis里,redis只是一个数据缓存,跟MySQL一样,可以数据持久化,只是这些数据有消息有效期,和连接池好像没什么关系,因为连接池是 先在运行程序中开辟内存,当连接来的时候,直接获取连接,让连接有条不紊的访问数据库。
这就好比,小商品店 客流量小不需要门闸,当变成大超市,都会有拦人的一些东西,当变成飞机场和火车站,那就必须要设立更大的拦人条件了。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用
悬赏问题
- ¥15 latex投稿显示click download
- ¥15 请问读取环境变量文件失败是什么原因?
- ¥15 在若依框架下实现人脸识别
- ¥15 网络科学导论,网络控制
- ¥100 安卓tv程序连接SQLSERVER2008问题
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?