基于etcd的分布式配置中心 etcd docs | etcd versus other key-value stores https://etcd.io/docs/v3.4.0/learning/why/ The name "etcd" originated from two ideas, the unix "/etc" folder and "d"istributed systems. The "/etc" folder…
来源:naughty 链接:my.oschina.net/taogang/blog/410864 笔者之前的博文提到过,随着大数据时代的到来,分布式是解决大数据问题的一个主要手段,随着越来越多的分布式的服务,如何在分布式的系统中对这些服务做协调变成了一个很棘手的问题.今天我们就来看看如何使用Python,利用开源对分布式服务做协调. 在对分布式的应用做协调的时候,主要会碰到以下的应用场景: 业务发现(service discovery) 找到分布式系统中存在那些可用的服务和节点 名字服务 (na…
这篇博文是探索三个分布式.一致性键值数据存储软件性能的系列文章中的第一篇:etcd.Zookeeper和Consul,由etcd团队所写,可以让我们全面地了解如何评估三个分布式一致存储软件的性能.翻译过程中难免有误差,还请大家谅解 一致性键值存储的用处 许多现代分布式应用程序都建立在分布式一致键值存储之上.Hadoop生态系统中的应用程序和“Netflix栈”的许多部分都使用Zookeeper.Consul公开了服务发现和运行状况检查API,并支持Nomad等集群工具.Kubernetes容器编…
CAP 定理CAP定理:CAP定理又称CAP原则,指的是在一个分布式系统中,一致性(Consistency).可用性(Availability).分区容错性(Partition tolerance).CAP 原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾. 一致性(C):在分布式系统中的所有数据备份,在同一时刻是否同样的值.(等同于所有节点访问同一份最新的数据副本) 可用性(A):在集群中一部分节点故障后,集群整体是否还能响应客户端的读写请求.(对数据更新具备高可用性) 分区容忍性(…
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina.com 目录 目录MMKV基本使用支持的数据类型SharedPreferences 迁移MMKV 组件现在开源了MMKV 源起MMKV 原理MMKV for Android 特有功能MMKV 使用Android 快速上手SharedPreferences 迁移MMKV 性能iOS 性能对比Andr…
本文基本上摘自纯洁的微笑的博客 http://www.ityouknow.com/springcloud/2018/07/20/spring-cloud-consul.html . 感谢作者的付出. =============================服务注册基础组件选择=============================在服务注册这个环节, 业界有很多组件可供选择, 主要有:1. Spring Cloud Eureka Spring Cloud Eureka 是 Spring Cl…
ZooKeeper和Etcd的主要异同可以参考这篇文章,此外,Etcd的官网上也有对比表格(https://coreos.com/etcd/docs/latest/learning/why.html),本文不加赘述. 本文主要关注这两者在watch上的功能差异.ZooKeeper和Etcd都可以对某个key进行watch,并在当这个key发生改变(比如有更新值,或删除key的操作发生)时触发. ZooKeeper的watch ZooKeeper的watch功能可参考其官网文档 但是光看文档不足以…
写在前面 经过前面三篇关于.NET Core Configuration的文章之后,本篇文章主要讨论如何扩展一个Configuration组件出来.如果前面三篇文章没有看到,可以点击如下地址访问 .NET Core 3.0之深入源码理解Configuration(一) .NET Core 3.0之深入源码理解Configuration(二) .NET Core 3.0之深入源码理解Configuration(三) 了解了Configuration的源码后,再去扩展一个组件就会比较简单,接下来我们…
Oracle 数据存取组件(ODAC) 库为Borland Delphi,C++ Builder 以及 Kylix提供了一些非可视化的组件.它们用来存取Oracle关系数据库系统.与BDE类似, ODAC 也是一种可供选择的处理数据的方法之一. ODAC 直接使用 Oracle 调用接口 (OCI). OCI 是一种允许应用程序开发人员使用第三方开发语言存取Oracle数据服务器的过程或函数以及控制所有的SQL语句执行状态的应用程序接口(API). OCI 通过一个动态运行库(ORA*.DLL)…
zookeeper提供了两个库,zookeeper_st和 zookeeper_mt. 前者是单线程库,仅仅提供了异步API和集成在应用程序实现循环中的回调函数,这个库是为了支持pthread库不支持或者不稳定的系统而存在的.使用过程中要自己通过zoo_interest和zoo_process实现事件处理及通知机制. 其他情况下应该使用后者多线程库.因为它同时支持同步和异步API.使用起来也方便很多,可以看我的例子. The package includes two shared librari…