mysql数据库连接(有界面配置路径,账号密码等),后台代码中使用BasicDataSource连接池,然后将连接池放在map缓存中(map<string,BasicDataSource>)方便直接获取连接池对象查询数据库,如果长时间没用到这个map去获取连接池,是否会出问题呢,比如内存回收问题等,如果不放在map中,比如说放redis,BasicDataSource对象存放与获取比较麻烦??还有什么可以用的缓存框架吗(像map可以存放object)
长时间没有map去获取连接池是不会影响程序的。
连接池的目的就是开辟内存空间 当连接需求进来的时候,不用再new Connection,这么做的好处是,当数据库处于非常多的用户访问情景下,数据连接池可以有条不紊的租还连接,从而防止数据库因为过量的连接导致失去服务。内存回收是需要在连接池里写全的。
连接池的连接是高可用的。把连接放在redis里,redis只是一个数据缓存,跟MySQL一样,可以数据持久化,只是这些数据有消息有效期,和连接池好像没什么关系,因为连接池是 先在运行程序中开辟内存,当连接来的时候,直接获取连接,让连接有条不紊的访问数据库。
这就好比,小商品店 客流量小不需要门闸,当变成大超市,都会有拦人的一些东西,当变成飞机场和火车站,那就必须要设立更大的拦人条件了。
做缓存map应该是最好的选项之一吧,get时要注意实现同步机制哦。
您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632