codecamp

高级用法

Dubbo 3.0 文档

启动时检查

在启动时检查依赖的服务是否可用

序列化协议安全

在 Dubbo 中更安全的使用序列化协议

集群容错

集群调用失败时,Dubbo 提供的容错方案

负载均衡

Dubbo 提供的集群负载均衡策略

线程模型

配置 Dubbo 中的线程模型

直连提供者

Dubbo 中点对点的直连方式

只订阅

只订阅不注册

多协议

在 Dubbbo 中配置多协议

多注册中心

在 Dubbo 中把同一个服务注册到多个注册中心上

服务分组

使用服务分组区分服务接口的不同实现

静态服务

将 Dubbo 服务标识为非动态管理模式

多版本

在 Dubbo 中为同一个服务配置多个版本

分组聚合

通过分组对结果进行聚合并返回聚合后的结果

参数验证

在 Dubbo 中进行参数验证

结果缓存

通过缓存结果加速访问速度

使用泛化调用

实现一个通用的服务测试框架,可通过 GenericService 调用所有服务实现

Protobuf

使用 IDL 定义服务

GoogleProtobuf 对象泛化调用

对 Google Protobuf 对象进行泛化调用

实现泛化调用

实现一个通用的远程服务 Mock 框架,可通过实现 GenericService 接口处理所有服务请求

回声测试

通过回声测试检测 Dubbo 服务是否可用

上下文信息

通过上下文存放当前调用过程中所需的环境信息

隐式参数

通过 Dubbo 中的 Attachment 在服务消费方和提供方之间隐式传递参数

异步执行

Dubbo 服务提供方的异步执行

异步调用

在 Dubbo 中发起异步调用

本地调用

在 Dubbo 中进行本地调用

参数回调

通过参数回调从服务器端调用客户端逻辑

事件通知

在调用之前、调用之后、出现异常时的事件通知

本地存根

在 Dubbo 中利用本地存根在客户端执行部分逻辑

本地伪装

如何在 Dubbo 中利用本地伪装实现服务降级

延迟暴露

延迟暴露 Dubbo 服务

并发控制

Dubbo 中的并发控制

连接控制

Dubbo 中服务端和客户端的连接控制

延迟连接

在 Dubbo 中配置延迟连接

粘滞连接

为有状态服务配置粘滞连接

TLS

通过 TLS 保证传输安全

令牌验证

通过令牌验证在注册中心控制权限

路由规则

通过 Dubbo 中的路由规则做服务治理

旧路由规则

在 Dubbo 2.6.x 版本以及更早的版本中配置路由规则

配置规则

在 Dubbo 中配置应用级治理规则和服务级治理规则

旧配置规则

Dubbo 中旧版本的规则配置方式

服务降级

降级 Dubbo 服务

消费端线程池模型

Dubbo 消费端线程池模型用法

优雅停机

让 Dubbo 服务完成优雅停机

主机绑定

在 Dubbo 中绑定主机名

主机配置

自定义 Dubbo 服务对外暴露的主机地址

注册信息简化

减少注册中心上服务的注册数据

日志适配

在 Dubbo 中适配日志框架

访问日志

配置 Dubbo 的访问日志

服务容器

使用 Dubbo 中的服务容器

ReferenceConfig 缓存

在 Dubbo 中缓存 ReferenceConfig

只注册

只注册不订阅

分布式事务

Dubbo 中分布式事务的支持

应用级服务发现地址迁移规则说明

本文具体说明了地址迁移过程中使用的规则体信息,用户可以根据自己需求定制适合自己的迁移规则。

导出线程堆栈

在 Dubbo 自动导出线程堆栈来保留现场

Netty4 支持

在 Dubbo 中配置 Netty4

Kryo 和 FST 序列化

在 Dubbo 中使用高效的 Java 序列化(Kryo 和 FST)

Protobuf与Interface对比

本文对比了Protobuf和Interface这2种IDL的差异,帮助Dubbo协议开发者了解Protobuf,为后续转到Triple协议和Grpc协议做铺垫。


应用级服务发现
Dubbo3 启动时检查
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

介绍与示例

应用级服务发现

动态修改运行态配置项

参考手册

配置中心参考手册

元数据参考手册

API 参考手册

Kubernetes 生命周期对齐探针

在线运维命令参考手册

Telnet 命令参考手册

Maven 插件参考手册

性能优化

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }