减少db 连接数压力
热重启配置
可水平扩容
遵守Mysql原生协议
无语言限制,mysqlclient,c,java等都可以使用
Heisenberg服务器通过管理命令可以查看,如连接数,线程池,结点等,并可以调整
采用velocity的分库分表脚本进行自定义分库表,相当的灵活
之前在组里有做过简单的分享,这段时间稍微轻松了点,先分享出来,看有没有更好的idea在这块有所提升
下面开始介绍heisenberg
1.heisenberg总体架构
首先这块架构:
应用对于heisenberg集群来说就是mysql客户端,
而heisenberg也是集成了mysql的原生协议,所以对于应用来说,就相当于单库单表的数据源
无论是mysql客户端,c,jdbc驱动等都可以访问heisenberg服务器,由服务器把分库分表的工作给做掉了
访问heisenberg集群可以通过像lvs,F5等负载软件/设备解决,
其实一台heisenberg的性能是相当的赞了,我压力到2320TPS load 都还只有0.1-0.3左右(CPU 8core,16G),由于找不到mysql物理机器了,只得做罢
服务端内部结构:
你需要怎么分?因为数据表太大影响性能了?建议直接分表数据,性质和mysql分区差不多,例如:把某个范围内的id的记录拷贝至另外的库,
这样就实现大表变小表,当然,程序上也需要改动
用sql语句就行了开始→运行→输入cmd,进入命令行模式,把目录切换到数据库bin目录下
mysqldump -u 用户名 -p 密码 --database 数据库名 >D:abc.sql
创建一个数据库,名字和原来的相同。
mysql -u 用户名 -p 密码 --database 数据库名 <D:abc.sql
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)