Java面試高頻問題(31-33)

?

三十一、服務網格:東西向流量治理與故障注入

?

?服務網格架構分層

mermaid

graph BT

? ? subgraph Control Plane

? ? ? ? APilot --> BEnvoy Sidecar

? ? ? ? CMixer --> B

? ? ? ? DCitadel --> B

? ? end

? ? subgraph Data Plane

? ? ? ? B --> E服務A

? ? ? ? B --> F服務B

? ? ? ? B --> G服務C

? ? end

?

?核心能力矩陣

?功能維度 Istio實現方案 Linkerd方案 技術選型點?

?流量路由 VirtualService+DestinationRule ServiceProfile 細粒度權重控制?

?可觀測性 Prometheus+Grafana+Jaeger Prometheus+TraceID 指標采集開銷對比?

?安全通信 mTLS雙向認證+RBAC 自動mTLS 證書輪轉機制?

?故障注入 HTTPFaultInjection Chaos Mesh集成 灰度故障注入能力?

?

?流量染色與金絲雀發布

java

// Istio VirtualService配置示例

VirtualService userVs = new VirtualServiceBuilder()

? ? .withHost("user-service")

? ? .addHttpRoute(new HTTPRoute()

? ? ? ? .withMatch(new HTTPMatchRequest()

? ? ? ? ? ? .setHeaders(Collections.singletonMap("x-version", "v2")))

? ? ? ? .setRoute(Collections.singletonList(

? ? ? ? ? ? new HTTPRouteDestination()

? ? ? ? ? ? .setSubset("v2")

? ? ? ? ? ? .setWeight(30))))

? ? .addHttpRoute(new HTTPRoute()

? ? ? ? .setRoute(Collections.singletonList(

? ? ? ? ? ? new HTTPRouteDestination()

? ? ? ? ? ? .setSubset("v1")

? ? ? ? ? ? .setWeight(70))))

? ? .build();

?

?

?三十二、分布式事務:Saga模式與TCC模式對比

?

?Saga事務執行流程

mermaid

sequenceDiagram

? ? participant Order

? ? participant Inventory

? ? participant Payment

? ??

? ? Order->>Inventory: 預扣庫存(Try)

? ? Inventory-->>Order: 庫存鎖定

? ? Order->>Payment: 預授權支付(Try)

? ? Payment-->>Order: 支付凍結

? ? Note right of Order: 正常流程提交

? ? Order->>Inventory: 提交庫存

? ? Inventory-->>Order: 扣減完成

? ? Order->>Payment: 提交支付

? ? Payment-->>Order: 支付完成

? ??

? ? rect rgba(255,0,0,0.1)

? ? Note left of Order: 異常補償流程

? ? Order->>Payment: 取消支付(Cancel)

? ? Payment-->>Order: 釋放凍結

? ? Order->>Inventory: 回滾庫存(Cancel)

? ? Inventory-->>Order: 庫存恢復

? ? end

?

?Seata AT模式核心機制

java

@GlobalTransactional

public void createOrder(Order order) {

? ? // 本地事務

? ? inventoryDao.deductStock(order.getProductId());

? ? paymentDao.freezeBalance(order.getUserId(), order.getAmount());

? ??

? ? // 記錄全局事務日志(TC協調)

? ? GlobalTransaction tx = GlobalTransactionManager.begin();

? ? BranchTransaction tx1 = BranchTransactionManager.register(

? ? ? ? "inventory",?

? ? ? ? "deductStock",?

? ? ? ? order.getId()

? ? );

? ? BranchTransaction tx2 = BranchTransactionManager.register(

? ? ? ? "payment",?

? ? ? ? "freezeBalance",?

? ? ? ? order.getId()

? ? );

}

?

?事務模式對比分析

?模式 數據一致性 補償復雜度 適用場景?

?Saga 最終一致 高(需逆向操作) 長事務跨多個微服務?

?TCC 最終一致 中(需Try/Confirm/Cancel) 高并發強隔離場景?

?XA 強一致 低(數據庫原生支持) 金融核心交易系統?

?

?

?三十三、混沌工程:故障注入策略與容錯驗證

?

混沌工程成熟度模型

mermaid

graph LR

? ? A穩定態假設 --> B故障注入

? ? B --> C故障傳播分析

? ? C --> D自愈能力驗證

? ? D --> E架構韌性優化

?

混沌實驗設計模板

yaml

?ChaosBlade網絡故障注入配置

apiVersion: chaosblade.io/v1alpha1

kind: ChaosBlade

metadata:

? name: network-latency

spec:

? experiments:

