微服務面試題之套路一

面試題

一、你的項目是從SpringBoot演進到微服務架構的,你在此過程中有調研過哪些技術,怎么調研落地的?

微服務通信框架:

需要選擇適合項目的微服務通信框架,如Dubbo、Spring Cloud或gRPC Feign RestTemplate 等。調研方式可以是通過官方文檔、技術交流社區和開源項目等途徑了解各個框架的優缺點,并根據項目需求進行選型。

容器化技術:

為了更好地管理微服務,需要將每個服務打包成容器鏡像,如Docker等。調研方式可以是通過官方文檔、技術交流社區和實踐案例等途徑了解Docker的使用方法和最佳實踐,并學習如何將Spring Boot應用打包成Docker鏡像。

服務注冊與發現:

微服務架構中的服務數量眾多,需要通過服務注冊與發現來定位和調用其他服務。調研方式可以是通過官方文檔、技術交流社區和開源項目等途徑了解ZooKeeper、Eureka或Nacos 等服務注冊與發現框架的原理和使用方法。

分布式事務:

在微服務架構中,需要保證事務的一致性和可靠性。調研方式可以是通過官方文檔、技術交流社區和開源項目等途徑了解Seata、Atomikos或Spring Cloud Transaction等分布式事務框架的原理和使用方法。

監控和日志管理:

微服務架構中的系統復雜度較高,需要對各個服務的性能和異常情況進行監控和日志管理。調研方式可以是通過官方文檔、技術交流社區和開源項目等途徑了解Prometheus、Grafana、Logstash或Kibana等監控和日志管理工具的原理和使用方法。

Api網關

Api網關是微服務架構中的重要組件 Zuul \ Gateway 等 我會部署一個Api網關 所有的外部請求都會先經過API 網關 再由Api 網關路由到相應的服務器. 以上是將SpringBoot項目演進到微服務架構過程中需要調研和落地的一些技術,調研方式包括官方文檔、技術交流社區和實踐案例等途徑。在調研過程中需要根據項目需求和項目人員進行選型,并結合實際情況進行實踐和調整。

二、 如何通過啥工具來查看分析一個接口中每個部分的耗時

分布式追蹤系統:

像Zipkin、Jaeger、SkyWalking等分布式追蹤系統可以幫助你追蹤一個請求在系統中流轉的情況,包括每個部分的耗時。這些系統通常需要你在代碼中集成相關的庫,然后它們就可以自動收集和上報追蹤數據。

APM工具:

應用性能管理(APM)工具,如New Relic、Dynatrace、AppDynamics等,可以提供全面的性能監控和分析,包括接口耗時、數據庫查詢耗時、外部服務調用耗時等。

Profiler工具:

像JProfiler、YourKit等Profiler工具可以幫助你分析Java應用的性能,包括方法調用的耗時。這些工具通常需要你在啟動Java應用時加入相關的參數,然后它們就可以收集和展示性能數據。

Spring Boot Actuator:

如果你的應用是Spring Boot應用,那么你可以使用Spring Boot Actuator的/metrics端點來查看一些基本的性能數據,包括接口的請求次數、平均耗時等。

日志分析工具:

如果你的應用將詳細的日志(包括接口調用的開始時間和結束時間)輸出到文件或者發送到日志服務,那么你可以使用日志分析工具,如ELK(Elasticsearch、Logstash、Kibana)堆棧,來分析日志,從而得到接口的耗時

三、 如果一個接口性能比較差,你該如何進行優化,請說明思路以及實施路徑

排查接口執行慢,可以從以下角度考慮:

  1. 看是否有慢sql,如果有慢sql ,可以根據情況選擇合適的索引。如果已經有索引,看索引是否失效
  2. 看是否有使用緩存
  3. 看是否可以使用異步,異步的方式可以根據具體情況選擇多線程或者消息隊列
  4. 看是否有用到大事務,如果有,需要將事務進行拆分
  5. 看代碼業務邏輯,是否可以進行預處理,比如某個數據在多個地方用到了,可以先提前算出來
  6. 串行改并行,比如有a,b,c三個子接口,c接口需要依賴a的結果,b接口完全獨立。那么可以將a,c和b分為兩組,并行執行
  7. 看設計是否合理,比如某個接口,數據可以直接查出來,產品卻搞了一堆配置。這種情況可以和產品溝通,是否有必要改需求。

