Erlang与Elixir:特性、对比与应用
1. Erlang简介
Erlang使用少量操作系统线程,并发完全由Erlang调度器处理,系统具有可扩展性、响应性和容错性。由于它作为单个项目实现,因此更易于管理、部署,也可在开发机器上本地运行。
需要注意的是,Erlang工具并非总是主流解决方案(如NGINX这样的Web服务器、MongoDB这样的数据库服务器、Redis这样的内存键值存储)的全面替代方案。但Erlang提供了选择,你可以先用Erlang实现初始解决方案,在Erlang方案不足时再采用其他技术。这使得整个系统更加统一,更易于开发和维护。
此外,Erlang并非孤立存在。它可以运行用C、C++或Rust等语言编写的进程内代码,并能与外部组件(如消息队列、内存键值存储和外部数据库)进行通信。所以,选择Erlang并不意味着不能使用现有的第三方技术,你可以在需要时使用它们,而不是因为主要开发平台没有解决问题的工具。
2. Erlang开发平台
Erlang不仅仅是一种编程语言,它是一个完整的开发平台,由四个不同部分组成:语言、虚拟机、框架和工具。
- 语言 :是编写在Erlang虚拟机中运行代码的主要方式。它是一种简单的函数式语言,具有基本的并发原语。用Erlang编写的源代码会被编译成字节码,然后在BEAM中执行。
- 虚拟机(BEAM) :并行处理并发的Erlang程序,负责进程隔离、分布式处理和系统的整体响应性。
- 框架(OTP) :即Open Telecom Platform
超级会员免费看
订阅专栏 解锁全文
67

被折叠的 条评论
为什么被折叠?



