日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

超贊!Spring Boot 3.3 自帶 Controller 接口監控,大家趕緊用起來

來源: 責編: 時間:2024-09-10 09:50:59 177觀看
導讀在現代應用開發中,系統的實時監控和維護變得至關重要。Spring Boot 3.3 的 Actuator 模塊為開發者提供了一整套強大的監控功能,使得應用程序的健康狀況、性能指標、用戶行為及安全性得以全方位掌握和管理。本文將詳細介

在現代應用開發中,系統的實時監控和維護變得至關重要。Spring Boot 3.3 的 Actuator 模塊為開發者提供了一整套強大的監控功能,使得應用程序的健康狀況、性能指標、用戶行為及安全性得以全方位掌握和管理。本文將詳細介紹如何配置和使用 Actuator,并展示如何將這些監控數據在前端頁面中可視化。VdR28資訊網——每日最新資訊28at.com

Spring Boot 3.3 的 Actuator 模塊提供了一整套全面的監控功能,幫助開發者更好地管理和維護應用程序。主要功能包括:VdR28資訊網——每日最新資訊28at.com

  1. 健康檢查:實時監控應用的健康狀態,快速發現和處理系統問題,確保應用穩定運行。
  2. 性能指標:監控應用的性能數據,如請求處理時間和響應時間,幫助識別和解決性能瓶頸。
  3. 環境屬性:展示應用的環境配置信息,為調試和環境管理提供支持。
  4. 請求追蹤:記錄和分析 HTTP 請求的詳細信息,幫助追蹤和定位問題源頭。
  5. 日志管理:動態調整日志級別,方便進行問題排查和監控。
  6. 線程轉儲:提供 JVM 線程的詳細轉儲信息,幫助分析線程狀態和優化性能。

這些功能使得開發者能夠實時獲取應用的運行狀態,優化系統性能,提升用戶體驗,并增強系統的安全性。接下來,我們將展示如何配置 Actuator 及其功能,并如何在前端頁面中展示這些監控數據。VdR28資訊網——每日最新資訊28at.com

運行效果:VdR28資訊網——每日最新資訊28at.com

圖片圖片VdR28資訊網——每日最新資訊28at.com

若想獲取項目完整代碼以及其他文章的項目源碼,且在代碼編寫時遇到問題需要咨詢交流,歡迎加入下方的知識星球。VdR28資訊網——每日最新資訊28at.com

項目依賴配置

首先,確保你的 pom.xml 文件中包含 Actuator 和 Thymeleaf 的依賴。VdR28資訊網——每日最新資訊28at.com

<?xml versinotallow="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">	<modelVersion>4.0.0</modelVersion>	<parent>		<groupId>org.springframework.boot</groupId>		<artifactId>spring-boot-starter-parent</artifactId>		<version>3.3.3</version>		<relativePath/> <!-- lookup parent from repository -->	</parent>	<groupId>com.icoderoad</groupId>	<artifactId>actuator-demo</artifactId>	<version>0.0.1-SNAPSHOT</version>	<name>actuator-demo</name>	<description>Demo project for Spring Boot</description>		<properties>		<java.version>17</java.version>	</properties>	<dependencies>				<!-- Spring Boot Starter Web -->	    <dependency>	        <groupId>org.springframework.boot</groupId>	        <artifactId>spring-boot-starter-web</artifactId>	    </dependency>	    	    <!-- Spring Boot Actuator -->	    <dependency>	        <groupId>org.springframework.boot</groupId>	        <artifactId>spring-boot-starter-actuator</artifactId>	    </dependency>		    <!-- Thymeleaf for HTML templates -->	    <dependency>	        <groupId>org.springframework.boot</groupId>	        <artifactId>spring-boot-starter-thymeleaf</artifactId>	    </dependency>		<dependency>			<groupId>org.springframework.boot</groupId>			<artifactId>spring-boot-starter-test</artifactId>			<scope>test</scope>		</dependency>	</dependencies>	<build>		<plugins>			<plugin>				<groupId>org.springframework.boot</groupId>				<artifactId>spring-boot-maven-plugin</artifactId>			</plugin>		</plugins>	</build></project>

配置 Actuator 監控功能

在 application.yml 中配置 Actuator 端點,啟用所需的監控功能。VdR28資訊網——每日最新資訊28at.com

server:  port: 8080    management:  endpoints:    web:      exposure:        include: health, metrics, info, mappings, env, conditions, loggers, threaddump  endpoint:    health:      show-details: always    metrics:      enable:        all: true    info:      enabled: true    mappings:      enabled: true    env:      enabled: true    conditions:      enabled: true    loggers:      enabled: true    threaddump:      enabled: true  trace:    http:      enabled: true

創建 Actuator 監控 Controller

創建一個 MonitoringController,用于展示 Actuator 的監控數據。VdR28資訊網——每日最新資訊28at.com