? - scope: pod

? ? target: network

? ? action: delay

? ? desc: "模擬服務間網絡延遲"

? ? matchers:

? ? - name: names

? ? ? value:

? ? ? - "order-service-.*"

? ? - name: namespace

? ? ? value: "production"

? ? - name: delay

? ? ? value: "300ms"

? ? - name: correlation

? ? ? value: "100%"

?

?容錯能力評估指標

?指標類別 監控項 健康閾值?

?故障檢測速度 熔斷觸發時間 < 500ms?

?服務降級效果 錯誤率波動幅度 < 5%?

?自愈恢復能力 平均恢復時間(MTTR) < 30s?

?資源隔離性 跨服務錯誤傳播率 0%?

?

?

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

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

相關文章

初學python的我開始Leetcode題8-3

提示&#xff1a;100道LeetCode熱題-8-3主要是二叉樹相關&#xff0c;包括三題&#xff1a;將有序數組轉換為二叉搜索樹、驗證二叉搜索樹、二叉搜索樹中第K小的元素。由于初學&#xff0c;所以我的代碼部分僅供參考。 目錄 前言 題目1&#xff1a;將有序數組轉換為二叉搜索樹…

1996-2022年全國31省ZF干預度數據/財政干預度數據(含原始數據+計算過程+結果)

1996-2022年全國31省ZF干預度數據/財政干預度數據&#xff08;含原始數據計算過程結果&#xff09; 1、時間&#xff1a;1996-2022年 2、來源&#xff1a;國家統計局和各省年鑒 3、指標&#xff1a;地方財政一般預算支出、地區生產總值&#xff08;GDP&#xff09;、ZF干預度…

g4f升級到0.5.2.0版本了,但是有些機器無法運行,只能降級到0.5.1.2版本

g4f升級到0.5.2.0版本了&#xff0c;跟0.5.1.2更以前的版本相比&#xff0c;主要更新為增加了可以設置Huggingface等供應商的key Providers API key HuggingFace:Get API key HuggingSpace: 因為很多模型都會調用Huggingface&#xff0c;所以最好設置Huggingface的API key。…

C語言教程(二十五):C 語言函數可變參數詳解

引言: 在 C 語言編程中,有時我們需要處理參數數量不固定的情況,比如常見的 printf 函數,它可以根據格式化字符串的要求接受任意數量的參數。這種能接受不確定數量參數的函數,就是可變參數函數。下面將深入探討其定義、實現原理、使用方式、示例以及注意事項。 一、可變參…

OpenStack Yoga版安裝筆記(25)Nova Cell理解

1、Nova Cell概述 &#xff08;官方文檔&#xff1a;Cells (v2) — nova 25.2.2.dev5 documentation&#xff09; Nova中的cells功能的目的是允許較大的部署將其多個計算節點分割成多個cell。所有的nova部署都默認是cell部署&#xff0c;即使大多數情況下只有單一cell。這意味…

Java Set<String>:如何高效判斷是否包含指定字符串?

在 Java 開發中&#xff0c;我們經常使用 Set 集合來存儲一組唯一性的元素。特別是 HashSet&#xff0c;由于其基于哈希表的實現&#xff0c;在進行元素查找&#xff08;判斷是否包含&#xff09;時通常具有非常高的效率&#xff08;平均時間復雜度 O(1)&#xff09;。 那么&a…

MySQL 查找指定表名的表的主鍵

