七天學會SpringCloud分布式微服務——03——Nacos遠程調用

1、微服務項目配置類放在地方

配置類型應放位置說明
通用配置類
(如:跨服務通用的攔截器、全局異常處理、統一響應體封裝等)
可放在一個**公共模塊(common/config)**中,被各服務引入實現代碼復用,避免重復
服務專屬配置類
(如:服務特有的 Feign 配置、服務自己的攔截器、服務的業務 Bean 配置)
應該放在該微服務自己的模塊中遵循“高內聚,低耦合”原則,不污染其他服務
網關、注冊中心、配置中心等基礎服務的配置類放在對應網關或中心服務模塊專責專屬

2、Nacos注冊中心宕機了,遠程調用還能使用嗎

  • 如果調用過就可以,如果沒有調用過就不可以

3、 遠程調用的三種方式(以order微服務調用product為例)

3.1 首先就是要獲取到service-product的微服務

  • 引入依賴
        <!-- Nacos服務發現 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
  • 注入@Resource DiscoveryClient discoveryClient
  • 獲取所有service-product微服務實例
// 1、獲取product的所有ip+端口號,因為要遠程調用了嗎List<ServiceInstance> instances = discoveryClient.getInstances("service-product");

3.2 如何發送調用呢

選擇RestTemplate 或者 WebClient,這里使用前者

  • 編寫配置類:
@Configuration
public class AppConfig {@Beanpublic RestTemplate restTemplate() {return new RestTemplate();}
}
  • 注入配置類 @Resource RestTemplate restTemplate
  • 使用
    	// 3、拼接遠程URLString url = "http://"+serviceInstance.getHost()+":"+serviceInstance.getPort()+"/product/"+productId;// 4、給遠程發請求return restTemplate.getForObject(url, Product.class);

