| |
| <!doctype html> |
| <html lang="en" class="no-js"> |
| <head> |
| |
| <meta charset="utf-8"> |
| <meta name="viewport" content="width=device-width,initial-scale=1"> |
| |
| |
| |
| |
| |
| |
| <link rel="icon" href="../../assets/images/favicon.png"> |
| <meta name="generator" content="mkdocs-1.6.0, mkdocs-material-9.5.19"> |
| |
| |
| |
| <title>Java Chassis 3技术解密:与Spring Cloud的互操作 - Java Chassis 3 开发指南</title> |
| |
| |
| |
| <link rel="stylesheet" href="../../assets/stylesheets/main.66ac8b77.min.css"> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> |
| <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback"> |
| <style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style> |
| |
| |
| |
| <script>__md_scope=new URL("../..",location),__md_hash=e=>[...e].reduce((e,_)=>(e<<5)-e+_.charCodeAt(0),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script> |
| |
| |
| |
| |
| |
| |
| </head> |
| |
| |
| <body dir="ltr"> |
| |
| |
| <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off"> |
| <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off"> |
| <label class="md-overlay" for="__drawer"></label> |
| <div data-md-component="skip"> |
| |
| |
| <a href="#java-chassis-3spring-cloud" class="md-skip"> |
| Skip to content |
| </a> |
| |
| </div> |
| <div data-md-component="announce"> |
| |
| </div> |
| |
| |
| |
| |
| |
| |
| <header class="md-header md-header--shadow" data-md-component="header"> |
| <nav class="md-header__inner md-grid" aria-label="Header"> |
| <a href="../../index.html" title="Java Chassis 3 开发指南" class="md-header__button md-logo" aria-label="Java Chassis 3 开发指南" data-md-component="logo"> |
| |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54Z"/></svg> |
| |
| </a> |
| <label class="md-header__button md-icon" for="__drawer"> |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg> |
| </label> |
| <div class="md-header__title" data-md-component="header-title"> |
| <div class="md-header__ellipsis"> |
| <div class="md-header__topic"> |
| <span class="md-ellipsis"> |
| Java Chassis 3 开发指南 |
| </span> |
| </div> |
| <div class="md-header__topic" data-md-component="header-topic"> |
| <span class="md-ellipsis"> |
| |
| Java Chassis 3技术解密:与Spring Cloud的互操作 |
| |
| </span> |
| </div> |
| </div> |
| </div> |
| |
| |
| <script>var media,input,key,value,palette=__md_get("__palette");if(palette&&palette.color){"(prefers-color-scheme)"===palette.color.media&&(media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']"),palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent"));for([key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script> |
| |
| |
| |
| <label class="md-header__button md-icon" for="__search"> |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg> |
| </label> |
| <div class="md-search" data-md-component="search" role="dialog"> |
| <label class="md-search__overlay" for="__search"></label> |
| <div class="md-search__inner" role="search"> |
| <form class="md-search__form" name="search"> |
| <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required> |
| <label class="md-search__icon md-icon" for="__search"> |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg> |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12Z"/></svg> |
| </label> |
| <nav class="md-search__options" aria-label="Search"> |
| |
| <button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1"> |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41Z"/></svg> |
| </button> |
| </nav> |
| |
| </form> |
| <div class="md-search__output"> |
| <div class="md-search__scrollwrap" data-md-scrollfix> |
| <div class="md-search-result" data-md-component="search-result"> |
| <div class="md-search-result__meta"> |
| Initializing search |
| </div> |
| <ol class="md-search-result__list" role="presentation"></ol> |
| </div> |
| </div> |
| </div> |
| </div> |
| </div> |
| |
| |
| </nav> |
| |
| </header> |
| |
| <div class="md-container" data-md-component="container"> |
| |
| |
| |
| |
| |
| |
| <main class="md-main" data-md-component="main"> |
| <div class="md-main__inner md-grid"> |
| |
| |
| |
| <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" > |
| <div class="md-sidebar__scrollwrap"> |
| <div class="md-sidebar__inner"> |
| |
| |
| |
| |
| <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0"> |
| <label class="md-nav__title" for="__drawer"> |
| <a href="../../index.html" title="Java Chassis 3 开发指南" class="md-nav__button md-logo" aria-label="Java Chassis 3 开发指南" data-md-component="logo"> |
| |
| |
| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54Z"/></svg> |
| |
| </a> |
| Java Chassis 3 开发指南 |
| </label> |
| |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../index.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 概述 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../start/design.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Java Chassis设计参考 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../introduce3.x.x.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Java Chassis 3版本介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_4" > |
| |
| |
| <label class="md-nav__link" for="__nav_4" id="__nav_4_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 快速入门 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_4"> |
| <span class="md-nav__icon md-icon"></span> |
| 快速入门 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../start/development-environment.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 安装本地开发环境 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../start/first-sample.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 开发第一个微服务应用 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../application-bmi.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| BMI应用-使用服务治理 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../application-porter.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| PORTER应用-典型开发场景 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/definition/service-definition.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 微服务定义 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_6" > |
| |
| |
| <label class="md-nav__link" for="__nav_6" id="__nav_6_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| Spring Boot集成Java Chassis |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_6_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_6"> |
| <span class="md-nav__icon md-icon"></span> |
| Spring Boot集成Java Chassis |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../spring-boot/introduction.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Spring Boot集成Java Chassis介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../spring-boot/diff-spring-mvc.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 与Spring Web MVC开发习惯的差异 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_7" > |
| |
| |
| <label class="md-nav__link" for="__nav_7" id="__nav_7_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 开发服务提供者 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_7_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_7"> |
| <span class="md-nav__icon md-icon"></span> |
| 开发服务提供者 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/basics.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 基础概念 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/http-mapping.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| HTTP参数映射参考 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/jaxrs.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 用JAX-RS开发微服务 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/springmvc.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 用SpringMVC开发微服务 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/transparent-rpc.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 用透明RPC开发微服务 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/use-interface.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 只发布interface的方法为服务接口 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/reactive.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 异步处理 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/context-param.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用 Context 参数 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/multi-code.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 多个返回值和错误码 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/swagger-annotation.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Swagger注解 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/interface-constraints.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 接口定义和数据类型 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/listen-address-and-publish-address.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 服务监听地址和发布地址 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/thread-pool.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 线程池 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/event-listener.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 服务启动事件 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/parameter-validator.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 参数效验 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/bootup.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 程序启动逻辑 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/ipv6-configuration.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| IPV6配置和使用 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-provider/access-log-configuration.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Access Log配置 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8" > |
| |
| |
| <label class="md-nav__link" for="__nav_8" id="__nav_8_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 开发服务消费者 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_8_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_8"> |
| <span class="md-nav__icon md-icon"></span> |
| 开发服务消费者 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-consumer/basics.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 基础概念 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-consumer/using-resttemplate.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Restful风格 - 使用 RestOperations |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-consumer/develop-consumer-using-rpc.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| RPC风格 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-consumer/invoker.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 泛化调用 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../build-consumer/3rd-party-service-invoke.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 调用第三方REST服务 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_9" > |
| |
| |
| <label class="md-nav__link" for="__nav_9" id="__nav_9_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 定制请求处理流程 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_9_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_9"> |
| <span class="md-nav__icon md-icon"></span> |
| 定制请求处理流程 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/intruduction.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 处理链介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_10" > |
| |
| |
| <label class="md-nav__link" for="__nav_10" id="__nav_10_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 通用功能开发 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_10_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_10"> |
| <span class="md-nav__icon md-icon"></span> |
| 通用功能开发 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/metrics.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 应用性能监控 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/microservice-invocation-chain.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 微服务调用链 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/customized-tracing.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 自定义调用链打点 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/local-develop-test.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 本地开发和测试 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/upload-download.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 文件上传下载 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/reactive.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Reactive |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/dnsconfig.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| DNS自定义配置 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/proxy.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 代理设置 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/report-framework-version.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 框架上报版本号 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/cross-app-invocation.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 跨应用调用 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/secret-field.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 定制序列化和反序列化方法 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/context.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Context传递控制消息 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/produceprocess.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 返回值序列化扩展 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/CORS.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 跨域资源共享(CORS) |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/AlarmEvent.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 获取熔断与实例隔离告警事件信息 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/shutdown.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 优雅停机 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/error-handling.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 异常处理 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/multienvironment.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 微服务实例间多环境隔离 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/thread-model.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 线程模型 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../general-development/config-logs.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 配置日志 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_11" > |
| |
| |
| <label class="md-nav__link" for="__nav_11" id="__nav_11_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 多样化的通信协议功能 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_11_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_11"> |
| <span class="md-nav__icon md-icon"></span> |
| 多样化的通信协议功能 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/introduction.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 多协议介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/rest-over-vertx.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| REST over HTTP(Vert.x) |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/http2.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| REST over HTTP2(Vert.x) |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/rest-over-servlet-embedded.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| REST over Servlet(Spring Boot Embedded) |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/rest-over-servlet.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| REST over Servlet(WAR) |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../transports/highway-rpc.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Highway |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_12" > |
| |
| |
| <label class="md-nav__link" for="__nav_12" id="__nav_12_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 多样化的服务注册与发现功能 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_12_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_12"> |
| <span class="md-nav__icon md-icon"></span> |
| 多样化的服务注册与发现功能 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/introduction.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 注册发现介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/service-center.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Service Center |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/nacos.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Nacos |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/zookeeper.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用ZooKeeper |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/local-registry.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 本地注册发现 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../registry/distributed.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 去中心化注册发现 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_13" > |
| |
| |
| <label class="md-nav__link" for="__nav_13" id="__nav_13_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 多样化的配置管理功能 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_13_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_13"> |
| <span class="md-nav__icon md-icon"></span> |
| 多样化的配置管理功能 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/general-config.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 服务配置介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/read-config.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 在程序中读取配置信息 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/kie.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Kie |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/nacos.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Nacos |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/zookeeper.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Zookeeper |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/apollo.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用Apollo |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config/cse1.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用CSE1.0配置中心 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_14" > |
| |
| |
| <label class="md-nav__link" for="__nav_14" id="__nav_14_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 服务治理功能参考 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_14_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_14"> |
| <span class="md-nav__icon md-icon"></span> |
| 服务治理功能参考 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/rule-governance.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 流量特征治理 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/governance-best-practise.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 流量特征治理最佳实践 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/loadbalance.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 负载均衡 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/ratelimit.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 限流 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/router.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 灰度发布 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/fault-injection.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 故障注入 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/fail-retry.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 快速失败和重试 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_15" > |
| |
| |
| <label class="md-nav__link" for="__nav_15" id="__nav_15_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 网关功能参考 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_15_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_15"> |
| <span class="md-nav__icon md-icon"></span> |
| 网关功能参考 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../edge/open-service.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../edge/by-servicecomb-sdk.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用 Edge Service 做网关 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../edge/zuul.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用 `zuul` 和 `spring cloud gateway` 做网关 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../edge/nginx.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| nginx 网关简单介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_16" > |
| |
| |
| <label class="md-nav__link" for="__nav_16" id="__nav_16_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 安全特性参考 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_16_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_16"> |
| <span class="md-nav__icon md-icon"></span> |
| 安全特性参考 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../references-handlers/publickey.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 公钥认证 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../security/tls.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用TLS通信 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../security/shi-yong-rsa-ren-zheng.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 使用RSA认证 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_17" > |
| |
| |
| <label class="md-nav__link" for="__nav_17" id="__nav_17_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 专题文章 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_17_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_17"> |
| <span class="md-nav__icon md-icon"></span> |
| 专题文章 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../features.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 特性介绍 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../secrets.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 技术解密 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../upgrading.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 升级指导 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../compatibility.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 兼容问题和兼容性策略 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../performance.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 性能问题分析和调优 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_18" > |
| |
| |
| <label class="md-nav__link" for="__nav_18" id="__nav_18_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 常用配置项参考 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_18_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_18"> |
| <span class="md-nav__icon md-icon"></span> |
| 常用配置项参考 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../config-reference/rest-transport-client.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| REST Transport Client 配置项 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item md-nav__item--nested"> |
| |
| |
| |
| <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_19" > |
| |
| |
| <label class="md-nav__link" for="__nav_19" id="__nav_19_label" tabindex="0"> |
| |
| |
| <span class="md-ellipsis"> |
| 常见问题 |
| </span> |
| |
| |
| <span class="md-nav__icon md-icon"></span> |
| </label> |
| |
| <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_19_label" aria-expanded="false"> |
| <label class="md-nav__title" for="__nav_19"> |
| <span class="md-nav__icon md-icon"></span> |
| 常见问题 |
| </label> |
| <ul class="md-nav__list" data-md-scrollfix> |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../question-and-answer/faq.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| FAQ |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../question-and-answer/question_answer.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| Q & A |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| <li class="md-nav__item"> |
| <a href="../../question-and-answer/interface-compatibility.html" class="md-nav__link"> |
| |
| |
| <span class="md-ellipsis"> |
| 微服务接口兼容常见问题 |
| </span> |
| |
| |
| </a> |
| </li> |
| |
| |
| |
| |
| </ul> |
| </nav> |
| |
| </li> |
| |
| |
| |
| </ul> |
| </nav> |
| </div> |
| </div> |
| </div> |
| |
| |
| |
| <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" > |
| <div class="md-sidebar__scrollwrap"> |
| <div class="md-sidebar__inner"> |
| |
| |
| <nav class="md-nav md-nav--secondary" aria-label="Table of contents"> |
| |
| |
| |
| |
| |
| |
| </nav> |
| </div> |
| </div> |
| </div> |
| |
| |
| |
| <div class="md-content" data-md-component="content"> |
| <article class="md-content__inner md-typeset"> |
| |
| |
| |
| |
| <h1 id="java-chassis-3spring-cloud">Java Chassis 3技术解密:与Spring Cloud的互操作</h1> |
| <p>Java Chassis 3一个很重要的设计原则:利用架构的韧性设计来解决兼容性问题。 </p> |
| <p><img alt="" src="serialization-arch.png" /></p> |
| <p>比如通过引入微服务网关,来解决不同语言、不同框架、遗留系统之间的互操作问题。 本文在这个架构原则基础上,讨论一个更加细粒度的互操作问题,并借此解密Java Chassis3在运行时设计依赖上的技术细节。</p> |
| <p>首先,我们描述一个互操作的场景和假设。 </p> |
| <p><img alt="" src="interoperability-scen.png" /></p> |
| <ul> |
| <li>Spring Cloud和Java Chassis应用同时注册到注册中心。引入了Spring Cloud Gateway作为网关,网关也注册到注册中心。 </li> |
| <li>Spring Cloud微服务和Java Chassis微服务相互调用。它们彼此作为消费者的时候,不需要感知对方是不同的框架,做到透明调用。 </li> |
| </ul> |
| <p>从技术原理上梳理下上述互操作需要满足的条件:</p> |
| <ul> |
| <li>Spring Cloud和Java Chassis需要有相互认识的注册信息。核心包括:应用名称、服务名称、地址信息和格式等。 需要的共同注册中心越少,越容易对注册中心和客户端进行选型。 在本例子中,我们选择 <code>Service Center</code> 或者 <code>Nacos</code> 作为注册中心,并选择Spring Cloud Huawei实现Spring Cloud注册。 </li> |
| <li>Spring Cloud访问Java Chassis,只需要一个地址信息,依赖较少。 Java Chassis访问Spring Cloud,需要知道Spring Cloud应用提供的契约信息。 </li> |
| </ul> |
| <p>Java Chassis区别于Spring Cloud的REST调用的部分,就是契约依赖。 Spring Cloud通过FeignClient来声明客户端契约,客户端都需要在FeignClient中重复书写REST标签;Java Chassis有两种模式发现契约:从注册中心发现和从Provider实例发现。 Java Chassis3默认采用从Provider实例发现, Java Chassis2采用从注册中心发现。 从Provider发现的好处是可以降低对于注册中心元数据管理能力的要求,本例既可以采用 <code>Service Center</code> 作为注册中心,也可以选择 <code>Nacos</code> 作为注册中心。 </p> |
| <p>从Provider发现,要求Provider实现如下接口:</p> |
| <pre><code class="language-java">/** |
| * Java Chassis internal management apis. |
| */ |
| @Path("/scb/management") |
| public interface ManagementEndpoint { |
| String NAME = "scb-management"; |
| |
| /** |
| * Health of this instance. If the instanceId match this instance, and this service is ready |
| * to service return true. Otherwise, return false. |
| * |
| * This api is for internal instance status usage. Load balancer will call this api to check if |
| * the target instance is alive. |
| */ |
| @GET |
| @Path("/health") |
| boolean health(@QueryParam("instanceId") String instanceId, @QueryParam("registryName") String registryName); |
| |
| /** |
| * Schemas of this instance. |
| * |
| * This api is for internal schema loading usage. |
| */ |
| @POST |
| @Path("/schema/contents") |
| Map<String, String> schemaContents(); |
| } |
| </code></pre> |
| <p>它包含一个健康检查接口和一个查询契约的接口。 当Spring Cloud应用实现上述接口以后,它就具备了Java Chassis微服务需要的基础特征,这样Java Chassis就可以像访问本框架的微服务一样访问Spring Cloud框架开发的微服务应用。 为了简化,在Spring Cloud简单实现了该接口,该实现接口从 <code>export</code> 目录加载契约信息,只需要将Spring Cloud需要对外暴露的 REST 接口的符合 Open API 3.0规范的契约文件放到这个目录下面 。</p> |
| <pre><code class="language-java">@RestController |
| @RequestMapping(("/scb/management")) |
| public class JavaChassisManagementEndpoint { |
| private static final Logger LOGGER = LoggerFactory.getLogger(JavaChassisManagementEndpoint.class); |
| |
| @Autowired |
| private Registration registration; |
| |
| @GetMapping(path = "/health") |
| public boolean health(@RequestParam("instanceId") String instanceId, |
| @RequestParam("registryName") String registryName) { |
| return "sc-registry".equals(registryName) && registration.getInstanceId().equals(instanceId); |
| } |
| |
| @PostMapping(path = "/schema/contents") |
| public Map<String, String> schemaContents() { |
| try { |
| List<URI> resourceUris = ResourceUtil.findResourcesBySuffix("export", ".yaml"); |
| Map<String, String> result = new HashMap<>(resourceUris.size()); |
| for (URI uri : resourceUris) { |
| String path = uri.toURL().getPath(); |
| String[] segments = path.split("/"); |
| if (segments.length < 2 || !"export".equals(segments[segments.length - 2])) { |
| continue; |
| } |
| result.put(segments[segments.length - 1].substring(0, segments[segments.length - 1].indexOf(".yaml")), |
| IOUtils.toString(uri, StandardCharsets.UTF_8)); |
| } |
| return result; |
| } catch (IOException | URISyntaxException e) { |
| LOGGER.error("Load schema ids failed from microservices. {}.", e.getMessage()); |
| return Collections.emptyMap(); |
| } |
| } |
| } |
| </code></pre> |
| <p>Java Chassis与Spring Cloud互操作的例子放到了<a href="https://github.com/apache/servicecomb-samples/tree/master/java-chassis-interoprability">ServiceComb Samples</a> , 这个例子也提供了使用 Nacos 作为注册中心和配置中心的实现, 只需要将 Profile 设置为 Nacos 即可。 </p> |
| <blockquote> |
| <blockquote> |
| <blockquote> |
| <p>客户故事:在架构选型变化的时候,解决功能迁移和兼容性问题是最大的挑战。一些客户将Spring Cloud应用改造为Java Chassis的过程中,发现一些功能不支持,比如SseEmitter、WebSocket等。 如果选择支持这些能力,Java Chassis需要实现很多Servlet能力,这些能力规划会和微服务技术架构存在冲突。 对于这些场景,我们选择通过架构韧性来保留这些功能,比如将提供SseEmitter、WebSocket功能的独立出微服务,采用Spring Boot开发,这些应用可以通过调用Java Chassis微服务的REST接口来实现其特殊功能。通过这种架构韧性的理念,降低了技术持续演进的包袱,为敏捷迭代,持续创新奠定了方向,减少了兼容性问题的争论。 </p> |
| </blockquote> |
| </blockquote> |
| </blockquote> |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| </article> |
| </div> |
| |
| |
| <script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script> |
| </div> |
| |
| </main> |
| |
| <footer class="md-footer"> |
| |
| <div class="md-footer-meta md-typeset"> |
| <div class="md-footer-meta__inner md-grid"> |
| <div class="md-copyright"> |
| |
| |
| Made with |
| <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener"> |
| Material for MkDocs |
| </a> |
| |
| </div> |
| |
| </div> |
| </div> |
| </footer> |
| |
| </div> |
| <div class="md-dialog" data-md-component="dialog"> |
| <div class="md-dialog__inner md-typeset"></div> |
| </div> |
| |
| |
| <script id="__config" type="application/json">{"base": "../..", "features": [], "search": "../../assets/javascripts/workers/search.b8dbb3d2.min.js", "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}}</script> |
| |
| |
| <script src="../../assets/javascripts/bundle.dd8806f2.min.js"></script> |
| |
| |
| </body> |
| </html> |