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 学习笔记(二)相关推荐

  1. qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)

    原博主博客地址:http://blog.csdn.net/qq21497936 本文章博客地址:http://blog.csdn.net/qq21497936/article/details/7851 ...

  2. [转载]dorado学习笔记(二)

    原文地址:dorado学习笔记(二)作者:傻掛 ·isFirst, isLast在什么情况下使用?在遍历dataset的时候会用到 ·dorado执行的顺序,首先由jsp发送请求,调用相关的ViewM ...

  3. PyTorch学习笔记(二)——回归

    PyTorch学习笔记(二)--回归 本文主要是用PyTorch来实现一个简单的回归任务. 编辑器:spyder 1.引入相应的包及生成伪数据 import torch import torch.nn ...

  4. tensorflow学习笔记二——建立一个简单的神经网络拟合二次函数

    tensorflow学习笔记二--建立一个简单的神经网络 2016-09-23 16:04 2973人阅读 评论(2) 收藏 举报  分类: tensorflow(4)  目录(?)[+] 本笔记目的 ...

  5. Scapy学习笔记二

    Scapy学习笔记二 Scapy Sniffer的用法: http://blog.csdn.net/qwertyupoiuytr/article/details/54670489 Scapy Snif ...

  6. Ethernet/IP 学习笔记二

    Ethernet/IP 学习笔记二 原文链接:http://wiki.mbalib.com/wiki/Ethernet/IP 1.通信模式 不同于源/目的通信模式,EtherNet/IP 采用生产/消 ...

  7. Java学习笔记二:数据类型

    Java学习笔记二:数据类型 1. 整型:没有小数部分,允许为负数,Java整型分4种:int short long byte 1.1 Int最为常用,一个Int类型变量在内存中占用4个字节,取值范围 ...

  8. 吴恩达《机器学习》学习笔记二——单变量线性回归

    吴恩达<机器学习>学习笔记二--单变量线性回归 一. 模型描述 二. 代价函数 1.代价函数和目标函数的引出 2.代价函数的理解(单变量) 3.代价函数的理解(两个参数) 三. 梯度下降- ...

  9. ASP.NET MVC 2 学习笔记二: 表单的灵活提交

    ASP.NET MVC 2 学习笔记二:  表单的灵活提交 前面说到有做到公司内部的一个请假系统,用的是ASP.NET MVC 2+Entity Framework.虽然EF(Entity Frame ...

  10. amazeui学习笔记二(进阶开发4)--JavaScript规范Rules

    amazeui学习笔记二(进阶开发4)--JavaScript规范Rules 一.总结 1.注释规范总原则: As short as possible(如无必要,勿增注释):尽量提高代码本身的清晰性. ...

最新文章

  1. 互联网大厂内推求职的正确姿势?
  2. python库--tensorflow--RNN(循环神经网络相关)
  3. Delphi 与 DirectX 之 DelphiX(35): TDIB.Saturation();
  4. linux默认开启sudo_Sudo漏洞允许非特权Linux和macOS用户以root身份运行命令
  5. Java中常见的十八种异常!
  6. java 生成校验验证码_java生成验证码并进行验证
  7. 烂泥:CentOS命令学习之scp复制
  8. Firefox 火狐网址生成二维码扩展推荐
  9. llinux 查看自己的公网ip
  10. html语言设计表单实例,40多个漂亮的网页表单设计实例_HTML/Xhtml_网页制作
  11. 解决主机ping不通xp虚拟机
  12. 我要多开梦幻手游PC端(梦幻手游PC端多开的简单分析及实现办法)
  13. 神经网络中的单层神经网络
  14. 计算机司法鉴定的程序,计算机司法鉴定的流程说明
  15. IDEA隐藏不想看见的文件
  16. 微信小程序开发 网络异常监听
  17. 4234最小差值生成树
  18. 7-1 循环-Fibonacci数列的运算 (50 分)
  19. python掷骰子实验代码_Python Tkinter实例——模拟掷骰子
  20. android 读写文件 简书,Android写入txt文件并读取

热门文章

  1. 托福100分什么水平
  2. Js高级单利模式理论模型
  3. S3C2440之IIC裸机驱动
  4. C/C++代码混淆器
  5. 在WinServer上安装小红伞杀毒软件的经验总结
  6. python学习(一)
  7. js 中断函数执行_javascript 终止函数执行操作
  8. 计算机软件技术有哪些,1.1 什么是计算机软件技术
  9. Html网页设计-羽毛球网站设计
  10. Flume介绍和使用