1.MycatåMySQLçåºå«
2.mycat 高可用
3.JAVA云HIS医院管理系统源码:可医保对接的码下云HIS运维平台源码 SaaS模式
4.小米开源数据库中间件Gaea实战
MycatåMySQLçåºå«
MycatåMySQLçåºå«ï¼
å¯ä»¥æä¸å±çä½æ¯å¯¹ä¸å±çæ½è±¡ï¼ä¾å¦æä½ç³»ç»æ¯å¯¹å类计ç®æºç¡¬ä»¶çæ½è±¡ãé£ä¹æ们ä»ä¹æ¶åéè¦æ½è±¡ï¼åå¦åªæä¸ç§ç¡¬ä»¶çæ¶åï¼æ们éè¦å¼åä¸ä¸ªæä½ç³»ç»åï¼
åæ¯å¦ä¸ä¸ªé¡¹ç®åªéè¦ä¸ä¸ªäººå®æçæ¶åä¸éè¦leaderï¼ä½æ¯å½éè¦å å人å®ææ¶ï¼å°±åºè¯¥æä¸ä¸ªç®¡çè ï¼åæ¥æ²éåè°çä½ç¨ï¼èè¿ä¸ªç®¡çè 对äºä»çä¸å±æ¥è¯´å°±æ¯å¯¹é¡¹ç®ç»çæ½è±¡ã
åæ ·çï¼å½æ们çåºç¨åªéè¦ä¸å°æ°æ®åºæå¡å¨çæ¶åæ们并ä¸éè¦Mycatï¼èå¦æä½ éè¦ååºçè³å表ï¼è¿æ¶ååºç¨è¦é¢å¯¹å¾å¤ä¸ªæ°æ®åºçæ¶åï¼è¿ä¸ªæ¶åå°±éè¦å¯¹æ°æ®åºå±åä¸ä¸ªæ½è±¡ï¼æ¥ç®¡çè¿äºæ°æ®åºï¼èæä¸é¢çåºç¨åªéè¦é¢å¯¹ä¸ä¸ªæ°æ®åºå±çæ½è±¡æè 说æ°æ®åºä¸é´ä»¶å°±å¥½äºï¼è¿å°±æ¯Mycatçæ ¸å¿ä½ç¨ã
æ以å¯ä»¥è¿æ ·ç解ï¼æ°æ®åºæ¯å¯¹åºå±åå¨æ件çæ½è±¡ï¼èMycatæ¯å¯¹æ°æ®åºçæ½è±¡ã
mycat 高可用
mycat 高可用
mycat 可通过 zookeeper 集群进行配置文件管理。
1.1 搭建 zookeeper 集群
此处不做 zookeeper集群搭建讲解
1.2 配置mycat支持zookeeper
修改 mycat conf 目录下myid.properties
loadZk=true # zk集群地址,码下多个用",码下"隔开 zkURL=..3.:,..3.:,..3.: # zk集群内Mycat集群ID clusterId=mycat-cluster-1 # Mycat集群内本实例ID,禁止重复 myid=mycat_fz_ # Mycat集群内节点个数 clusterSize=3 #集群内所有节点的码下 id clusterNodes=mycat_fz_,mycat_fz_,mycat_fz_ #server booster ; booster install on db same server,will reset all minCon to 1 type=server boosterDataHosts=dataHost1
1.3 自定义配置
将需要修改的配置文件替换到 conf 目录中的 zkconf 目录下,只需要在一台机器修改即可,需要注意 conf目录中的 server.xml 中用户名和密码与 zkconf 中的不一致
1.4 上传配置
执行修改了配置文件的 mycat 下的bin 目录下的initzkdata.sh,上传配置文件,(在修改了配置文件的机器上执行)
./initzkdata.sh
1.5 启动所有 mycat
启动后发现其他 mycat conf 下的配置文件已经自动变化为修改的内容,是zookeeper 中下载的
2. 使用的是 lvs+keepalived 的方式
此处使用的是 lvs+keepalived 的方式实现mycat高可用负载均衡集群
2.1 配置环境
角色 主机IP 主机名 操作系统版本 软件版本
VIP ..3.
LVS-DR-Master ..3. keepalived CentOS6.9 Keepalived v1.2.,LVS 1.2.1
LVS-DR-Backup ..3. keepalived CentOS6.9 Keepalived v1.2.,码下LVS 1.2.1
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
2.2 安装keepalived和ipvsadm
注意:ipvsadm并不是码下超级模块源码lvs,它只是码下lvs的配置工具。在 CentOS1.1 的码下内核版本中是默认支持的。因此,码下这里不需要重新安装。码下使用 yum 的码下安装方式,分别在 keepalived 和 keepalived 两台主机上安装 keepalived 和 ipvsadm。码下除了这种简易方式外,码下也可直接编译官方的码下源码包。安装步骤可参考文档。码下
2.3 配置Keepalived
2.3.1 master
vi /etc/keepalived/keepalived.conf
配置详细内容如下,注意优先级、状态、接口、橙源码虚拟IP地址、负载调度算法、服务器节点配置、检查间隔、会话保持时间、协议类型等参数设置。
2.3.2 backup
备份机配置与主机一致,除了优先级和状态修改外。
在配置文件中,特别需要注意的是interface的修改,根据实际情况进行相应的修改。
2.4 安装配置 mycat
安装mycat请参考相关文档。
2.4.1 绑定虚拟 vip
在mycat服务器上为lo:0绑定VIP地址、抑制ARP广播。
执行脚本./realserver.sh start在mycat和mycat、mycat三台主机上。
2.4.2 查看
运行 ifconfig 查看结果。
2.5 启动 keeplive
分别在keepalived和keepalived上启动Keepalived服务。硕源码
2.5.1 查看
通过ipvsadm -L 查看映射。
2.5.2 测试
通过一台装有 mysql的机器连接虚拟 ip 发现可以登录数据库。
2.5.3 查看转发
再次在 keepalived 的机器执行ipvsadm -L,发现被转到上面一次。
2.5.4 负载均衡方式
与配置相关,多次都指向一个机器,因为我们在 keepalived 的配置文件中persistence_timeout属性指定为,则代表秒内同一个机器来的请求会被 hash 一致性分配。如果想实现严格意义上面的轮询,修改为0即可。
JAVA云HIS医院管理系统源码:可医保对接的云HIS运维平台源码 SaaS模式
云HIS是专门为中小型医疗健康机构设计的云端诊所服务平台,提供内部管理、临床辅助决策、体检、客户管理、健康管理等全面解决方案。系统集成了多个大系统和子模块,助力诊所和家庭医生在销售、管理和服务等方面提升效率。aide 源码
基于SaaS模式的Java版云HIS系统,在公立二甲医院应用三年,经过多轮优化,运行稳定、功能丰富,界面布局合理,操作简单。
系统融合B/S版电子病历系统,支持电子病历四级,拥有自主知识产权。
技术细节方面,前端采用Angular+Nginx,后台使用Java+Spring、SpringBoot、SpringMVC、SpringSecurity、MyBatisPlus等技术。数据库为MySQL + MyCat,eclipse源码导入缓存为Redis+J2Cache,消息队列采用RabbitMQ,任务调度中心为XxlJob。接口技术包括RESTful API、WebSocket和WebService,报表组件为itext、POI和ureport2,数据库监控组件为Canal。
云HIS系统对接医保流程包括准备阶段、技术对接阶段、业务协同阶段和后续维护与优化阶段。在准备阶段,需了解医保政策和要求,准备系统环境。在技术对接阶段,确定接口规范,开发医保接口,并进行测试和验证。在业务协同阶段,实现业务流程对接和数据同步。在后续维护与优化阶段,监控与故障处理,政策更新与适配,安全与保密工作。
云HIS系统具有成本节约、高效运维、安全可靠和政策支持等优势,为医疗机构提供便捷、高效的医保服务。无论是大型三甲医院、连锁医疗集团还是中小型医疗机构,云HIS都是实现高效低成本云计算的最佳选择。
小米开源数据库中间件Gaea实战
本文基于dbaplus社群第期线上分享整理。
Gaea,作为一款MySQL数据库中间件,兼容MyCAT核心特性,提供读写分离、分库分表等功能。选择使用Go语言实现,考虑到Go语言在编写网络应用方面的易用性、可靠性,以及公司内部以Go语言生态为主的技术体系。
Gaea实现MySQL协议,将自己伪装成一个MySQL服务器,应用程序通过MySQL客户端访问Gaea,向Gaea发起SQL请求,Gaea将请求转发至后端MySQL执行,再将响应结果返回给客户端。中间件有助于集中管理用户和数据库配置信息,减轻DBA的运维负担。
Gaea抽象出namespace、user、slice等概念,其中namespace对应业务,是资源划分的基本单位;user等同于MySQL用户,通过username和password连接至Gaea;slice对应MySQL实例资源,包含主库与从库,实现读写分离;namespace中可包含多个slice,通过制定路由规则实现分库分表。
Gaea配置信息管理由Proxy、CC(中控服务)与Web(管理控制台)三部分组成。Proxy负责MySQL流量接入,CC通过管理接口与Proxy交互进行配置管理和下发。Web提供可视化管理界面,用于DBA管理配置信息和开发工程师查看。配置数据存储在etcd中,Gaea CC与Proxy通过etcd进行交互。
Gaea主要功能包括快速使用、连接安装与配置、启动Proxy、发送请求、查看监控等。使用简单,源码编译需go 1.,使用go module管理依赖。启动Proxy需配置文件,包括监听端口、日志路径等。发送请求时,使用用户名和密码连接Gaea,执行SQL操作。Gaea提供监控指标,包括SQL请求指标与机器层面指标,方便问题排查与监控。
Gaea整体架构包含协议解析、会话管理、SQL解析、路由调度与SQL执行等模块。支持MySQL文本协议与二进制prepare协议,SQL执行使用TiDB解析器,配置热加载实现在线修改配置,无需重启。
性能测试显示,在点查询场景下,Gaea Proxy性能比MyCAT高约%左右。Gaea项目已开源,地址为github.com/XiaoMi/Gaea,欢迎试用、贡献代码与提供反馈。