四、你有沒有進行過架構設計,架構設計需要考慮哪些方面,你是如何去實施的?

  1. 需要考慮;從承接的需求開始,分析項目。
  2. 系統分解:將整個系統分解為可管理的部分,通常是服務或模塊,以便于理解、開發和測試。
  3. 組件選擇:選擇合適的軟件和硬件組件,包括數據庫、中間件、服務框架、前端框架等。
  4. 技術棧選擇:根據項目需求和團隊技能選擇合適的技術棧。
  5. 可擴展性:設計時要考慮系統未來的擴展,包括水平擴展(增加更多的節點)和垂直擴展(增強單個節點的能力)。 性能:確保系統設計能夠滿足性能要求,包括處理速度、響應時間、吞吐量等。
  6. 可靠性和容錯性:系統應該能夠處理各種錯誤情況,并且在出現部分故障時仍能保持運行。
  7. 安全性:保護系統免受未授權訪問和攻擊,確保數據的安全和隱私。
  8. 可維護性和可測試性:設計應該便于未來的維護和升級,同時也要便于測試。

五、 如果一個程序的內存占用過高你該如何去分析呢?

可以基于監控工具進行全鏈路排查,查看QPS、TPS、瞬時峰值,用戶規模等。之后在針對性的分析具體的系統流程。之后結合工具 JProfiler(一般全鏈路監控工具是有集成的)之后就可以看到具體的內存高的代碼片段,在做分析和驗證處理

六、nacos 注冊中心怎么判斷服務端已經崩潰了?

Nacos作為注冊中心,通過心跳機制來檢測服務實例是否存活。每一個注冊到Nacos的服務實例,都會定期向Nacos發送心跳包,表明它們的存在。默認情況下,這個心跳間隔是5秒,也就是說每5秒,服務實例就會向Nacos發送一次心跳。

如果Nacos在15秒(默認配置,也就是3個心跳周期)內沒有收到某個服務實例的心跳,那么Nacos會認為這個服務實例已經下線或者崩潰,然后從服務列表中移除這個服務實例。

這個心跳間隔和超時時間都可以在Nacos的配置中修改。如果你的服務實例在高負載下運行,或者網絡狀況不穩定,可能需要增大這些值以避免誤判。

需要注意的是,這個機制只能檢測服務實例是否能夠正常響應心跳,不能判斷服務實例是否能夠正常提供服務。如果一個服務實例雖然能夠發送心跳,但是由于某種原因無法正常處理請求,那么這個服務實例仍然會被Nacos認為是存活的。在這種情況下,可能需要額外的健康檢查機制來判斷服務實例的狀態。

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

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

相關文章

高性能通信之Netty

一, 同步IO(BIO)模型的架構 一般針對性能不高的情況下可以使用. 二,異步IO(NIO)模型的架構 多路復用(epoll模型):

【LeetCode:124. 二叉樹中的最大路徑和 + 二叉樹+遞歸】

🚀 算法題 🚀 🌲 算法刷題專欄 | 面試必備算法 | 面試高頻算法 🍀 🌲 越難的東西,越要努力堅持,因為它具有很高的價值,算法就是這樣? 🌲 作者簡介:碩風和煒,…

前端開發人員如何做好SEO

前端開發人員如何做好SEO SEO工作不僅限于專業人員。前端開發者也可以在日常開發中實施一些代碼層面的SEO優化。 以下是一些前端常用的SEO方法: 設置合理的title、keywords、description title、keywords、description對SEO至關重要,需貼合頁面內容編…

Codeforces Round 931 (Div. 2) (A~B)

比賽:Codeforces Round 931 (Div. 2) (A~B) 目錄:A B A題:Too Min Too Max 標簽: 構造算法(constructive algorithms)貪心(greedy)數學(math) 題目大意 對數組 a 找到…

【力扣hot100】刷題筆記Day19

前言 回溯回溯回溯!早上整理檔案竟然用了桶排序,不愧是算法狂魔們 79. 單詞搜索 - 力扣(LeetCode) DFS class Solution:def exist(self, board: List[List[str]], word: str) -> bool:m, n len(board), len(board[0])# used…

mysql timestamp轉換為datetime

MySQL timestamp轉換為datetime的方法 1. 流程概述 在MySQL中,timestamp和datetime是兩種不同的數據類型。timestamp存儲了日期和時間,并且會自動更新,可以用于記錄數據的創建和修改時間。datetime則是一個固定的日期和時間,不會自…

談談高并發系統的設計方法論

談談高并發系統的設計方法論 何為高并發系統?什么是并發(Conurrent)?什么是高并發(Hight Concurrnet)?高并發的衡量指標有哪些? 實現高并發系統的兩大板塊高并發系統應用程序側的設計…

騰訊云學生服務器使用教程_申請騰訊云學生機詳細流程

2024年騰訊云學生服務器優惠活動「云校園」,學生服務器優惠價格:輕量應用服務器2核2G學生價30元3個月、58元6個月、112元一年,輕量應用服務器4核8G配置191.1元3個月、352.8元6個月、646.8元一年,CVM云服務器2核4G配置842.4元一年&…

