Elang 学习笔记(二)
erlang的学习也算是告一段落了,要开始实战应用了。
当初学erlang的目的就是用来做DB API的。 可接受 HTTP, TCP, UDP的请求。
根据的erlang的特性,构思了一个初步的架构方案。
如下图所示:
、
其中 Communicator 用来处理各种请求,根据业务逻辑决定 开放 HTTP,TCP,UDP这其中的哪种或者哪几种通信方式。
Communicator也负责处理协议的编码、解码。
其中 Holder 是松耦合的独立进程,用于处理具体的业务逻辑。 可根据使用情况,对某些Holder进行合并处理。 Holder之间也可以通过 IPC或者RPC的方式进行通信,通信协议遵循 erlang OTP默认规范。(gen_server)。
至于Mod1..ModN处理数据的读取,查询。所有Mod都针对单表进行操作,若需要进行联合查询,放在Holder中处理。
数据存储方式:ETS|DETS + MySQL。 目前的存储方式暂定如此。
===================================================
介绍完毕,现在记录下自己为什么这么设计
===================================================
首先,erlang的RPC,IPC是一大特点,而且创建进程开销极小。利用这一特点,可以把单表的存储操作模块看作是 流水线上的一个工人,也就是Mod。 而Holder是各条流水线,一条流水线上可以只有1个Mod进行操作,也可以多个Mod合作操作。 流水线之间也可以有协作关系。
Communicator 不关心具体的业务逻辑操作,只会根据定义的 消息ID 和 Holder中函数的映射,调用Holder中的函数进行业务逻辑处理。
这样设计的优点是所有的业务逻辑够分散,绝对的松耦合,缺点是涉及到多个hodler之间的无序业务逻辑需要在 业务逻辑拆分上进行一定的处理。
总而言之,这个架构只是个初步构想,而且想要应用这个架构达到想要的性能和开发便捷性,需要在业务逻辑的拆分上具备一定的行业经验。 不适合初学者。
转载于:https://www.cnblogs.com/coddingfun/p/3788325.html
Elang 学习笔记(二)相关推荐
- qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)
原博主博客地址:http://blog.csdn.net/qq21497936 本文章博客地址:http://blog.csdn.net/qq21497936/article/details/7851 ...
- [转载]dorado学习笔记(二)
原文地址:dorado学习笔记(二)作者:傻掛 ·isFirst, isLast在什么情况下使用?在遍历dataset的时候会用到 ·dorado执行的顺序,首先由jsp发送请求,调用相关的ViewM ...
- PyTorch学习笔记(二)——回归
PyTorch学习笔记(二)--回归 本文主要是用PyTorch来实现一个简单的回归任务. 编辑器:spyder 1.引入相应的包及生成伪数据 import torch import torch.nn ...
- tensorflow学习笔记二——建立一个简单的神经网络拟合二次函数
tensorflow学习笔记二--建立一个简单的神经网络 2016-09-23 16:04 2973人阅读 评论(2) 收藏 举报 分类: tensorflow(4) 目录(?)[+] 本笔记目的 ...
- Scapy学习笔记二
Scapy学习笔记二 Scapy Sniffer的用法: http://blog.csdn.net/qwertyupoiuytr/article/details/54670489 Scapy Snif ...
- Ethernet/IP 学习笔记二
Ethernet/IP 学习笔记二 原文链接:http://wiki.mbalib.com/wiki/Ethernet/IP 1.通信模式 不同于源/目的通信模式,EtherNet/IP 采用生产/消 ...
- Java学习笔记二:数据类型
Java学习笔记二:数据类型 1. 整型:没有小数部分,允许为负数,Java整型分4种:int short long byte 1.1 Int最为常用,一个Int类型变量在内存中占用4个字节,取值范围 ...
- 吴恩达《机器学习》学习笔记二——单变量线性回归
吴恩达<机器学习>学习笔记二--单变量线性回归 一. 模型描述 二. 代价函数 1.代价函数和目标函数的引出 2.代价函数的理解(单变量) 3.代价函数的理解(两个参数) 三. 梯度下降- ...
- ASP.NET MVC 2 学习笔记二: 表单的灵活提交
ASP.NET MVC 2 学习笔记二: 表单的灵活提交 前面说到有做到公司内部的一个请假系统,用的是ASP.NET MVC 2+Entity Framework.虽然EF(Entity Frame ...
- amazeui学习笔记二(进阶开发4)--JavaScript规范Rules
amazeui学习笔记二(进阶开发4)--JavaScript规范Rules 一.总结 1.注释规范总原则: As short as possible(如无必要,勿增注释):尽量提高代码本身的清晰性. ...
最新文章
- 互联网大厂内推求职的正确姿势?
- python库--tensorflow--RNN(循环神经网络相关)
- Delphi 与 DirectX 之 DelphiX(35): TDIB.Saturation();
- linux默认开启sudo_Sudo漏洞允许非特权Linux和macOS用户以root身份运行命令
- Java中常见的十八种异常!
- java 生成校验验证码_java生成验证码并进行验证
- 烂泥:CentOS命令学习之scp复制
- Firefox 火狐网址生成二维码扩展推荐
- llinux 查看自己的公网ip
- html语言设计表单实例,40多个漂亮的网页表单设计实例_HTML/Xhtml_网页制作
- 解决主机ping不通xp虚拟机
- 我要多开梦幻手游PC端(梦幻手游PC端多开的简单分析及实现办法)
- 神经网络中的单层神经网络
- 计算机司法鉴定的程序,计算机司法鉴定的流程说明
- IDEA隐藏不想看见的文件
- 微信小程序开发 网络异常监听
- 4234最小差值生成树
- 7-1 循环-Fibonacci数列的运算 (50 分)
- python掷骰子实验代码_Python Tkinter实例——模拟掷骰子
- android 读写文件 简书,Android写入txt文件并读取