netty权威指南 (2-netty入门)

in JAVA  |  update on
netty入门netty服务端和客户端开发服务端主流程123456789101112131415161718192021222324// 配置服务端Reactor线程组// 一个用于服务端接受客户端的连接EventLoopGroup bossGroup = new NioEventLoopGroup();// 用于进行SocketChannel的网络读写EventLoopGroup workerG...
Continue reading

netty权威指南 (3-TCP粘包拆包问题)

in JAVA  |  update on
TCP粘包拆包问题TCP粘包/拆包TCP粘包/拆包问题说明假设客户端分别发送了两个数据包Dl和D2给服务端,由于服务端一次读取到的字节数是不确定的,故可能存在以下5种情况。 服务端分两次读取到了两个独立的数据包,分别是D1和D2,没有粘包和拆包 服务端一次接收到了两个数据包,D1和D2粘合在一起,被称为TCP粘包 服务端分两次读取到了两个数据包,第一次读取到了完整的D1包和D2包的部分内容,...
Continue reading

netty权威指南 (4-解码器)

in JAVA  |  update on
解码器LineBasedFrameDecoderLineBasedFrameDecoder的工作原理足它依次遍历ByteBuf中的可读字节,判断看是否有“\n”或者“\r\n”,如果有,就以此位置为结束位置,从可读索引到结束位置区间的字节就组成了一行。它是以换行符为结束标志的解码器,支持携带结束符或者不携带结束符两种解码方式,同时支持配置单行的最大长度。如果连续读取到最大长度后仍然没有发现换行符,...
Continue reading

从Paxos到ZooKeeper (1-分布式架构)

in 分布式  |  update on
分布式架构分布式的特点分布式系统是一个硬件或软件组件分布在不同的网络计算机上,彼此之间仅仅通过消息传递进行通信和协调的系统。 分布性 对等性 并发性 缺乏全局时钟 故障总是会发生 分布式环境的各种问题 通信异常 单机内存访问的延时在纳秒数量级(通常是10ns左右),而正常的一次网络通信的延迟在0.1〜1ms左右(相当于内存访问延时的105〜106倍) 网络分区 当网络由于发生异...
Continue reading

从Paxos到ZooKeeper (4-ZooKeeper与Paxos)

in 分布式  |  update on
ZooKeeper与PaxosZooKeeper介绍ZooKeeper并没有直接采用Paxos算法,而是采用了一种被称为ZAB(ZooKeeper Atomic Broadcast)的一致性协议。 ZooKeeper是一个典型的分布式数据一致性的解决方案,分布式应用程序可以基于它实现诸如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、Master选举、分布式锁和分布式队列等功能。Z...
Continue reading

从Paxos到ZooKeeper (6-ZooKeeper的典型应用场景)

in 分布式  |  update on
ZooKeeper的典型应用场景ZooKeeper是一个典型的发布/订阅模式的分布式数据管理与协调框架,开发人员可以使用它来进行分布式数据的发布与订阅。另一方面,通过对ZooKeeper中丰富的数据节点类型进行交叉使用,配合Watcher事件通知机制,可以非常方便地构建一系列分布式应用中都会涉及的核心功能,如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、Master选举、分布式锁...
Continue reading

从Paxos到ZooKeeper (2-一致性协议)

in 分布式  |  update on
一致性协议为了解决分布式一致性问题,在长期的探索研究过程中,涌现出了一大批经典的一致性协议和算法,其中最著名的就是二阶段提交协议、三阶段提交协议和Paxos算法了。 2PC (Two-Phase Commit)二阶段提交协议是将事务的提交过程分成了两个阶段来进行处理 优点:原理简单,实现方便。 缺点:同步阻塞、单点问题、脑裂、太过保守。 同步阻塞 二阶段提交协议存在的最明显也是最大的一个问...
Continue reading

微服务设计 (1-微服务)

in 分布式  |  update on
微服务领域驱动设计 : 用代码呈现真实世界的重要性,并且告诉我们如何更好地进行建模 持续交付理论 : 告诉我们如何更有效及更高效地发布软件产品,并指出保持每次提交均可发布的重要性 六边形架构理论 : 参考:http://www.cnblogs.com/Leo_wl/p/4418663.html 什么是微服务微服务就是一些协同工作的小而自治的服务。 服务应该多小 微服务将单一职责原则应用在独立的...
Continue reading

分布式服务框架-原理与实践 (3-通信框架)

in 分布式  |  update on
通信框架关键技术点分析长连接还是短连接绝大多数的分布式服务框架(RPC框架)都推荐使用长连接进行内部通信,为什么选择长连接而不是短连接呢? 相比于短连接,长连接更节省资源 远程通信是常态,调用时延是关键指标 功能设计可靠性设计链路有效性检测心跳检测机制分为三个层面: TCP层面的心跳检测,即TCP的FCeep-Alive机制,它的作用域是整个TCP协议栈。 协议层的心跳检测,主要存在于...
Continue reading

微服务设计 (10-康威定律和系统设计)

in 分布式  |  update on
康威定律和系统设计康威定律 任何组织在设计一套系统(广义概念上的系统)时,所交付的设计方案在结构上都与该组织的沟通结构保持一致。 松耦合组织和紧耦合组织紧耦合组织的一个例子是商业产品公司,他们的员工都在一起工作,并有着一致的愿景和目标;而松耦合组织的典型代表是分布式开源社区。 组织的耦合度越低,其创建的系统的模块化就越好,耦合也越低;组织的耦合度越高,其创建的系统的模块化也越差。 服务所有权服务所...
Continue reading

srzyhead

Progress is the activity of today and the assurance of tomorrow.


Web Developer


Tianjin,China