還在用Jenkins?快來試試這款簡而輕的自動部署軟件!

最近發現了一個比 Jenkins 使用更簡單的項目構建和部署工具,完全可以滿足個人以及一些小企業的需求,分享一下。 Jpom 是一款 Java 開發的簡單輕量的低侵入式在線構建、自動部署、日常運維、項目監控軟件。 日常開發中,Jpom 可以解決下面這些…

Nginx的多線程支持探究

文章中心思想: Nginx本身并不直接支持多線程處理模型。它采用的是基于事件驅動的單線程或多進程架構,而非多線程模型。然而,通過Nginx的模塊和第三方擴展,可以實現類似多線程的并發處理效果。 詳細說明: Nginx,作為一款高性能的Web服務器和反向代理服務器,其架構和并發…

章節二、three.js開發入門與調試設置02;

一、軌道控制器查看物體; 1、基本概念 軌道控制器(OrbitControls)可以使得相機圍繞目標進行軌道運動; 2、代碼樣例 // 七、創建軌道控制器(相機圍繞著物體捕捉視角) const controls new OrbitControls(c…

吳恩達機器學習全課程筆記第五篇

目錄 前言 P80-P85 添加數據 遷移學習 機器學習項目的完整周期 公平、偏見與倫理 P86-P95 傾斜數據集的誤差指標 決策樹模型 測量純度 選擇拆分方式增益 使用分類特征的一種獨熱編碼 連續的有價值特征 回歸樹 前言 這是吳恩達機器學習筆記的第五篇&#xff0c…

《2023跨境電商投訴大數據報告》發布|亞馬遜 天貓國際 考拉海購 敦煌網 阿里巴巴

2023年,跨境電商API接口天貓國際、京東國際和抖音全球購以其強大的品牌影響力和市場占有率,穩坐行業前三的位置。同時,各大跨境電商平臺消費糾紛問題層出不窮。依據國內知名網絡消費糾紛調解平臺“電訴寶”(315.100EC.CN&#xff…

javaEE--后端環境變量配置

目錄 pre 文件準備 最終運行成功結果 后端運行步驟 1.修改setenv文件 2.運行setenv,設置環境變量 3.查看jdk版本 4.修改mysql文件夾下的my文件 前端運行步驟 1.nodejs環境配置 2.查看node和npm版本 3.下載并運行npm 4.注冊登錄 pre 文件準備 最終運行…

VR轉接器:破解虛擬與現實邊界的革命性設備

VR轉接器,這一革命性的設備,為虛擬現實體驗帶來了前所未有的自由度。它巧妙地連接了虛擬與現實,使得用戶在享受VR眼鏡帶來的奇幻世界的同時,也能自由地在現實世界中活動。這一設計的誕生,不僅解決了VR眼鏡續航的瓶頸問…

2、云原生安全之可視化界面rancher的部署

文章目錄 1、rancher的部署1.1、安裝rancher1.2、配置k8s2、部署helm3、容器安全工具neuvector此時已經部署好了k8s,使用rancher來管理 rancher簡化了使用k8s的流程,可以圖形化管理k8s。 參考: https://blog.51cto.com/u_15343792/5000311https://docs.rancher.cn/docs/ra…

你們團隊是否有RocketMQ創建Topic、GID創建規范呢

這里是weihubeats,覺得文章不錯可以關注公眾號小奏技術 背景 早期在使用RocketMQ的時候,系統和開發人員不算多。所以topic的創建會非常隨意,各種千奇百怪的topic 比如: order_topic、ORDER_TOPIC、order-topic 各種奇奇怪怪的風格,用_的&a…

GO結構體

1. 結構體 Go語言可以通過自定義的方式形成新的類型,結構體就是這些類型中的一種復合類型,結構體是由零個或多個任意類型的值聚合成的實體,每個值都可以稱為結構體的成員。 結構體成員也可以稱為“字段”,這些字段有以下特性&am…

JS清空數組方法

清空數組的方法有多種,以下是幾種常見的方式: 1.使用 array.length 屬性將數組的長度設為0,這樣會移除數組中的所有元素: var arr [1, 3, 5]; arr.length 0; console.log(arr); // [] 2. 使用 array.splice() 方法,…

STM32 | 零基礎 STM32 第一天

零基礎 STM32 第一天 一、認知STM32 1、STM32概念 STM32:意法半導體基于ARM公司的Cortex-M內核開發的32位的高性能、低功耗單片機。 ST:意法半導體 M:基于ARM公司的Cortex-M內核的高性能、低功耗單片機 32:32位單片機 2、STM32開發的產品 STM32開發的產品&a…