成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Dubbo中用到了哪些設計模式?

開發 前端
當工廠想提供更多產品時,還得對創建過程進行修改,因此抽象出一個工廠類,當增加一種產品,就增加一個工廠類(繼承抽象工廠類或實現接口)。

[[404370]]

介紹

策略模式

這個毫無爭議,Dubbo是基于SPI來擴展的,SPI就是典型的策略模式。

Dubbo中可替換的組件太多了,例如負載均衡策略

實現類 解釋
RandomLoadBalance 隨機策略(默認)
RoundRobinLoadBalance 輪詢策略
LeastActiveLoadBalance 最少活躍調用數
ConsistentHashLoadBalance 一致性hash策略

工廠模式

「簡單工廠模式」:提供一個方法,返回創建好的對象

  1. public class VideoFactory { 
  2.  
  3.     public static Video getVideo(String type) { 
  4.         if ("java".equalsIgnoreCase(type)) { 
  5.             return new JavaVideo(); 
  6.         } else if ("python".equalsIgnoreCase(type)) { 
  7.             return new PythonVideo(); 
  8.         } 
  9.         return null
  10.     } 

「工廠方法模式」:當工廠想提供更多產品時,還得對創建過程進行修改,因此抽象出一個工廠類,當增加一種產品,就增加一個工廠類(繼承抽象工廠類或實現接口)。這樣就實現了對擴展開發,對修改關閉

  1. public abstract class VideoFactory { 
  2.  
  3.     public abstract Video getVideo(); 
  4. public class JavaVideoFactory extends VideoFactory { 
  5.     public Video getVideo() { 
  6.         return new JavaVideo(); 
  7.     } 
  8. public class Test { 
  9.  
  10.     public static void main(String[] args) { 
  11.         VideoFactory videoFactory = new JavaVideoFactory(); 
  12.         Video video = videoFactory.getVideo(); 
  13.         // 學習Java視頻 
  14.         video.study(); 
  15.     } 

「抽象工廠模式」:當生產的產品較多時,如果我們用工廠方法模式會造成類爆照,此時我們就可以把相關的產品生產放到一個工廠類中

  1. public abstract class CourseFactory { 
  2.  
  3.     public abstract Video getVideo(); 
  4.     public abstract Article getArticle(); 
  5. public class JavaCourseFactory extends CourseFactory { 
  6.     public Video getVideo() { 
  7.         return new JavaVideo(); 
  8.     } 
  9.  
  10.     public Article getArticle() { 
  11.         return new JavaArticle(); 
  12.     } 

因為JavaVideo和JavaArticle都是Java相關的資料,所以可以用一個工廠類來生產。如果用工廠方法模式來設計的話,JavaVideo和JavaArticle都會有一個對應的工廠類

簡單工廠模式

  1. public class LoggerFactory { 
  2.  
  3.     public static Logger getLogger(Class<?> key) { 
  4.         return LOGGERS.computeIfAbsent(key.getName(), name -> new FailsafeLogger(LOGGER_ADAPTER.getLogger(name))); 
  5.     } 

工廠方法模式

Dubbo可以對結果進行緩存,緩存的策略有很多種,一種策略對應一個緩存工廠類

  1. @SPI("lru"
  2. public interface CacheFactory { 
  3.  
  4.     @Adaptive("cache"
  5.     Cache getCache(URL url, Invocation invocation); 
  6.  

抽象工廠模式

在RPC框架中,客戶端發送請求和服務端執行請求的過程都是由代理類來完成的。客戶端的代理對象叫做Client Stub,服務端的代理對象叫做Server Stub。

  1. @SPI("javassist"
  2. public interface ProxyFactory { 
  3.  
  4.     // 針對consumer端,創建出代理對象 
  5.     @Adaptive({Constants.PROXY_KEY}) 
  6.     <T> T getProxy(Invoker<T> invoker) throws RpcException; 
  7.  
  8.     // 針對consumer端,創建出代理對象 
  9.     @Adaptive({Constants.PROXY_KEY}) 
  10.     <T> T getProxy(Invoker<T> invoker, boolean generic) throws RpcException; 
  11.  
  12.     // 針對provider端,將服務對象包裝成一個Invoker對象 
  13.     @Adaptive({Constants.PROXY_KEY}) 
  14.     <T> Invoker<T> getInvoker(T proxy, Class<T> type, URL url) throws RpcException; 
  15.  

單例模式

服務導出的過程中,為了防止開啟多個NettyServer,用了單例模式

  1. private void openServer(URL url) { 
  2.     // find server. 
  3.     String key = url.getAddress(); 
  4.     //client can export a service which's only for server to invoke 
  5.     boolean isServer = url.getParameter(Constants.IS_SERVER_KEY, true); 
  6.     if (isServer) { 
  7.         ExchangeServer server = serverMap.get(key); 
  8.         if (server == null) { 
  9.             synchronized (this) { 
  10.                 server = serverMap.get(key); 
  11.                 if (server == null) { 
  12.                     // 創建服務器實例 
  13.                     serverMap.put(key, createServer(url)); 
  14.                 } 
  15.             } 
  16.         } else { 
  17.             // server supports reset, use together with override 
  18.             server.reset(url); 
  19.         } 
  20.     } 

裝飾者模式

Dubbo中網絡傳輸層用到了Netty,當我們用Netty開發時,一般都是寫多個ChannelHandler,然后將這些ChannelHandler添加到ChannelPipeline上,就是典型的責任鏈模式

但是Dubbo考慮到有可能替換網絡框架組件,所以整個請求發送和請求接收的過程全部用的都是裝飾者模式。即只有NettyServerHandler實現的接口是Netty中的ChannelHandler,剩下的接口實現的是Dubbo中的ChannelHandler

如下是服務端消息接收會經過的ChannelHandler

代理模式

前面說過了哈,Client Stub和Server Stub都是代理對象

適配器模式

Dubbo可以支持多個日志框架,每個日志框架的實現都有對應的Adapter類,為什么要搞Adapter類呢,因為Dubbo中日志接口Logger用的是自己的,而實現類是引入的。但這些日志實現類的等級和Dubbo中定義的日志等級并不完全一致,例如JdkLogger中并沒有trace和debug這個等級,所以要用Adapter類把Logger中的等級對應到實現類中的合適等級

  1. public interface Logger 
  2.  
  3.     // 省略部分代碼 
  4.      
  5.     void trace(String msg); 
  6.  
  7.     void debug(String msg); 
  8.  
  9.     void info(String msg); 
  10.  
  11.     void warn(String msg); 
  12.  

Dubbo接口中定義的日志等級 JdkLogger對應的日志等級 Slf4jLogger對應的日志等級
trace finer trace
debug finer debug
info info info

觀察者模式

在Dubbo中提供了各種注冊中心的實現,類圖如下。AbstractRegistry對注冊中心的內容進行了緩存,這樣能保證當注冊中心不可用的時候,還能正常提供服務

「既然對注冊中心的內容進行了緩存,那么注冊中心的內容發生改變的時候,怎么通知客戶端呢?」

例如客戶端從注冊中心獲取到服務端的地址,并緩存到本地,如果服務端宕機了,本地緩存怎么清除呢?此時就得需要對有可能變動的節點進行訂閱。當節點發生變化的時候,就能收到通知,這樣就能更新本地緩存。

NotifyListener就是接收節點變動的接口,各種注冊中心的節點發生變化都會主動回調這個接口

  1. public interface RegistryService { 
  2.  
  3.     // 注冊 
  4.     void register(URL url); 
  5.  
  6.     // 注銷 
  7.     void unregister(URL url); 
  8.  
  9.     // 訂閱,訂閱的數據發生變化,會主動通知NotifyListener#notify方法 
  10.     void subscribe(URL url, NotifyListener listener); 
  11.  
  12.     // 退訂 
  13.     void unsubscribe(URL url, NotifyListener listener); 
  14.  
  15.     // 查找服務地址 
  16.     List<URL> lookup(URL url); 
  17.  

責任鏈模式

代理對象(Client Stub或者Server Stub)在執行的過程中會執行所有Filter的invoke方法,但是這個實現方法是對對象不斷進行包裝,看起來非常像裝飾者模式,但是基于方法名和這個Filter的功能,我更覺得這個是責任鏈模式

  1. private static <T> Invoker<T> buildInvokerChain(final Invoker<T> invoker, String key, String group) { 
  2.     Invoker<T> last = invoker; 
  3.     // 獲取自動激活的擴展類 
  4.     List<Filter> filters = ExtensionLoader.getExtensionLoader(Filter.class).getActivateExtension(invoker.getUrl(), keygroup); 
  5.     if (!filters.isEmpty()) { 
  6.         for (int i = filters.size() - 1; i >= 0; i--) { 
  7.             final Filter filter = filters.get(i); 
  8.             final Invoker<T> next = last
  9.             last = new Invoker<T>() { 
  10.  
  11.                 // 省略部分代碼 
  12.  
  13.                 @Override 
  14.                 public Result invoke(Invocation invocation) throws RpcException { 
  15.                     // filter 不斷的套在 Invoker 上,調用invoke方法的時候就會執行filter的invoke方法 
  16.                     Result result = filter.invoke(next, invocation); 
  17.                     if (result instanceof AsyncRpcResult) { 
  18.                         AsyncRpcResult asyncResult = (AsyncRpcResult) result; 
  19.                         asyncResult.thenApplyWithContext(r -> filter.onResponse(r, invoker, invocation)); 
  20.                         return asyncResult; 
  21.                     } else { 
  22.                         return filter.onResponse(result, invoker, invocation); 
  23.                     } 
  24.                 } 
  25.  
  26.             }; 
  27.         } 
  28.     } 
  29.     return last

本文轉載自微信公眾號「Java識堂」,可以通過以下二維碼關注。轉載本文請聯系Java識堂公眾號。

 

責任編輯:武曉燕 來源: Java識堂
相關推薦

2022-09-21 09:01:27

Spring設計模式框架,

2023-07-11 08:50:34

2020-03-18 09:43:37

開發技能代碼

2024-11-26 14:29:48

2019-05-29 17:20:07

Spring設計模式Java

2020-01-02 15:43:29

Spring設計策略

2021-05-31 07:58:59

Spring設計模式

2021-10-27 17:57:35

設計模式場景

2023-10-04 07:27:33

WebPhotoshop

2025-05-09 09:05:00

Spring框架設計模式

2025-05-12 07:43:14

SpringMVC設計模式代碼

2021-08-11 17:22:11

設計模式單例

2010-05-11 14:23:05

Unix命令

2021-02-15 22:07:18

項目策略模式

2011-09-08 16:30:59

SQL Server查詢

2010-04-02 10:04:21

Oracle結構

2019-11-07 11:49:14

架構運維技術

2021-10-29 09:40:21

設計模式軟件

2022-05-16 08:09:45

前端API

2019-04-24 09:43:46

代碼開發工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品视频一区 | 国产 日韩 欧美 在线 | 91精品国产91 | 在线观看国产91 | 蜜桃视频在线观看免费视频网站www | 成人欧美一区二区三区 | 日韩不卡视频在线 | 人人射人人插 | 九九精品在线 | 欧美午夜精品理论片a级按摩 | 国产精品久久久久久久久动漫 | 韩国精品一区二区三区 | 日韩欧美中文字幕在线观看 | 国产午夜精品一区二区三区嫩草 | 国产成人网 | 日韩欧美在线播放 | 亚洲综合视频一区 | 日本午夜在线视频 | 成人激情视频网 | 日本字幕在线观看 | 欧美一区二区三区国产 | 丁香综合 | 蜜桃av鲁一鲁一鲁一鲁 | 日韩手机在线视频 | 91视视频在线观看入口直接观看 | 久久久久久国产精品免费免费 | 性一爱一乱一交一视频 | 国产一区二区不卡 | av网站免费看| 国内精品久久久久久 | 国产精品99999 | 激情视频一区 | 999热精品视频 | 日本黄色一级片视频 | 亚洲成人黄色 | 国产精品18久久久 | 日韩精品在线视频免费观看 | 青青久久av北条麻妃海外网 | 国产成人精品一区二区三区网站观看 | 欧美 日本 国产 | 国产精品视频一区二区三区 |