package com.icoderoad.actuator_demo.controller;import org.springframework.boot.actuate.env.EnvironmentEndpoint;import org.springframework.boot.actuate.health.HealthEndpoint;import org.springframework.boot.actuate.info.InfoEndpoint;import org.springframework.boot.actuate.logging.LoggersEndpoint;import org.springframework.boot.actuate.management.ThreadDumpEndpoint;import org.springframework.boot.actuate.metrics.MetricsEndpoint;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import java.util.HashMap;import java.util.Map;@RestController@RequestMapping("/monitoring")public class MonitoringController {    private final HealthEndpoint healthEndpoint;    private final MetricsEndpoint metricsEndpoint;    private final InfoEndpoint infoEndpoint;    private final EnvironmentEndpoint environmentEndpoint;    private final LoggersEndpoint loggersEndpoint;    private final ThreadDumpEndpoint threadDumpEndpoint;    public MonitoringController(HealthEndpoint healthEndpoint, MetricsEndpoint metricsEndpoint,                                InfoEndpoint infoEndpoint, EnvironmentEndpoint environmentEndpoint,                                LoggersEndpoint loggersEndpoint, ThreadDumpEndpoint threadDumpEndpoint) {        this.healthEndpoint = healthEndpoint;        this.metricsEndpoint = metricsEndpoint;        this.infoEndpoint = infoEndpoint;        this.environmentEndpoint = environmentEndpoint;        this.loggersEndpoint = loggersEndpoint;        this.threadDumpEndpoint = threadDumpEndpoint;    }    @GetMapping    public Map<String, Object> getMonitoringData() {        Map<String, Object> monitoringData = new HashMap<>();                monitoringData.put("health", healthEndpoint.health());        monitoringData.put("metrics", metricsEndpoint.listNames());        monitoringData.put("info", infoEndpoint.info());        monitoringData.put("environment", environmentEndpoint.environment(null)); // 返回環境屬性描述符        monitoringData.put("loggers", loggersEndpoint.loggers());        monitoringData.put("threaddump", threadDumpEndpoint.threadDump());        return monitoringData;    }}

創建用戶菜單接口

創建一個新的接口 /menu,用于提供用戶菜單數據。VdR28資訊網——每日最新資訊28at.com

package com.icoderoad.actuator_demo.controller;import java.util.List;import java.util.Map;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;@RestController@RequestMapping("/api")public class UserController {    @GetMapping("/menu")    public List<Map<String, String>> getMenu() {        // 模擬返回用戶菜單        return List.of(            Map.of("name", "首頁", "url", "/home"),            Map.of("name", "用戶管理", "url", "/users"),            Map.of("name", "設置", "url", "/settings")        );    }}

視圖控制器

package com.icoderoad.actuator_demo.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.GetMapping;@Controllerpublic class IndexController {    @GetMapping("/")    public String index() {        return "index";    }}

創建 Thymeleaf 模板

在 src/main/resources/templates 目錄下創建或更新 monitoring.html 文件,以展示 Actuator 監控數據和測試接口結果。VdR28資訊網——每日最新資訊28at.com

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>接口監控</title>    <link rel="stylesheet" >    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>    <style>    	.container {    		width: 40%;    		margin: 40px auto;    	}        pre {            white-space: pre-wrap; /* Allow text to wrap within the element */            word-wrap: break-word; /* Break long words */        }    </style></head><body>    <div class="container mt-5">        <h1>接口監控</h1>                <!-- 接口健康狀態 -->        <div class="mt-3">            <h3>接口健康狀態</h3>            <button class="btn btn-info" onclick="toggleContent('health', fetchHealth)">顯示健康狀態</button>            <pre id="health" style="display: none;"></pre>        </div>                <!-- 可用指標 -->        <div class="mt-3">            <h3>可用指標</h3>            <button class="btn btn-info" onclick="toggleContent('metrics', fetchMetrics)">顯示可用指標</button>            <pre id="metrics" style="display: none;"></pre>        </div>                <!-- 環境屬性 -->        <div class="mt-3">            <h3>環境屬性</h3>            <button class="btn btn-info" onclick="toggleContent('environment', fetchEnvironment)">顯示環境屬性</button>            <pre id="environment" style="display: none;"></pre>        </div>                <!-- 日志級別 -->        <div class="mt-3">            <h3>日志級別</h3>            <button class="btn btn-info" onclick="toggleContent('loggers', fetchLoggers)">顯示日志級別</button>            <pre id="loggers" style="display: none;"></pre>        </div>                <!-- 線程轉儲 -->        <div class="mt-3">            <h3>線程轉儲</h3>            <button class="btn btn-info" onclick="toggleContent('threaddump', fetchThreadDump)">顯示線程轉儲</button>            <pre id="threaddump" style="display: none;"></pre>        </div>        <!-- 用戶菜單 -->        <div class="mt-3">            <h3>用戶菜單</h3>            <a href="#" class="btn btn-primary" onclick="fetchUserMenu()">訪問用戶菜單接口</a>            <div id="menu-result" class="mt-2"></div>        </div>    </div>    <script>        function fetchMonitoringData() {            fetch('/monitoring')                .then(response => response.json())                .then(data => {                    // Store the data in the global scope for later use                    window.monitoringData = data;                })                .catch(error => console.error('Error fetching monitoring data:', error));        }        function fetchHealth() {            if (!window.monitoringData) {                fetchMonitoringData();                return;            }            return JSON.stringify(window.monitoringData.health, null, 2);        }        function fetchMetrics() {            if (!window.monitoringData) {                fetchMonitoringData();                return;            }            return JSON.stringify(window.monitoringData.metrics, null, 2);        }        function fetchEnvironment() {            if (!window.monitoringData) {                fetchMonitoringData();                return;            }            return JSON.stringify(window.monitoringData.environment, null, 2);        }        function fetchLoggers() {            if (!window.monitoringData) {                fetchMonitoringData();                return;            }            return JSON.stringify(window.monitoringData.loggers, null, 2);        }        function fetchThreadDump() {            if (!window.monitoringData) {                fetchMonitoringData();                return;            }            return JSON.stringify(window.monitoringData.threaddump, null, 2);        }        function fetchUserMenu() {            fetch('/api/menu')                .then(response => response.json())                .then(data => {                    document.getElementById('menu-result').textContent = JSON.stringify(data, null, 2);                })                .catch(error => console.error('Error fetching user menu:', error));        }        function toggleContent(id, fetchFunction) {            const content = document.getElementById(id);            const button = event.target;                        if (content.style.display === 'none') {                // Display content                content.textContent = fetchFunction();                content.style.display = 'block';                button.textContent = `隱藏${button.textContent.substring(2)}`;            } else {                // Hide content                content.style.display = 'none';                button.textContent = `顯示${button.textContent.substring(2)}`;            }        }        // Trigger fetchMonitoringData on page load        window.onload = function() {            fetchMonitoringData();        }    </script></body></html>

運行并測試

  1. 啟動 Spring Boot 應用程序。
  2. 訪問 http://localhost:8080 頁面,查看 Actuator 提供的監控數據。
  3. 點擊“訪問用戶菜單接口”按鈕,查看用戶菜單接口的響應數據。

通過以上步驟,你可以輕松驗證 Actuator 的 HTTP 請求追蹤功能,并在頁面上測試用戶菜單接口。這樣不僅能夠展示 Actuator 的強大功能,還可以檢查和調試接口的響應數據。這篇文章希望能幫助大家有效地實現和利用 Spring Boot 的監控功能,并提升系統的管理和維護能力。VdR28資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-112780-0.html超贊!Spring Boot 3.3 自帶 Controller 接口監控,大家趕緊用起來

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: PHP異步非阻塞MySQL客戶端連接池

下一篇: 如何使用 CGLIB 在 Spring Boot 3.3 中實現動態代理

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
国产一区二区观看| 欧美激情一区二区久久久| 亚洲欧美国产制服动漫| 午夜精品视频在线| 久久久人成影片一区二区三区| 久久久久免费视频| 欧美精品久久久久a| 国产精品毛片va一区二区三区 | 欧美aⅴ一区二区三区视频| 欧美激情精品久久久久久变态| 欧美色图五月天| 国产在线观看一区| 亚洲精品一区在线观看香蕉| 午夜国产一区| 欧美成人69av| 国产日韩欧美黄色| 亚洲另类自拍| 久久精品二区亚洲w码| 欧美精品三级日韩久久| 国产日韩在线看| 日韩午夜精品视频| 久久国内精品视频| 欧美日韩成人激情| 狠狠色2019综合网| 中文日韩在线| 蜜桃av综合| 国产午夜精品久久久久久免费视 | 夜夜爽夜夜爽精品视频| 欧美专区中文字幕| 欧美日韩在线三级| 亚洲第一中文字幕| 欧美亚洲网站| 欧美日韩亚洲高清| 在线看视频不卡| 欧美深夜影院| 国内成+人亚洲+欧美+综合在线| 日韩性生活视频| 久久综合狠狠综合久久综青草 | 欧美www在线| 国产视频亚洲精品| 在线一区二区日韩| 免费在线亚洲欧美| 国产一区二区精品丝袜| 一区二区三区日韩| 欧美成人精品不卡视频在线观看| 国产精品永久免费| 亚洲少妇诱惑| 欧美精品偷拍| 亚洲丰满在线| 久久精品国产亚洲高清剧情介绍| 国产精品美女久久久久久久| 亚洲精品资源| 嫩草国产精品入口| 韩国精品久久久999| 亚洲欧美激情诱惑| 欧美四级在线观看| 亚洲靠逼com| 欧美电影美腿模特1979在线看| 激情视频一区| 久久久国产精品亚洲一区| 国产精品专区第二| 亚洲女性喷水在线观看一区| 欧美日韩在线观看一区二区三区| 亚洲精品日本| 欧美成人嫩草网站| 亚洲高清二区| 老司机精品久久| 一区在线免费观看| 久久人人97超碰精品888| 国产在线精品自拍| 久久国产精品久久久久久久久久| 国产精品实拍| 亚洲欧美日韩高清| 国产精品一级在线| 西西裸体人体做爰大胆久久久| 国产精品福利在线观看| 在线中文字幕一区| 欧美午夜精品理论片a级按摩| 一本色道久久综合亚洲精品按摩| 欧美日本中文字幕| 一区二区三区**美女毛片| 欧美人成网站| 一区二区精品| 国产精品v日韩精品| 亚洲一区二区免费看| 国产精品国产福利国产秒拍| 亚洲一级黄色av| 国产精品免费一区二区三区观看| 亚洲一区二区三区免费观看| 国产精品久久99| 亚洲欧美精品suv| 国产欧美一区二区三区视频| 欧美在线一二三| 激情久久中文字幕| 蜜臀久久99精品久久久久久9| 亚洲国产精品免费| 欧美精品色综合| 亚洲网站在线看| 国产乱码精品1区2区3区| 欧美制服第一页| 亚洲第一福利社区| 欧美日韩高清在线观看| 亚洲视频中文| 国产亚洲欧美一区在线观看| 老司机午夜免费精品视频| 亚洲人久久久| 国产精品v欧美精品∨日韩| 亚洲欧美日韩成人| 国产一区二区中文| 久久中文精品| 日韩亚洲欧美一区| 国产精品色婷婷| 久久五月天婷婷| 日韩亚洲欧美在线观看| 国产精品女主播一区二区三区| 久久国产精品毛片| 亚洲黄色av一区| 国产精品极品美女粉嫩高清在线| 国产精品主播| 久久久国产视频91| 亚洲精品老司机| 国产精品国产福利国产秒拍| 久久久777| 日韩视频在线观看免费| 国产精品一区视频| 欧美96在线丨欧| 亚洲午夜影视影院在线观看| 国内精品免费午夜毛片| 欧美精品18| 欧美在线视频一区二区三区| 91久久午夜| 国产精品一区2区| 欧美va亚洲va日韩∨a综合色| 亚洲午夜一区二区三区| 狠狠做深爱婷婷久久综合一区 | 欧美激情一区二区三区蜜桃视频 | 亚洲精品一区在线观看| 国产精品网站一区| 免费在线亚洲| 午夜精品999| 亚洲精品中文字幕在线观看| 国产亚洲精品久久久| 欧美激情久久久| 欧美一区深夜视频| 99精品视频一区| 伊甸园精品99久久久久久| 国产精品xnxxcom| 欧美va亚洲va香蕉在线| 欧美在线观看视频在线| a91a精品视频在线观看| 激情成人综合网| 国产精品午夜国产小视频| 欧美激情精品久久久| 久久国产精品一区二区三区四区| 夜夜嗨av一区二区三区网站四季av | 欧美电影在线| 欧美在线不卡视频| 中文网丁香综合网| 亚洲片在线观看| 好吊妞**欧美| 国产精品视频第一区| 欧美日本韩国在线| 麻豆精品精华液| 欧美一区二区三区免费大片| 亚洲视频福利| 日韩午夜精品视频| 亚洲黄一区二区| 在线精品亚洲| 狠狠色丁香久久婷婷综合_中| 国产精品日韩欧美一区二区| 欧美另类人妖| 欧美成人一区二区三区| 狂野欧美一区| 久久久久99| 久久av红桃一区二区小说| 亚洲自拍偷拍色片视频| 日韩一区二区免费高清| 亚洲激情在线| 亚洲国产成人91精品| 韩日欧美一区二区| 国产视频久久网| 国产精品一区二区久激情瑜伽| 欧美日韩一区二区三区在线观看免| 欧美a级片网站| 久久综合九色综合久99| 久久精品国产v日韩v亚洲 | 韩国美女久久| 国产亚洲精品成人av久久ww| 国产精品私人影院| 国产精品久久久久久五月尺| 欧美日韩一区高清| 欧美日韩国产综合新一区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产免费亚洲高清| 国产精品美女久久久浪潮软件 | 农夫在线精品视频免费观看| 狼人天天伊人久久| 麻豆精品在线观看| 麻豆久久久9性大片| 免费人成精品欧美精品| 免费av成人在线| 欧美成人小视频| 欧美精品久久久久久久免费观看| 欧美黄色一级视频|