原理 SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE TABLE_NAME 表名 AND CONSTRAINT_NAME PRIMARY方法 public static String getPk(String tableName) {String sql "SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE TA…

Java大廠面試突擊:從Spring Boot自動配置到Kafka分區策略實戰解析

第一輪核心知識 面試官:請解釋Spring Boot中自動配置的工作原理并演示如何自定義一個@ConfigurationProperties組件? xbhog:自動配置通過EnableAutoConfiguration注解觸發,結合當前環境判斷(如是否檢測到MyBatis依賴)和條件注解(@ConditionalOnClass)來決定是否啟用配…

開發板型號 ESP32-DevKitC-32模塊型號 ESP32-WROOM-32 和主控芯片 ESP32-D0WDQ6-V3

以下是關于開發板型號 ESP32-DevKitC-32、模塊型號 ESP32-WROOM-32 和主控芯片 ESP32-D0WDQ6-V3 的詳細介紹&#xff1a; 開發板型號&#xff1a;ESP32-DevKitC-32 概述&#xff1a;ESP32-DevKitC 是樂鑫推出的一款基于 ESP32 模組的小型開發板&#xff0c;板上模組的絕大部…

數據庫系統綜合應用與深度實踐指南

前言 在當今數據驅動的時代&#xff0c;數據庫技術已成為信息系統的核心支柱。從簡單的數據存儲到復雜的企業級應用&#xff0c;數據庫系統支撐著現代社會的方方面面。本文作為一篇綜合性的數據庫科普文章&#xff0c;旨在為讀者提供從基礎到進階的完整知識體系&#xff0c;涵…

vscode 的空格和 tab 設置 與 Rime 自建詞庫

自動保存&#xff08;多用于失去焦點時保存&#xff09; Files: Auto Save 推薦不勾 保存時格式化&#xff08;Pritter 插件的功能&#xff0c;自動使用 Pritter 的格式&#xff09; Editor: Format On Save 推薦不勾 tab 的空格數量&#xff0c;2 或 4 Editor: Tab Size 推薦…

【Python爬蟲詳解】第五篇:使用正則表達式提取網頁數據

在前面幾篇文章中&#xff0c;我們介紹了幾種強大的HTML解析工具&#xff1a;BeautifulSoup、XPath和PyQuery。這些工具都是基于HTML結構來提取數據的。然而&#xff0c;有時我們需要處理的文本可能沒有良好的結構&#xff0c;或者我們只關心特定格式的字符串&#xff0c;這時正…

論文報錯3

idm不讓用&#xff1a; powershell管理員運行&#xff1a; irm https://raw.githubusercontent.com/lstprjct/IDM-Activation-Script/main/IAS.ps1 | iex 選擇1&#xff1a; 輸入9&#xff1a;

數據結構-樹(二叉樹、紅黑、B、B+等)

?樹的基本定義? 樹的定義 樹&#xff08;Tree&#xff09;?? 是一種 ??非線性數據結構??&#xff0c;由 ??節點&#xff08;Node&#xff09;?? 和 ??邊&#xff08;Edge&#xff09;?? 組成&#xff0c;滿足以下條件&#xff1a; ??有且僅有一個根節點&am…

【Android】四大組件

目錄 1. Activity 2. Service 3. BroadcastReceiver 4. ContentProvider 四大組件各自承擔著不同的職責&#xff0c;彼此之間協同工作&#xff0c;共同為用戶提供一個流暢的APP體驗。 1. Activity 負責展示用戶界面&#xff0c;就像App的一個個“頁面”&#xff0c;用戶通…

Java 多線程進階:線程安全、synchronized、死鎖、wait/notify 全解析(含代碼示例)

在 Java 并發編程中&#xff0c;“線程安全” 是核心議題之一。本文將深入講解線程安全的實現手段、synchronized 的使用方式、可重入鎖、死鎖的成因與避免、wait/notify 通信機制等&#xff0c;并配合實際代碼案例&#xff0c;幫助你徹底搞懂 Java 線程協作機制。 一、線程安全…

高并發場景下的MySQL生存指南

引言 在2025年全球數字經濟峰會上&#xff0c;阿里云披露其核心交易系統單日處理請求量突破萬億次&#xff0c;其中MySQL集群承載了78%的OLTP業務。這標志著數據庫系統已進入百萬級QPS時代&#xff0c;傳統優化手段面臨三大挑戰&#xff1a; 一、硬件與架構優化&#xff1a;構…

MCP入門

什么是mcp mcp&#xff08;model context protocol&#xff0c;模型上下文協議&#xff09; 標準化協議&#xff1a;讓大模型用統一的方式來調用工具&#xff0c;是llm和工具之間的橋梁 A2A&#xff1a;Agent-to-Agent協議 mcp通信機制 提供mcp服務查詢的平臺 具有工具合集…

服務容錯治理框架resilience4jsentinel基礎應用---微服務的限流/熔斷/降級解決方案

繼續上一章未完成的sentinel&#xff1b; 直接實操&#xff1b; 關于測試&#xff1a;本文使用線程池線程異步執行模擬并發結合Mock框架測試 其他文章 服務容錯治理框架resilience4j&sentinel基礎應用---微服務的限流/熔斷/降級解決方案-CSDN博客 conda管理python環境-…

深入理解 C 語言中的變量作用域與鏈接性:`extern`、`static` 與全局變量

深入理解 C 語言中的變量作用域與鏈接性&#xff1a;extern、static 與全局變量 在 C 語言中&#xff0c;變量的作用域&#xff08;Scope&#xff09;和鏈接性&#xff08;Linkage&#xff09;是理解程序結構和模塊化的關鍵概念。本文將詳細探討在函數外定義的變量是否為全局變…