接触了一些采用Linux/Unix工具的架构的应用以后,我发现我越来越喜欢松散的架构。即除了接口(UI),然后是算法,最后是面向领域的工具或DSL。而Microsoft的架构大都反其道而行之,原因是:Microsoft想让使用者用起来更傻瓜化,但是否能达到目的就不一定了。

对于数据交换的接口(Interface)层面,尽量用同通用的数据格式,如果是函数调用就用string,char,int之类的,如果是文件就用Plain Text或者其他Human-Readable的格式。

松散架构的有点主要有两个:

1,最小化关注点

2,面向领域(问题域)来解决问题

1,最小化关注点

实现最小化关注的前提是:简单,通用数据格式,协议。在同一个时刻只解决一个问题。而这时接口,协议不能成为解决问题的累赘。还有就是适当的拆分问题,问题的拆分取决于问题域。而不是业务的解决方案域。Linux/Unix工具本身这点做的就很好,拆分的很干净。而这反过来就会促进问题的划分。通过适当拆分,简单通用数据格式,我们只解决该解决的问题——而不是因为解决方案而引入的问题,比如:数据转换,数据传输对象,阻抗匹配等等。

2,面向问题域解决问题

也就是采用面向领域的解决方案解决领域内的问题。采用合适的Unix工具:文本处理用Awk,Sed,Regular Expression;网络获取用wget;查找文件或过滤用grep,find;自动化处理用Bash Scripting或者Ruby/Python等等。总之我们总能够找到一个非常容易处理领域问题的语言或工具,不多不少地解决当前问题。

通过松散的架构,最终得到的应用看上去没有Microsoft的巨无霸强壮,但实际上坚强无比。还有一个不那么明显但却非常重要的优点是这种架构可以Evolution,随着时间的推移这种架构容易调整成面向领域的架构,不多不少地解决架构该解决的问题,多的把他裁掉,少的把他补上。之所以可这样是因为架构是松散的,不是谁一定要谁依赖于谁,不离不弃对爱情是好的,对架构来说是种灾难。

转载于:https://www.cnblogs.com/Jerry-Chou/archive/2012/02/06/2339762.html

松散架构(Loosely Coupled Architecture)相关推荐

  1. Building Loosely Coupled and Scalable RESTful Services using Orleans

    These days, I'm working on Orleans and Actor-based systems as I mentioned in my post titled "Ov ...

  2. go 微服务框架_清晰架构(Clean Architecture)的Go微服务

    更新 我最进对这个框架进行了重大升级,虽然所做的改动不大,但成效显著.这次更新修复了旧框架中的所有主要问题,尽管它的的主要项目结构和接口都没有改变,具体改动内容请参见清晰架构(Clean Archit ...

  3. 神经架构搜索(Neural Architecture Search,NAS)介绍

    神经架构搜索Neural Architecture Search,NAS介绍 Introduction Intractable Search Space Non transferable optima ...

  4. 15支持哪些数据库版本 tfs_TFS数据库架构(TFS Database Architecture)

    TFS数据库架构(TFS Database Architecture) 我正在为可以使用TFS对象模型的应用程序构建后端. 到目前为止,我有一个简单的设计,有两个表. 让我们说dbo.Users ,而 ...

  5. 微服务架构(Microservice Architecture)

    之前一段时间,有听部门架构说起接下来公司要使用微服务架构来研发系统,当时没怎么在意,因为是第一次听说微服务这个名词(果然无知者无畏啊):正好赶上五一假,我自告奋勇的,接了编写微服务架构培训文档这个任务 ...

  6. 清晰架构(Clean Architecture)的Go微服务: 程序设计

    我使用Go和gRPC创建了一个微服务,并将程序设计和编程的最佳实践应用于该项目. 我写了一系列关于在项目工作中做出的设计决策和取舍的文章,此篇是关于程序设计. 程序的设计遵循清晰架构(Clean Ar ...

  7. 清晰架构(Clean Architecture)的Go微服务: 程序容器(Application Container)

    清晰架构(Clean Architecture)的一个理念是隔离程序的框架,使框架不会接管你的应用程序,而是由你决定何时何地使用它们.在本程序中,我特意不在开始时使用任何框架,因此我可以更好地控制程序 ...

  8. OpenStack概念结构与逻辑架构:Conceptual architecture and Logical architecture

    目录 Get started with OpenStack The OpenStack services The OpenStack architecture Conceptual architect ...

  9. OpenStack Glance(镜像服务)基础架构:Basic architecture

    https://docs.openstack.org/glance/pike/contributor/architecture.html OpenStack Glance has a client-s ...

最新文章

  1. ASP.NET 内置对象
  2. 设置EditText光标颜色
  3. gunicorn之日志详细配置
  4. struct output SVM
  5. Ubuntu 安装配置NFS网络文件系统服务器
  6. 梦世界服务器修改指令,我的世界梦世界有哪些指令必须知道 梦世界所有必须知道指令汇总...
  7. Linux学习:文件描述符相关函数
  8. C# Bitmap类型与Byte[]类型相互转化
  9. 底层框架_你有必要了解一下Flink底层RPC使用的框架和原理
  10. http://www.tldp.org/LDP/abs/abs-guide.txt.gz
  11. amd sata controller下载_AMD发布全新锐龙芯片组驱动:告别卡死、报错
  12. 纸牌三角形(蓝桥杯)
  13. java怎么检测代码安全_foritfy代码安全审计、foritfy代码检测服务、java代码安全审计检测、C/C++语言代码安全审计检测...
  14. WaitForSingleObject的使用
  15. Iocomp ActiveX v5 SP6 带OPC -Crack
  16. 98道常见Hadoop面试题及答案解析
  17. (Spring+SpringMVC+mybatis)SSM企业职工工资管理系统
  18. 精益产品开发—精益思想
  19. 跟着鹏哥学C语言第一天
  20. 小程序开发如何租用服务器

热门文章

  1. 达观数据中标国信证券文档智能审阅项目
  2. SparkSQL in中使用子查询耗时高如何优化
  3. 34k*16 薪,3年自动化测试历经3轮面试成功拿下华为Offer....
  4. 在Unity中使用FFmpeg将视频绿色背景处理为透明背景
  5. 【华人学者风采】赵军 中国科学院自动化所
  6. 如何用 Redis 查询 “附近的人” ?
  7. “/”应用程序中的服务器错误的解决办法
  8. 个人记录:enforce fail at /pytorch/third_party/gloo/gloo/transport/tcp/device.cc:208]
  9. csharp高级练习题:Codewars风格排名系统【难度:4级】--景越C#经典编程题库,不同难度C#练习题,适合自学C#的新手进阶训练
  10. busybox ync.c:(.text.sync_main+0x78): undefined reference to `syncfs' 出错