草庐IT

What's new in Dubbo 3.1.4 and 3.2.0-beta.3

apache-dubbo 2023-04-17 原文

在 12 月 22 日,Dubbo 3.1.4 和 3.2.0-beta.3 正式通过投票发布。本文将介绍发布的变化一览。

Dubbo 3.1.4 版本是目前 Dubbo 3 的最新稳定版本,我们建议所有的用户都升级到最新的稳定版本。Dubbo 3.2.0-beta.3 版本是目前 Dubbo 3 的最新特性版本,包括了如 Spring Boot 3、JDK 17、服务粒度的线程池隔离等新特性的支持,欢迎大家尝鲜使用。

Dubbo 3.1.4

新特性

  • Dubbo QoS 支持指定白名单 IP 列表访问所有命令

Bugfix

  • 修复在泛化调用时 Dubbo Metrics 采集方法名错误
  • 修复使用 Zookeeper 作为元数据中心时,上报接口映射可能存在相互覆盖的问题
  • 修复 timeout countdown 在 Triple 协议的支持
  • 修复 timeout countdown 存在透传的问题
  • 修复多注册中心请求时,由于没有可用的地址导致的 NPE 问题
  • 修复 Mesh 模式下 Triple 获取 remoteApplicationName 为空的问题
  • 修复 GraalVM Native Image 的支持
  • 修复端口复用时无 SSL 连接导致的 NPE 异常
  • 完善 JDK 编译器报错日志的输出格式
  • 修复 MetadataReportConfig 部分配置时应用无法启动的问题
  • 修复 dubbo.reference 作为默认参数在 3.x 版本中不生效的问题
  • 完善 Zookeeper 连接失败的日志
  • 修复 ReferenceConfig 中配置的 ClassLoader 可能被覆盖的问题
  • 修复部分属性在应用级服务发现时被缓存在实例级的地址中导致方法级配置失效的问题
  • 修复 Triple 协议 onError 异常的问题

FAQ

本次发布中有 3 个提交涉及异常日志 FAQ 的完善。关于错误码机制请参考官网错误码机制介绍一文。(https://cn.dubbo.apache.org/zh/docs3-v2/java-sdk/faq/intro/)

代码优化

本次发布中有 11 个提交涉及代码质量的优化。

依赖升级

  • 升级 fastjson2: 2.0.14 -> 2.0.21
  • 升级 resteasy-jaxrs: 3.0.19.Final -> 3.0.20.Final

贡献者

Dubbo 感谢以下贡献者对本次发布的贡献:@cnjxzhao, @CrazyHZM, @EarthChen, @gold-fisher, @IncrementalRefinement, @Koooooo-7, @ShenFeng312, @tonycody, @twz007, @win120a, @wlazjr

新贡献者

  • @twz007 在 PR #11012 提交了第一个贡献
  • @IncrementalRefinement 在 PR #11046 提交了第一个贡献
  • @gold-fisher 在 PR #11058 提交了第一个贡献
  • @wlazjr 在 PR #11084 提交了第一个贡献
  • @ShenFeng312 在 PR #11102 提交了第一个贡献

Dubbo 3.2.0-beta.3

注:Dubbo 3.2.0-beta.3 的代码基础和 Dubbo 3.1.4 完全一致,因此在 Dubbo 3.1.4 中包括的所有修改内容,在 Dubbo 3.2.0-beta.3 中也同样存在,后续说明中对于重复的内容讲不再赘述。

新特性

  • 支持使用 jackson 作为Dubbo 内部的 JSON 序列化方式
  • 优化 Dubbo Logger 的选择逻辑,在存在多种日志框架的情况下会尝试读取其配置,选择一个有效的日志框架,解决在 SpringBoot 等场景下 Dubbo 日志不输出的问题。
  • Triple 协议支持客户端流控
  • 支持发布 Dubbo Metrics 数据到 Spring Boot 的 Endpoints 上
  • 支持可选关闭线程池满时的线程 Dump 以及支持配置 Dump 的结果输出路径
  • xDS 实现支持路由规则的解析
  • 支持 Dubbo QoS 命令安全性分级,默认对外暴露存活检测的端口,支持 Kubernetes 的原生接入
  • 支持基于 P2C 的自适应负载均衡

Bugfix

  • 修复默认 Metadata 缓存未开启的问题
  • 修复 Metrics 指标资源路径错误的问题
  • 完善线程池隔离的配置,默认采用共享线程池,避免创建过多的线程
  • 完善 prefer-serialization 的选择逻辑,提供向前兼容的能力
  • 修复 Triple 协议传输时未携带版本号导致版本调用错误的问题
  • 完善 GraalVM Native Image 的支持

性能优化

  • 优化在连接数高时由于获取 channels 数量导致的资源占用问题

代码优化

本次发布中有 5 个提交涉及代码质量的优化。

贡献者

Dubbo 感谢以下贡献者对本次发布的贡献:@AlbumenJ, @asa3311, @conghuhu, @CrazyHZM, @gitchenjh, @haoyann, @JavaHello, @Koooooo-7, @nannanfighting, @ningboliu, @shanuo0312, @songxiaosheng, @tonycody, @XDanwar

新贡献者

  • @JavaHello 在 PR #10970 提交了第一个贡献
  • @songxiaosheng 在 PR #10997提交了第一个贡献
  • @Koooooo-7 在 PR #11051 提交了第一个贡献
  • @ningboliu 在 PR #10745 提交了第一个贡献
  • @XDanwar 在 PR #11063 提交了第一个贡献

未来版本规划

Dubbo 版本的发布规划以及在《聚焦稳定性,Dubbo 发版规划公布》一文中正式发布,欢迎查看。

欢迎在 https://github.com/apache/dubbo 给 Dubbo Star。

有关What's new in Dubbo 3.1.4 and 3.2.0-beta.3的更多相关文章

  1. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  4. ruby - 在 jRuby 中使用 'fork' 生成进程的替代方案? - 2

    在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',

  5. ruby - 主要 :Object when running build from sublime 的未定义方法 `require_relative' - 2

    我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby​​1.9+ 关于ruby-主要:Objectwhenrun

  6. ruby-on-rails - rails : save file from URL and save it to Amazon S3 - 2

    从给定URL下载文件并立即将其上传到AmazonS3的更直接的方法是什么(+将有关文件的一些信息保存到数据库中,例如名称、大小等)?现在,我既不使用Paperclip,也不使用Carrierwave。谢谢 最佳答案 简单明了:require'open-uri'require's3'amazon=S3::Service.new(access_key_id:'KEY',secret_access_key:'KEY')bucket=amazon.buckets.find('image_storage')url='http://www.ex

  7. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  8. ruby-on-rails - 新 Rails 项目 : 'bundle install' can't install rails in gemfile - 2

    我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="

  9. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  10. ruby-on-rails - Rails 中的 NoMethodError::MailersController#preview undefined method `activation_token=' for nil:NilClass - 2

    似乎无法为此找到有效的答案。我正在阅读Rails教程的第10章第10.1.2节,但似乎无法使邮件程序预览正常工作。我发现处理错误的所有答案都与教程的不同部分相关,我假设我犯的错误正盯着我的脸。我已经完成并将教程中的代码复制/粘贴到相关文件中,但到目前为止,我还看不出我输入的内容与教程中的内容有什么区别。到目前为止,建议是在函数定义中添加或删除参数user,但这并没有解决问题。触发错误的url是http://localhost:3000/rails/mailers/user_mailer/account_activation.http://localhost:3000/rails/mai

随机推荐