3.3 負載均衡的遠程調用

  • 引入依賴:
       <!--負載均衡依賴--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency></dependencies>
  • 注入依賴 @Resource LoadBalancerClient loadBalancerClient;
  • 使用
 private Product getProductFromRemoteBalance(Long productId){// 1、chooseServiceInstance choose = loadBalancerClient.choose("service-product");// 2、拼接遠程URLString url = "http://"+choose.getHost()+":"+choose.getPort()+"/product/"+productId;System.out.println(url);// 3、給遠程發請求return restTemplate.getForObject(url, Product.class);}

3.4 負載均衡遠程調用注解(推薦,不用獲取服務了)

  • 在遠程調用配置類中加入注解@LoadBalanced
@Configuration
public class ServiceConfig {/*遠程調用自動負載均衡*/@LoadBalanced@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}
  • 使用
 private Product getProductFromRemoteWithAno(Long productId){// 1、拼接遠程URLString url = "http://service-product/product/"+productId;System.out.println(url);// 2、給遠程發請求return restTemplate.getForObject(url, Product.class);}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/86811.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/86811.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/86811.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基于Java+Spring Boot的校園閑置物品交易系統

源碼編號&#xff1a;S561 源碼名稱&#xff1a;基于Spring Boot的校園閑置物品交易系統 用戶類型&#xff1a;多角色&#xff0c;用戶、商家、管理員 數據庫表數量&#xff1a;12 張表 主要技術&#xff1a;Java、Vue、ElementUl 、SpringBoot、Maven 運行環境&#xff1…

SpringBoot 的 jar 包為什么可以直接運行?

一、普通jar包和SpringBoot jar包有什么區別&#xff1f;什么是jar包&#xff1f;&#xff1f; &#xff08;1&#xff09;什么是Jar包&#xff1f; 定義&#xff1a; JAR 包&#xff08;Java Archive&#xff09; 是 Java 平臺標準的歸檔文件格式&#xff0c;用于將多個 Jav…

算法-基礎算法-遞歸算法(Python)

文章目錄 前言遞歸和數學歸納法遞歸三步走遞歸的注意點避免棧溢出避免重復運算 題目斐波那契數反轉鏈表 前言 遞歸&#xff08;Recursion&#xff09;&#xff1a;指的是一種通過重復將原問題分解為同類的子問題而解決的方法。在絕大數編程語言中&#xff0c;可以通過在函數中再…

TVFEMD-CPO-TCN-BiLSTM多輸入單輸出模型

47-TVFEMD-CPO-TCN-BiLSTM多輸入單輸出模型 適合單變量&#xff0c;多變量時間序列預測模型&#xff08;可改進&#xff0c;加入各種優化算法&#xff09; 時變濾波的經驗模態分解TVFEMD時域卷積TCN雙向長短期記憶網絡BiLSTM時間序列預測模型 另外以及有 TCN-BILSTM …

深入淺出Node.js中間件機制

我們用一個實際的例子來看看中間件是如何運作的。假設我們有一個非常簡單的Express應用&#xff0c;它只有兩個中間件函數&#xff1a; const express require(express); const app express();app.use((req, res, next) > {console.log(第一個中間件);next(); });app.use…

Vue-15-前端框架Vue之應用基礎編程式路由導航

文章目錄 1 RouterLink的replace屬性1.1 App.vue1.2 應用效果2 編程式路由導航2.1 場景一Home.vue2.2 場景二News.vue3 路由重定向3.1 index.ts3.2 Detail.vue3.3 About.vue1 RouterLink的replace屬性 路由每次跳轉都有記錄,默認是push,可以改為replace。 RouterLink支持兩…

android14 設置下連續點擊5次Settings標題跳轉到撥號界面

部分項目隱藏了撥號器&#xff0c;但開發者需要間距跳轉到撥號界面 設置一級界面&#xff1a; packages/apps/Settings/src/com/android/settings/homepage/SettingsHomepageActivity.java 通過dispatchTouchEvent方法先獲取Settings標題的區域X,Y數據。 import java.util.Set…

MP分頁和連表常用寫法

1. 分頁查詢 方案一&#xff1a;MyBatis XML MyBatis 內置的使用方式&#xff0c;步驟如下&#xff1a; ① 創建 AdminUserMapper.xml 文件&#xff0c;編寫兩個 SQL 查詢語句&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE m…

使用 Spring AI Alibaba構建 AI Code Review 應用

很早的時候就想著用AI來做Code Review&#xff0c;最近也看到了一些不錯的實現&#xff0c;但是沒有一個使用Java來構建的&#xff0c;看的比較費勁&#xff0c;雖然說語言只是一種工具&#xff0c;但是還是想用Java重新寫一遍&#xff0c;正好最近Spring AI Alibaba出了正式版…

力扣1590. 使數組和能被 P 整除

這一題的難點在于模運算&#xff0c;對模運算足夠了解&#xff0c;對式子進行變換就很容易得到結果&#xff0c;本質上還是一道前綴和哈希表的題 這里重點講一下模運算。 常見的模運算的用法 (a-b)%k0等價于 a%kb%k 而在這一題中由于多了一個len&#xff0c;&#xff08;數組的…

FPGA內部資源介紹

FPGA內部資源介紹 目錄 邏輯資源塊LUT&#xff08;查找表&#xff09;加法器寄存器MUX&#xff08;復用器&#xff09;時鐘網絡資源 全局時鐘網絡資源區域時鐘網絡資源IO時鐘網絡資源 時鐘處理單元BLOCK RAMDSP布線資源接口資源 用戶IO資源專用高速接口資源 總結 1. 邏輯資源…

CSS 列表

CSS 列表 引言 CSS 列表是網頁設計中常用的一種布局方式&#xff0c;它能夠幫助我們以更靈活、更美觀的方式展示數據。本文將詳細介紹 CSS 列表的創建、樣式設置以及常用技巧&#xff0c;幫助您更好地掌握這一重要技能。 CSS 列表概述 CSS 列表主要包括兩種類型&#xff1a…

spring中的@Cacheable緩存

1. 使用方法 在方法上面加上注解Cacheable&#xff0c; OverrideCacheable(cacheNames "userCache", key "#id")public User getUserById(Long id) {System.out.println("查詢數據庫了");return getById(id);}如果你的項目中引入了&#xff…

Node.js特訓專欄-實戰進階:9.MySQL連接池配置與優化

?? 歡迎來到 Node.js 實戰專欄!在這里,每一行代碼都是解鎖高性能應用的鑰匙,讓我們一起開啟 Node.js 的奇妙開發之旅! Node.js 特訓專欄主頁 專欄內容規劃詳情 MySQL連接池配置與優化:提升數據庫交互性能的關鍵 一、MySQL連接池基礎概念 1.1 什么是連接池? 連接池是…

【innovus基礎】- 如何手動畫線?

后端實現的過程就是將邏輯連線變為物理的金屬連線的過程。 1、打開Pin shape的Visible 和 Selected開關&#xff0c;使其可見并可選 2、選中想要畫線的IOCell 3、鼠標選中對應的pin 4、使用dbGet 獲取此pin腳邏輯連線net的名字&#xff1b; dbGet selected.net.name 5、使用畫…

element-plus限制日期可選范圍(這里以7天為例)

element-plus日期范圍限制功能實現邏輯 1. 需求&#xff1a;通過限制時間的可選范圍減少請求的數據量 2. 實現效果&#xff1a; 日期選擇器做限制 3. 代碼邏輯&#xff1a; 思路&#xff1a;通過calendar-change獲取開始日期&#xff0c;然后通過disabled-date禁用不滿足條件…

機器學習2-梯度下降與反向傳播

損失函數 與 平均方差函數 傻傻分不清 損失函數是概念&#xff1b;平均方差函數是具體的實現 損失函數&#xff08;如均方誤差 MSE&#xff09;用于衡量模型預測值與真實值之間的差距。損失越小&#xff0c;說明模型對當前數據的擬合越好。 但模型并非擬合度越高越好&#xf…

安全生產風險管控平臺:企業安全管理的智能化解決方案

在工業生產、建筑施工、能源化工等領域&#xff0c;安全生產是企業可持續發展的基石。然而&#xff0c;傳統安全管理模式依賴人工巡檢、紙質記錄和事后處理&#xff0c;難以滿足現代化企業的高效風險管控需求。安全生產風險管控平臺應運而生&#xff0c;它利用物聯網、大數據、…

如何保證數據庫與 Redis 緩存的一致性?

在現代互聯網應用中&#xff0c;Redis 緩存幾乎是性能優化的標配。但在使用過程中&#xff0c;一個繞不過去的問題就是&#xff1a; 如何保證 Redis 緩存與數據庫之間的數據一致性&#xff1f; 特別是在高并發場景下&#xff0c;讀寫操作錯位可能導致緩存中出現臟數據&#xff…

現代 JavaScript (ES6+) 入門到實戰(三):字符串與對象的魔法升級—模板字符串/結構賦值/展開運算符

在前兩篇&#xff0c;我們升級了變量和函數。今天&#xff0c;我們要給 JavaScript 中最常用的兩種數據類型——字符串&#xff08;String&#xff09;和對象&#xff08;Object&#xff09;——裝備上 ES6 帶來的強大魔法。 準備好告別丑陋的 號拼接和重復的對象屬性賦值了嗎…