| |
| <!DOCTYPE HTML> |
| <html lang="" > |
| <head> |
| <meta charset="UTF-8"> |
| <meta content="text/html; charset=utf-8" http-equiv="Content-Type"> |
| <title>7.1 dubbo:// · GitBook</title> |
| <meta http-equiv="X-UA-Compatible" content="IE=edge" /> |
| <meta name="description" content=""> |
| <meta name="generator" content="GitBook 3.2.2"> |
| |
| |
| |
| |
| <link rel="stylesheet" href="../gitbook/style.css"> |
| |
| |
| |
| |
| <link rel="stylesheet" href="../gitbook/gitbook-plugin-highlight/website.css"> |
| |
| |
| |
| <link rel="stylesheet" href="../gitbook/gitbook-plugin-search/search.css"> |
| |
| |
| |
| <link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css"> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <meta name="HandheldFriendly" content="true"/> |
| <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no"> |
| <meta name="apple-mobile-web-app-capable" content="yes"> |
| <meta name="apple-mobile-web-app-status-bar-style" content="black"> |
| <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png"> |
| <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon"> |
| |
| |
| <link rel="next" href="rmi.html" /> |
| |
| |
| <link rel="prev" href="introduction.html" /> |
| |
| |
| </head> |
| <body> |
| |
| <div class="book"> |
| <div class="book-summary"> |
| |
| |
| <div id="book-search-input" role="search"> |
| <input type="text" placeholder="Type to search" /> |
| </div> |
| |
| |
| <nav role="navigation"> |
| |
| |
| |
| <ul class="summary"> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="chapter " data-level="1.1" data-path="../"> |
| |
| <a href="../"> |
| |
| |
| Introduction |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.2" > |
| |
| <span> |
| |
| |
| 1 入门 |
| |
| </span> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.2.1" data-path="../preface/background.html"> |
| |
| <a href="../preface/background.html"> |
| |
| |
| 1.1 背景 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.2.2" data-path="../preface/requirements.html"> |
| |
| <a href="../preface/requirements.html"> |
| |
| |
| 1.2 需求 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.2.3" data-path="../preface/architacture.html"> |
| |
| <a href="../preface/architacture.html"> |
| |
| |
| 1.3 架构 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.2.4" data-path="../preface/usage.html"> |
| |
| <a href="../preface/usage.html"> |
| |
| |
| 1.4 用法 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.3" > |
| |
| <span> |
| |
| |
| 2 快速启动 |
| |
| </span> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.3.1" data-path="../dependencies/dependencies.html"> |
| |
| <a href="../dependencies/dependencies.html"> |
| |
| |
| 2.1 依赖 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.3.2" data-path="../maturity/maturity.html"> |
| |
| <a href="../maturity/maturity.html"> |
| |
| |
| 2.2 成熟度 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.4" > |
| |
| <span> |
| |
| |
| 3 配置 |
| |
| </span> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.4.1" data-path="../configuration/xml.html"> |
| |
| <a href="../configuration/xml.html"> |
| |
| |
| 3.1 XML配置 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.4.2" data-path="../configuration/properties.html"> |
| |
| <a href="../configuration/properties.html"> |
| |
| |
| 3.2 属性配置 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.4.3" data-path="../configuration/api.html"> |
| |
| <a href="../configuration/api.html"> |
| |
| |
| 3.3 API配置 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.4.4" data-path="../configuration/annotation.html"> |
| |
| <a href="../configuration/annotation.html"> |
| |
| |
| 3.4 注解配置 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5" > |
| |
| <span> |
| |
| |
| 4 示例 |
| |
| </span> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.5.1" data-path="../demos/启动时检查.html"> |
| |
| <a href="../demos/启动时检查.html"> |
| |
| |
| 4.1 启动时检查 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.2" data-path="../demos/集群容错.html"> |
| |
| <a href="../demos/集群容错.html"> |
| |
| |
| 4.2 集群容错 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.3" data-path="../demos/负载均衡.html"> |
| |
| <a href="../demos/负载均衡.html"> |
| |
| |
| 4.3 负载均衡 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.4" data-path="../demos/线程模型.html"> |
| |
| <a href="../demos/线程模型.html"> |
| |
| |
| 4.4 线程模型 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.5" data-path="../demos/直连提供者.html"> |
| |
| <a href="../demos/直连提供者.html"> |
| |
| |
| 4.5 直连提供者 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.6" data-path="../demos/只订阅.html"> |
| |
| <a href="../demos/只订阅.html"> |
| |
| |
| 4.6 只订阅 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.7" data-path="../demos/只注册.html"> |
| |
| <a href="../demos/只注册.html"> |
| |
| |
| 4.7 只注册 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.8" data-path="../demos/静态服务.html"> |
| |
| <a href="../demos/静态服务.html"> |
| |
| |
| 4.8 静态服务 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.9" data-path="../demos/多协议.html"> |
| |
| <a href="../demos/多协议.html"> |
| |
| |
| 4.9 多协议 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.10" data-path="../demos/多注册中心.html"> |
| |
| <a href="../demos/多注册中心.html"> |
| |
| |
| 4.10 多注册中心 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.11" data-path="../demos/服务分组.html"> |
| |
| <a href="../demos/服务分组.html"> |
| |
| |
| 4.11 服务分组 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.12" data-path="../demos/多版本.html"> |
| |
| <a href="../demos/多版本.html"> |
| |
| |
| 4.13 多版本 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.13" data-path="../demos/分组聚合.html"> |
| |
| <a href="../demos/分组聚合.html"> |
| |
| |
| 4.14 分组聚合 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.14" data-path="../demos/参数验证.html"> |
| |
| <a href="../demos/参数验证.html"> |
| |
| |
| 4.15 参数验证 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.15" data-path="../demos/结果缓存.html"> |
| |
| <a href="../demos/结果缓存.html"> |
| |
| |
| 4.16 结果缓存 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.16" data-path="../demos/泛化引用.html"> |
| |
| <a href="../demos/泛化引用.html"> |
| |
| |
| 4.17 泛化引用 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.17" data-path="../demos/泛化实现.html"> |
| |
| <a href="../demos/泛化实现.html"> |
| |
| |
| 4.18 泛化实现 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.18" data-path="../demos/回声测试.html"> |
| |
| <a href="../demos/回声测试.html"> |
| |
| |
| 4.19 回声测试 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.19" data-path="../demos/上下文信息.html"> |
| |
| <a href="../demos/上下文信息.html"> |
| |
| |
| 4.20 上下文信息 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.20" data-path="../demos/隐式传参.html"> |
| |
| <a href="../demos/隐式传参.html"> |
| |
| |
| 4.21 隐式参数 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.21" data-path="../demos/异步调用.html"> |
| |
| <a href="../demos/异步调用.html"> |
| |
| |
| 4.22 异步调用 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.22" data-path="../demos/本地调用.html"> |
| |
| <a href="../demos/本地调用.html"> |
| |
| |
| 4.23 本地调用 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.23" data-path="../demos/参数回调.html"> |
| |
| <a href="../demos/参数回调.html"> |
| |
| |
| 4.24 参数回调 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.24" data-path="../demos/事件通知.html"> |
| |
| <a href="../demos/事件通知.html"> |
| |
| |
| 4.25 事件通知 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.25" data-path="../demos/本地存根.html"> |
| |
| <a href="../demos/本地存根.html"> |
| |
| |
| 4.26 本地存根 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.26" data-path="../demos/本地伪装.html"> |
| |
| <a href="../demos/本地伪装.html"> |
| |
| |
| 4.27 本地伪装 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.27" data-path="../demos/延迟暴露.html"> |
| |
| <a href="../demos/延迟暴露.html"> |
| |
| |
| 4.28 延迟暴露 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.28" data-path="../demos/并发控制.html"> |
| |
| <a href="../demos/并发控制.html"> |
| |
| |
| 4.29 并发控制 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.29" data-path="../demos/连接控制.html"> |
| |
| <a href="../demos/连接控制.html"> |
| |
| |
| 4.30 连接控制 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.30" data-path="../demos/延迟连接.html"> |
| |
| <a href="../demos/延迟连接.html"> |
| |
| |
| 4.31 延迟连接 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.31" data-path="../demos/粘滞连接.html"> |
| |
| <a href="../demos/粘滞连接.html"> |
| |
| |
| 4.32 粘滞连接 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.32" data-path="../demos/令牌验证.html"> |
| |
| <a href="../demos/令牌验证.html"> |
| |
| |
| 4.33 令牌验证 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.33" data-path="../demos/路由规则.html"> |
| |
| <a href="../demos/路由规则.html"> |
| |
| |
| 4.34 路由规则 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.34" data-path="../demos/配置规则.html"> |
| |
| <a href="../demos/配置规则.html"> |
| |
| |
| 4.35 配置规则 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.35" data-path="../demos/服务降级.html"> |
| |
| <a href="../demos/服务降级.html"> |
| |
| |
| 4.36 服务降级 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.36" data-path="../demos/优雅停机.html"> |
| |
| <a href="../demos/优雅停机.html"> |
| |
| |
| 4.37 优雅停机 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.37" data-path="../demos/主机绑定.html"> |
| |
| <a href="../demos/主机绑定.html"> |
| |
| |
| 4.38 主机绑定 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.38" data-path="../demos/日志适配.html"> |
| |
| <a href="../demos/日志适配.html"> |
| |
| |
| 4.39 日志适配 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.39" data-path="../demos/访问日志.html"> |
| |
| <a href="../demos/访问日志.html"> |
| |
| |
| 4.40 访问日志 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.40" data-path="../demos/服务容器.html"> |
| |
| <a href="../demos/服务容器.html"> |
| |
| |
| 4.41 服务容器 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.41" data-path="../demos/ReferenceConfig缓存.html"> |
| |
| <a href="../demos/ReferenceConfig缓存.html"> |
| |
| |
| 4.42 Reference Config缓存 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.5.42" data-path="../demos/分布式事务.html"> |
| |
| <a href="../demos/分布式事务.html"> |
| |
| |
| 4.43 分布式事务 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.6" data-path="../reference-apiconf/api.html"> |
| |
| <a href="../reference-apiconf/api.html"> |
| |
| |
| 5 API参考手册 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7" data-path="../reference-xmlconf/introduction.html"> |
| |
| <a href="../reference-xmlconf/introduction.html"> |
| |
| |
| 6 schema配置参考手册 |
| |
| </a> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.7.1" data-path="../reference-xmlconf/dubbo-service.html"> |
| |
| <a href="../reference-xmlconf/dubbo-service.html"> |
| |
| |
| 6.1 dubbo:service |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.2" data-path="../reference-xmlconf/dubbo-reference.html"> |
| |
| <a href="../reference-xmlconf/dubbo-reference.html"> |
| |
| |
| 6.2 dubbo:reference |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.3" data-path="../reference-xmlconf/dubbo-protocol.html"> |
| |
| <a href="../reference-xmlconf/dubbo-protocol.html"> |
| |
| |
| 6.3 dubbo:protocol |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.4" data-path="../reference-xmlconf/dubbo-registry.html"> |
| |
| <a href="../reference-xmlconf/dubbo-registry.html"> |
| |
| |
| 6.4 dubbo:registry |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.5" data-path="../reference-xmlconf/dubbo-monitor.html"> |
| |
| <a href="../reference-xmlconf/dubbo-monitor.html"> |
| |
| |
| 6.5 dubbo:monitor |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.6" data-path="../reference-xmlconf/dubbo-application.html"> |
| |
| <a href="../reference-xmlconf/dubbo-application.html"> |
| |
| |
| 6.6 dubbo:application |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.7" data-path="../reference-xmlconf/dubbo-module.html"> |
| |
| <a href="../reference-xmlconf/dubbo-module.html"> |
| |
| |
| 6.7 dubbo:module |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.8" data-path="../reference-xmlconf/dubbo-provider.html"> |
| |
| <a href="../reference-xmlconf/dubbo-provider.html"> |
| |
| |
| 6.8 dubbo:provider |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.9" data-path="../reference-xmlconf/dubbo-consumer.html"> |
| |
| <a href="../reference-xmlconf/dubbo-consumer.html"> |
| |
| |
| 6.9 dubbo:consumer |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.10" data-path="../reference-xmlconf/dubbo-method.html"> |
| |
| <a href="../reference-xmlconf/dubbo-method.html"> |
| |
| |
| 6.10 dubbo:method |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.11" data-path="../reference-xmlconf/dubbo-argument.html"> |
| |
| <a href="../reference-xmlconf/dubbo-argument.html"> |
| |
| |
| 6.11 dubbo:argument |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.7.12" data-path="../reference-xmlconf/dubbo-parameter.html"> |
| |
| <a href="../reference-xmlconf/dubbo-parameter.html"> |
| |
| |
| 6.12 dubbo:parameter |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8" data-path="introduction.html"> |
| |
| <a href="introduction.html"> |
| |
| |
| 7 协议参考手册 |
| |
| </a> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter active" data-level="1.8.1" data-path="dubbo.html"> |
| |
| <a href="dubbo.html"> |
| |
| |
| 7.1 dubbo:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.2" data-path="rmi.html"> |
| |
| <a href="rmi.html"> |
| |
| |
| 7.2 rmi// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.3" data-path="hessian.html"> |
| |
| <a href="hessian.html"> |
| |
| |
| 7.3 hessian:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.4" data-path="http.html"> |
| |
| <a href="http.html"> |
| |
| |
| 7.4 http:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.5" data-path="webservice.html"> |
| |
| <a href="webservice.html"> |
| |
| |
| 7.5 webservice:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.6" data-path="thrift.html"> |
| |
| <a href="thrift.html"> |
| |
| |
| 7.6 thrift:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.7" data-path="memcached.html"> |
| |
| <a href="memcached.html"> |
| |
| |
| 7.7 memcached:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.8.8" data-path="redis.html"> |
| |
| <a href="redis.html"> |
| |
| |
| 7.8 redis:// |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.9" data-path="../reference-registry/introduction.html"> |
| |
| <a href="../reference-registry/introduction.html"> |
| |
| |
| 8 注册中心参考手册 |
| |
| </a> |
| |
| |
| |
| <ul class="articles"> |
| |
| |
| <li class="chapter " data-level="1.9.1" data-path="../reference-registry/multicast.html"> |
| |
| <a href="../reference-registry/multicast.html"> |
| |
| |
| 8.1 Multicast注册中心 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.9.2" data-path="../reference-registry/zookeeper.html"> |
| |
| <a href="../reference-registry/zookeeper.html"> |
| |
| |
| 8.2 Zookeeper注册中心 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.9.3" data-path="../reference-registry/redis.html"> |
| |
| <a href="../reference-registry/redis.html"> |
| |
| |
| 8.3 Redis注册中心 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.9.4" data-path="../reference-registry/simple.html"> |
| |
| <a href="../reference-registry/simple.html"> |
| |
| |
| 8.4 Simple注册中心 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| </ul> |
| |
| </li> |
| |
| <li class="chapter " data-level="1.10" data-path="../reference-telnet/telnet.html"> |
| |
| <a href="../reference-telnet/telnet.html"> |
| |
| |
| 9 telnet命令参考手册 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.11" data-path="../reference-maven/maven.html"> |
| |
| <a href="../reference-maven/maven.html"> |
| |
| |
| 10 maven插件参考手册 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.12" data-path="../best-practice.html"> |
| |
| <a href="../best-practice.html"> |
| |
| |
| 11 服务化最佳实践 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.13" data-path="../recommend.html"> |
| |
| <a href="../recommend.html"> |
| |
| |
| 12 推荐用法 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.14" data-path="../capacity-plan.html"> |
| |
| <a href="../capacity-plan.html"> |
| |
| |
| 13 容量规划 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.15" data-path="../benchmark.html"> |
| |
| <a href="../benchmark.html"> |
| |
| |
| 14 基准测试工具包 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.16" data-path="../perf-test.html"> |
| |
| <a href="../perf-test.html"> |
| |
| |
| 15 性能测试报告 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| <li class="chapter " data-level="1.17" data-path="../coveragence.html"> |
| |
| <a href="../coveragence.html"> |
| |
| |
| 16 测试覆盖率报告 |
| |
| </a> |
| |
| |
| |
| </li> |
| |
| |
| |
| |
| <li class="divider"></li> |
| |
| <li> |
| <a href="https://www.gitbook.com" target="blank" class="gitbook-link"> |
| Published with GitBook |
| </a> |
| </li> |
| </ul> |
| |
| |
| </nav> |
| |
| |
| </div> |
| |
| <div class="book-body"> |
| |
| <div class="body-inner"> |
| |
| |
| |
| <div class="book-header" role="navigation"> |
| |
| |
| <!-- Title --> |
| <h1> |
| <i class="fa fa-circle-o-notch fa-spin"></i> |
| <a href=".." >7.1 dubbo://</a> |
| </h1> |
| </div> |
| |
| |
| |
| |
| <div class="page-wrapper" tabindex="-1" role="main"> |
| <div class="page-inner"> |
| |
| <div id="book-search-results"> |
| <div class="search-noresults"> |
| |
| <section class="normal markdown-section"> |
| |
| <blockquote> |
| <p><img src="../sources/images/check.gif" alt="warning">Dubbo缺省协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况。</p> |
| <p><img src="../sources/images/warning-3.gif" alt="warning">Dubbo缺省协议不适合传送大数据量的服务,比如传文件,传视频等,除非请求量很低。</p> |
| </blockquote> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:protocol</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"dubbo"</span> <span class="hljs-attr">port</span>=<span class="hljs-string">"20880"</span> /></span> |
| </code></pre> |
| <p>设置默认协议:</p> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:provider</span> <span class="hljs-attr">protocol</span>=<span class="hljs-string">"dubbo"</span> /></span> |
| </code></pre> |
| <p>设置服务协议:</p> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:service</span> <span class="hljs-attr">protocol</span>=<span class="hljs-string">"dubbo"</span> /></span> |
| </code></pre> |
| <p>多端口:</p> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:protocol</span> <span class="hljs-attr">name</span>=<span class="hljs-string">“dubbo”</span> <span class="hljs-attr">port</span>=<span class="hljs-string">“9090”</span> <span class="hljs-attr">server</span>=<span class="hljs-string">“netty”</span> <span class="hljs-attr">client</span>=<span class="hljs-string">“netty”</span> <span class="hljs-attr">codec</span>=<span class="hljs-string">“dubbo”</span> <span class="hljs-attr">serialization</span>=<span class="hljs-string">“hessian2”</span> <span class="hljs-attr">charset</span>=<span class="hljs-string">“UTF-8”</span> <span class="hljs-attr">threadpool</span>=<span class="hljs-string">“fixed”</span> <span class="hljs-attr">threads</span>=<span class="hljs-string">“100”</span> <span class="hljs-attr">queues</span>=<span class="hljs-string">“0”</span> <span class="hljs-attr">iothreads</span>=<span class="hljs-string">“9”</span> <span class="hljs-attr">buffer</span>=<span class="hljs-string">“8192”</span> <span class="hljs-attr">accepts</span>=<span class="hljs-string">“1000”</span> <span class="hljs-attr">payload</span>=<span class="hljs-string">“8388608”</span> /></span> |
| </code></pre> |
| <p><img src="../sources/images/dubbo-protocol.jpg" alt="/user-guide/images/dubbo-protocol.jpg"></p> |
| <ul> |
| <li>Transporter: mina, netty, grizzy</li> |
| <li>Serialization: dubbo, hessian2, java, json</li> |
| <li>Dispatcher: all, direct, message, execution, connection</li> |
| <li>ThreadPool: fixed, cached</li> |
| </ul> |
| <blockquote> |
| <p><img src="../sources/images/check.gif" alt="warning">Dubbo协议缺省每服务每提供者每消费者使用单一长连接,如果数据量较大,可以使用多个连接。</p> |
| </blockquote> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:protocol</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"dubbo"</span> <span class="hljs-attr">connections</span>=<span class="hljs-string">"2"</span> /></span> |
| </code></pre> |
| <ul> |
| <li><code><dubbo:service connections=”0”></code> 或 <code><dubbo:reference connections=”0”></code> 表示该服务使用JVM共享长连接。(缺省)</li> |
| <li><code><dubbo:service connections=”1”></code> 或 <code><dubbo:reference connections=”1”></code> 表示该服务使用独立长连接。</li> |
| <li><code><dubbo:service connections=”2”></code> 或<code><dubbo:reference connections=”2”></code> 表示该服务使用独立两条长连接。</li> |
| </ul> |
| <blockquote> |
| <p><img src="../sources/images/check.gif" alt="warning">为防止被大量连接撑挂,可在服务提供方限制大接收连接数,以实现服务提供方自我保护。</p> |
| </blockquote> |
| <pre><code class="lang-xml"><span class="hljs-tag"><<span class="hljs-name">dubbo:protocol</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"dubbo"</span> <span class="hljs-attr">accepts</span>=<span class="hljs-string">"1000"</span> /></span> |
| </code></pre> |
| <p>缺省协议,使用基于mina1.1.7+hessian3.2.1的tbremoting交互。</p> |
| <ul> |
| <li>连接个数:单连接</li> |
| <li>连接方式:长连接</li> |
| <li>传输协议:TCP</li> |
| <li>传输方式:NIO异步传输</li> |
| <li>序列化:Hessian二进制序列化</li> |
| <li>适用范围:传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用dubbo协议传输大文件或超大字符串。</li> |
| <li>适用场景:常规远程服务方法调用</li> |
| </ul> |
| <p><strong>为什么要消费者比提供者个数多?</strong></p> |
| <p>因dubbo协议采用单一长连接,假设网络为千兆网卡(1024Mbit=128MByte),根据测试经验数据每条连接最多只能压满7MByte(不同的环境可能不一样,供参考),理论上1个服务提供者需要20个服务消费者才能压满网卡。</p> |
| <p><strong>为什么不能传大包?</strong></p> |
| <p>因dubbo协议采用单一长连接,如果每次请求的数据包大小为500KByte,假设网络为千兆网卡(1024Mbit=128MByte),每条连接最大7MByte(不同的环境可能不一样,供参考),单个服务提供者的TPS(每秒处理事务数)最大为:128MByte / 500KByte = 262。单个消费者调用单个服务提供者的TPS(每秒处理事务数)最大为:7MByte / 500KByte = 14。如果能接受,可以考虑使用,否则网络将成为瓶颈。</p> |
| <p><strong>为什么采用异步单一长连接?</strong></p> |
| <p>因为服务的现状大都是服务提供者少,通常只有几台机器,而服务的消费者多,可能整个网站都在访问该服务,比如Morgan的提供者只有6台提供者,却有上百台消费者,每天有1.5亿次调用,如果采用常规的hessian服务,服务提供者很容易就被压跨,通过单一连接,保证单一消费者不会压死提供者,长连接,减少连接握手验证等,并使用异步IO,复用线程池,防止C10K问题。</p> |
| <p>(1) 约束:</p> |
| <ul> |
| <li>参数及返回值需实现Serializable接口</li> |
| <li>参数及返回值不能自定义实现List, Map, Number, Date, Calendar等接口,只能用JDK自带的实现,因为hessian会做特殊处理,自定义实现类中的属性值都会丢失。</li> |
| <li><p>Hessian序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况:(由吴亚军提供)</p> |
| <p> 数据通讯 | 情况 | 结果 |
| ------------- | ------------- | ------------- |
| A->B | 类A多一种 属性(或者说类B少一种 属性)| 不抛异常,A多的那 个属性的值,B没有, 其他正常 |
| A->B | 枚举A多一种 枚举(或者说B少一种 枚举),A使用多 出来的枚举进行传输 | 抛异常 |
| A->B | 枚举A多一种 枚举(或者说B少一种 枚举),A不使用 多出来的枚举进行传输 | 不抛异常,B正常接 收数据 |
| A->B | A和B的属性 名相同,但类型不相同 | 抛异常 |
| A->B | serialId 不相同 | 正常传输</p> |
| <p> 总结:会抛异常的情况:枚举值一边多一种,一边少一种,正好使用了差别的那种,或者属性名相同,类型不同</p> |
| </li> |
| </ul> |
| <p>接口增加方法,对客户端无影响,如果该方法不是客户端需要的,客户端不需要重新部署。输入参数和结果集中增加属性,对客户端无影响,如果客户端并不需要新属性,不用重新部署。</p> |
| <p>输入参数和结果集属性名变化,对客户端序列化无影响,但是如果客户端不重新部署,不管输入还是输出,属性名变化的属性值是获取不到的。</p> |
| <p>总结:服务器端和客户端对领域对象并不需要完全一致,而是按照最大匹配原则。</p> |
| <p>(2) 配置:</p> |
| <p><strong>dubbo.properties</strong></p> |
| <pre><code class="lang-sh">dubbo.service.protocol=dubbo |
| </code></pre> |
| |
| |
| </section> |
| |
| </div> |
| <div class="search-results"> |
| <div class="has-results"> |
| |
| <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1> |
| <ul class="search-results-list"></ul> |
| |
| </div> |
| <div class="no-results"> |
| |
| <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1> |
| |
| </div> |
| </div> |
| </div> |
| |
| </div> |
| </div> |
| |
| </div> |
| |
| |
| |
| <a href="introduction.html" class="navigation navigation-prev " aria-label="Previous page: 7 协议参考手册"> |
| <i class="fa fa-angle-left"></i> |
| </a> |
| |
| |
| <a href="rmi.html" class="navigation navigation-next " aria-label="Next page: 7.2 rmi//"> |
| <i class="fa fa-angle-right"></i> |
| </a> |
| |
| |
| |
| </div> |
| |
| <script> |
| var gitbook = gitbook || []; |
| gitbook.push(function() { |
| gitbook.page.hasChanged({"page":{"title":"7.1 dubbo://","level":"1.8.1","depth":2,"next":{"title":"7.2 rmi//","level":"1.8.2","depth":2,"path":"reference-protocol/rmi.md","ref":"reference-protocol/rmi.md","articles":[]},"previous":{"title":"7 协议参考手册","level":"1.8","depth":1,"path":"reference-protocol/introduction.md","ref":"reference-protocol/introduction.md","articles":[{"title":"7.1 dubbo://","level":"1.8.1","depth":2,"path":"reference-protocol/dubbo.md","ref":"reference-protocol/dubbo.md","articles":[]},{"title":"7.2 rmi//","level":"1.8.2","depth":2,"path":"reference-protocol/rmi.md","ref":"reference-protocol/rmi.md","articles":[]},{"title":"7.3 hessian://","level":"1.8.3","depth":2,"path":"reference-protocol/hessian.md","ref":"reference-protocol/hessian.md","articles":[]},{"title":"7.4 http://","level":"1.8.4","depth":2,"path":"reference-protocol/http.md","ref":"reference-protocol/http.md","articles":[]},{"title":"7.5 webservice://","level":"1.8.5","depth":2,"path":"reference-protocol/webservice.md","ref":"reference-protocol/webservice.md","articles":[]},{"title":"7.6 thrift://","level":"1.8.6","depth":2,"path":"reference-protocol/thrift.md","ref":"reference-protocol/thrift.md","articles":[]},{"title":"7.7 memcached://","level":"1.8.7","depth":2,"path":"reference-protocol/memcached.md","ref":"reference-protocol/memcached.md","articles":[]},{"title":"7.8 redis://","level":"1.8.8","depth":2,"path":"reference-protocol/redis.md","ref":"reference-protocol/redis.md","articles":[]}]},"dir":"ltr"},"config":{"gitbook":"*","theme":"default","variables":{},"plugins":[],"pluginsConfig":{"highlight":{},"search":{},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"fontsettings":{"theme":"white","family":"sans","size":2},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"}},"file":{"path":"reference-protocol/dubbo.md","mtime":"2017-08-02T06:13:38.000Z","type":"markdown"},"gitbook":{"version":"3.2.2","time":"2017-08-02T07:12:01.637Z"},"basePath":"..","book":{"language":""}}); |
| }); |
| </script> |
| </div> |
| |
| |
| <script src="../gitbook/gitbook.js"></script> |
| <script src="../gitbook/theme.js"></script> |
| |
| |
| <script src="../gitbook/gitbook-plugin-search/search-engine.js"></script> |
| |
| |
| |
| <script src="../gitbook/gitbook-plugin-search/search.js"></script> |
| |
| |
| |
| <script src="../gitbook/gitbook-plugin-lunr/lunr.min.js"></script> |
| |
| |
| |
| <script src="../gitbook/gitbook-plugin-lunr/search-lunr.js"></script> |
| |
| |
| |
| <script src="../gitbook/gitbook-plugin-sharing/buttons.js"></script> |
| |
| |
| |
| <script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script> |
| |
| |
| |
| </body> |
| </html> |
| |