博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】diamond专题(三)—— diamond架构
阅读量:5940 次
发布时间:2019-06-19

本文共 882 字,大约阅读时间需要 2 分钟。

特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过。如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:

大家好,这次为大家带来的是diamond的架构

说明:

1、作为一个配置中心,diamond的功能分为发布和订阅两部分。因为diamond存放的是持久数据,这些数据的变化频率不会很高,甚至很低,所以发布采用手工的形式,通过diamond后台管理界面发布;订阅是diamond的核心功能,订阅通过diamond-client的API进行。

2、diamond服务端采用mysql加本地文件的形式存放配置数据。发布数据时,数据先写到mysql,再写到本地文件;订阅数据时,直接获取本地文件,不查询数据库,这样可以最大程度减少对数据库的压力。

3、diamond服务端是一个集群,集群中的每台机器连接同一个mysql,集群之间的数据同步通过两种方式进行,一是每台server定时去mysqldump数据到本地文件,二是某一台server接收发布数据请求,在更新完mysql和本机的本地文件后,发送一个HTTP请求(通知)到集群中的其他几台server,其他server收到通知,去mysql中将刚刚更新的数据dump到本地文件。

4、每一台server前端都有一个nginx,用来做流量控制。

5、图中没有将地址服务器画出,地址服务器是一台有域名的机器,上面运行有一个HTTPserver,其中有一个静态文件,存放着diamond服务器的地址列表。客户端启动时,根据自身的域名绑定,连接到地址服务器,取回diamond服务器的地址列表,从中随机选择一台diamond服务器进行连接。

可以看到,整个diamond的架构非常简单,使用的都是最常用的一些技术以及产品,它之所以表现得非常稳定,跟其架构简单是分不开的,当然,稳定的另一个主要原因是它具备一套比较完善的容灾机制,容灾机制将在下一篇文章中讲述。

原文地址:

转载于:https://www.cnblogs.com/mao2080/p/7223641.html

你可能感兴趣的文章
phonegap+jquerymobile开发android的心得(6)
查看>>
TLD文件中body-content四种类型(能力工场)
查看>>
一门杀人于无形的艺术——>社会工程
查看>>
Hyper-V 3.0部署PART 14:准备仲裁磁盘
查看>>
CentOS 7.0系统安装配置图解教程
查看>>
zabbix监控系统的安装与配置
查看>>
Linux下杀毒软件Clamav的安装和使用
查看>>
CentOS6.5上源码安装MongoDB3.2.1
查看>>
centos5.8 安装配置vsftp虚拟用户
查看>>
海量大数据处理最新面试题-1
查看>>
dubbo学习之dubbo管理控制台装配及集成zookeeper集群部署(1)【转】
查看>>
APKTOOL编译出现“entry index is larger than available symbols” <index ,total symbols> 的研究...
查看>>
高拍仪是否支持TWAIN方式的测试方法
查看>>
Jquery加载dom元素
查看>>
VIM 命令使用大全
查看>>
MYSQL注入
查看>>
Linux 命令 sudo 用法及配置解析
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
VS2010没有Intellisense(智能感知)的解决办法
查看>>