原文 http://www.iteye.com/topic/143714
新的公司的底层数据库是MySQL,由于访问量巨大,所以采用了Master-Slave模式。也就是对于Master的机器,可以进行写入操作,而对于 Slave的机器进行数据读取操作,他们互相之间的数据同步由MySQL底层来完成。通过这种方法,来降低数据库的压力。
在这种情况下,我们在开发J2EE引用时,整个持久层的设计就有点犯难。如果使用Hibernate这样的ORM框架,持久化操作是简单了,但是只能针对Master的机器作为DataSource去创建SessionFactory。此时,又不能对之进行查询操作,所以这种方案又不大合适。如果纯采用JDBC进行开发,我们就要在程序中去做一些人工的ORM的工作,毕竟类似Spring的JDBCTemplate,尚没有将ORM武装到牙齿。
我目前的想法,是依然采用Hibernate,针对Master数据库进行ORM映射。并作一些持久化操作和最简单的查询操作。对于Slave得数据库,采用JDBCTemplate进行查询。但是这种在程序中混用的方式,我总是感觉不是很舒服,而且还要经常区分,到底是哪台数据库。
对这种构架比较有经验的朋友一起来讨论一下。
你也可以按照类似的想法在JDBC Driver这一层做手脚:
读操作随机读取slave中的某个数据库
写操作写入master
返回顶楼
简单的解决办法是这样的:查询语句使用Hibernate的native SQL,可以在查询语句里面动态绑定不同的数据库表,实现动态查询不同的slave数据库
或者复杂一些,你可以钻研一下Hibernate Shards,这个是Google公司捐献给Hibernate的项目,利用Hibernate进行分布式数据库访问,做的相当不错。
CJDBC很不错,但是它怎么根据读写操作来进行访问区分呢?貌似使用RAIDb-1这种策略,在写操作时,它会在每个数据库节点进行数据复制。而这点似乎已经可以由MySQL自己完成了。
你也可以按照类似的想法在JDBC Driver这一层做手脚:读操作随机读取slave中的某个数据库写操作写入master
cjdbc真的很强,不过对mysql来说,在server端做raid1集群也有自己的优点,因为一个数据库如果是给多个应用来访问的话,比如php,用不上cjdbc的就搞不定数据的复制了。
同downpour讨论之后,觉得还是配置两个sessionfactory,readsessionfacotry和 writesessionfactory,在opensession in view里把readsessionfactory的session放到当前线程中,然后在更新,插入删除操作时使用 writesessionfactory里的session就可以了。这样可以保证读取是靠slave库,更新是用master库。
它是通过Connection的readonly属性来判断读/写操作,看样子你们在用spring,那么spring的默认查询事务设置readonly能够很好用在此处。
可以做一些试验,比较一下cjdbc/ha-jdbc和mysql自己的replication这2种不同的解决方案,看谁的代码简单以及性能更好.
2个session factory是不好的解决方案,会遇到更多的麻烦问题,你们也可以试验看看
权衡下来Replication Driver似乎是最好的选择,对于我程序来说是完全透明的,而且能最大程度满足需求。多谢Readonly的介绍。
返回顶楼
http://www.jroller.com/kenwdelong/entry/horizontal_database_partitioning_with_spring
这里有篇文章介绍如何使用spring/hibernate进行水平数据库分区的文章,很不错,推荐。
返回顶楼
确实在jdbc drvier层去实现区分M/S是最好的方式了。
这种方法甚至可以在不同的数据库之间完成读写区分的操作。恩,甚至把cache搬到driver中去实现。。。上层再加上个通用orm工具,haibernate或许就该退役了...
返回顶楼
你可以使用mysql proxy在数据库层实现,对应用是透明的。
我刚才很仔细的阅读了MySQL Proxy的文档,非常赞叹!另外我发现,MySQL Proxy的作者原来就是lighttpd的作者,难怪MySQL Proxy很多功能和lighttpd看起来那么似曾相识。MySQL Proxy做的很棒,用lua编写分发逻辑,实现读写分离也很酷,相信等MySQL Proxy正式发布以后,所有的MySQL用户,特别是用MySQL来跑大流量网站的用户都会欢欣鼓舞的。
分享到:
相关推荐
【个人博客】 Java、技术面试必备基础知识、Leetcode、计算机操作系统、计算机网络等_CSLearning
yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
人力资源+大数据+薪酬报告+涨薪调薪,在学习、工作生活中,越来越多的事务都会使用到报告,通常情况下,报告的内容含量大、篇幅较长。那么什么样的薪酬报告才是有效的呢?以下是小编精心整理的调薪申请报告,欢迎大家分享。相信老板看到这样的报告,一定会考虑涨薪的哦。
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
这是一个基于全卷积神经网络的语音识别系统_DFCNN-master
一个可以运行在 vercel 上的 go 语言框架,基于 g
基于一维卷积神经网络(1D-CNN)的多元时间序列分类_TSC-CNN
网鼎杯
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
OrinNX平台JetPack 5.1.4-R35.6.0版本相机相关补丁1
MD5EditTools,MD5修改工具.exe
原文链接:https://blog.csdn.net/zsd12379/article/details/141281454 包含功能: 业主管理:实现业主信息的录入、编辑、查询与删除,确保业主数据的准确性和完整性。 维修员管理:管理维修员的基本信息、工作状态和派工情况,优化维修资源配置。 楼宇信息管理:记录并维护楼宇的基本信息、设施详情及状态,支持快速查询与更新。 业主投诉管理:接收并处理业主的投诉信息,跟踪处理进度,提升业主满意度。 业主报修管理:提供便捷的报修渠道,记录报修详情,实现报修请求的有效管理。 报修处理管理:分配报修任务给维修员,跟踪报修进度,确保报修问题及时解决。 缴费信息管理:管理业主的缴费记录,包括物业费、维修基金等,支持费用查询与提醒。 建议反馈管理:收集业主的建议与反馈,促进物业服务的持续改进和优化。
<项目介绍> - 该项目是为了研究基于深度卷积神经网络的图像去噪算法,是利用DnCNN模型,但是为了比较该算法的效果,另外实现了四种传统的图像去噪算法(均值滤波、中值滤波、非局部均值滤波NLM和三维块匹配滤波BM3D)作为对照组 - 不懂运行,下载完可以私聊问,可远程教学 该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------
2023-04-06-项目笔记-第三百零三阶段-课前小分享_小分享1.坚持提交gitee 小分享2.作业中提交代码 小分享3.写代码注意代码风格 4.3.1变量的使用 4.4变量的作用域与生命周期 4.4.1局部变量的作用域 4.4.2全局变量的作用域 4.4.2.1全局变量的作用域_1 4.4.2.301局变量的作用域_301- 2024-10-31
那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据
High_net_worth.dta