OTP 23 发布
2020年5月13日 · 作者:Henrik Nord
OTP 23 #
Erlang/OTP 23 是一个包含新功能、改进以及一些不兼容性的新的主要版本。
潜在的不兼容性 #
- SSL: * 完全移除对 SSL 3.0 的支持。
- TLS 1.3 被添加到默认支持的版本列表中。
erl_interface
: 移除erl_interface
中已弃用的部分 (erl_interface.h
以及所有前缀为erl_
的 C 函数)。- 已弃用的
erlang:get_stacktrace/0
BIF 现在返回一个空列表,而不是堆栈跟踪。erlang:get_stacktrace/0
计划在 OTP 24 中移除。
改进和新功能 #
- ssh:
- OpenSSH 6.5 引入了一种新的密钥文件表示形式,称为
openssh-key-v1
。现在支持这种格式,但不包括处理加密密钥。 - 现在可以在 .config 文件中完成算法配置。 例如,这对于启用默认情况下禁用的算法而无需更改代码非常有用。
- SSL:
- 对中间盒兼容模式的支持使得 TLS 1.3 握手看起来更像 TLS 1.2 握手,并增加了通过传统中间盒成功建立 TLS 1.3 连接的机会。
- 添加了对使用 Edward 曲线进行密钥交换以及在签名验证中使用 PSS-RSA 填充的支持。
- 无需依赖 EPMD 即可运行 Erlang 分布的可能性已得到扩展。 为了实现这一点,向 inet 分布添加了几个新选项。
-dist_listen false
设置分发通道,但不侦听传入连接。-erl_epmd_port Port
配置内置 EPMD 客户端应返回的默认端口。- 已实现
gen_tcp
和inet
的第一个实验性socket
后端。gen_udp
和gen_sctp
将会跟进。 将{inet_backend, socket}
作为listen()
或connect()
的第一个选项可以很容易地为现有代码尝试此功能。 - kernel 中有一个新的模块
erpc
,它实现了rpc
模块提供的操作的增强子集。 增强之处在于,它可以区分返回值、引发的异常和其他错误。erpc
也比原始的rpc
实现具有更好的性能和可伸缩性。 这是通过利用新引入的spawn_request()
BIF 实现的。 此外,rpc
模块在可能的情况下也会通过使用erpc
从这些改进中受益。 - 关于分布式 spawn 操作的可伸缩性和性能改进以及新功能。
- 在二进制匹配中,现在允许要匹配的段的大小是一个 guard 表达式 (EEP-52)
- 当使用 map 进行匹配时,键现在可以是 guard 表达式 (EEP-52)。
- ssh:支持 TCP/IP 端口转发,也称为隧道,也称为 tcp-forward/direct-tcp。在 OpenSSH 客户端中,这对应于选项 -L 和 -R。
- 允许在数字字面量中使用下划线以提高可读性。 示例:
123_456_789
,16#1234_ABCD
。 - shell 中用于显示 Erlang 模块、函数和类型的文档的新函数。 这些函数是
h/1,2,3
– 打印Module:Function/Arity
的文档。ht/1,2,3
– 打印Module:Type/Arity
的类型文档。 嵌入式文档在构建 Erlang/OTP 文档时以 docchunk (EEP 48) 的形式创建。- kernel:引入了模块
pg
,其中包含分布式命名进程组的新实现。 旧模块pg2
已弃用,并计划在 OTP 24 中移除。 - 我们用于构建 Windows 包的工具链已升级,包括新的 C++ 编译器、Java 编译器、OpenSSL 库和 wxWidgets 版本。 我们现在使用 WSL(构建时适用于 Windows 的 Linux 子系统),这使得处理构建环境更加容易。
有关更多详细信息,请参阅 https://erlang.ac.cn/download/otp_src_23.0.readme
可以在此处获取 Windows 的预构建版本:https://erlang.ac.cn/download/otp_win32_23.0.exe https://erlang.ac.cn/download/otp_win64_23.0.exe
可以在此处浏览在线文档:https://erlang.ac.cn/documentation/doc-11.0/doc Erlang/OTP 源代码也可以在官方 Erlang 存储库的 GitHub 上找到:https://github.com/erlang/otp