本文介紹了利用千分尺實現新型文物與彈簧靴的集成的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在嘗試使用測微計將一個簡單的Spring Boot應用程序與New Relic集成。
以下是配置詳細信息:-
application.properties
management.endpoints.web.exposure.include=*
management.endpoint.health.show-details=always
management.metrics.export.newrelic.enabled=true
management.metrics.export.newrelic.api-key:MY_API_KEY // Have added the API key here
management.metrics.export.newrelic.account-id: MY_ACCOUNT_ID // Have added the account id here
logging.level.io.micrometer.newrelic=TRACE
pom.xml
<?xml version="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>2.5.5</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<groupId>springboot.micrometer.demo</groupId>
<artifactId>micrometer-new-relic</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>micrometer-new-relic</name>
<description>Demo project for actuator integration with new relic using micrometer</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>io.micrometer</groupId>
<artifactId>micrometer-registry-new-relic</artifactId>
</dependency>
<dependency>
<groupId>io.micrometer</groupId>
<artifactId>micrometer-registry-prometheus</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</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>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
我能夠使用micrometer-registry-prometheus
依賴項將Prometheus與此應用程序集成。我將普羅米修斯設置為在本地系統的Docker容器中運行。我使用了以下一組命令-
docker pull prom/prometheus
docker run -p 9090:9090 -v D:/Workspaces/STS/server_sent_events_blog/micrometer-new-relic/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus
prometheus.yml
global:
scrape_interval: 4s
evaluation_interval: 4s
scrape_configs:
- job_name: 'spring_micrometer'
metrics_path: '/actuator/prometheus'
scrape_interval: 5s
static_configs:
- targets: ['my_ip_address:8080']
當我導航到localhost:9090/targets
時,我可以看到Prometheus儀表板顯示了我的應用程序詳細信息,并且可以從中獲取數據。在儀表板中,我還可以看到我的自定義指標以及其他指標。
所以我的問題是,我想使用New Relic實現相同的功能。我已經添加了micrometer-registry-new-relic
POM依賴項。我也分享了application.properties
文件。我可以在我的控制臺中看到日志,說明它正在向New Relic發送數據-
2021-10-24 12:42:04.889 DEBUG 2672 --- [trics-publisher] i.m.n.NewRelicInsightsApiClientProvider : successfully sent 58 metrics to New Relic.
問題:
-
下一步是什么?
我是否需要一個本地運行的New Relic服務器,就像我為普羅米修斯做的那樣?
我可以在哪里可視化此數據?我在New Relic有一個賬戶,在那里我什么也看不到
https://discuss.newrelic.com/t/integrate-spring-boot-actuator-with-new-relic/126732
根據上面的鏈接,Spring Bootctuator將指標作為事件類型”SpringBootSample”進行推送。
使用NRQL查詢,我們可以確認這一點-
FROM SpringBootSample SELECT max(value) TIMESERIES 1 minute WHERE metricName = 'jvmMemoryCommitted'
-
此查詢的結果表明什么?它是與我的應用程序相關的指標嗎?
這里是我在這里分享的演示的GitHub link。
我沒有找到任何關于這方面的明確說明,有一些例子,但使用Java代理。
我們將非常感謝您的任何幫助。
推薦答案
根據我目前所學。
有三種方法可以將New Relic與Spring Boot應用程序集成-
-
使用New Relic提供的Java代理
使用New Relic的千分尺依賴
千分表的新遺跡依賴
1.使用New Relic提供的Java代理進行配置
-
從此URL下載Java代理-https://docs.newrelic.com/docs/release-notes/agent-release-notes/java-release-notes/
提取它。
修改解壓縮文件夾中的newrelic.yml文件以包含您的
許可證密鑰(_K):
應用程序名稱:
創建具有一些REST終結點的SpringBoot應用程序。
生成應用程序。
導航到您解壓了newRelic Java代理的根路徑。
輸入此命令
java -javagent:<path to your new relic jar>
ewrelic.jar -jar <path to your application jar><you rapplication jar name>.jar
查看應用程序指標-
-
登錄到您的新文物帳戶。
轉到資源管理器選項卡。
點擊服務-APM
您可以在那里看到您的應用程序的名稱(您在newrelic.yml文件中提到過)。
單擊應用程序名稱。
儀表板應如下所示。
使用New Relic的微米依賴項是執行此操作的首選方法。
2.使用New Relic的微米依賴項進行配置
-
添加此依賴項
<dependency>
<groupId>com.newrelic.telemetry</groupId>
<artifactId>micrometer-registry-new-relic</artifactId>
<version>0.7.0</version>
</dependency>
-
修改
MicrometerConfig.java
類以添加您的API密鑰和應用程序名稱。
import java.net.InetAddress;
import java.net.UnknownHostException;
import org.springframework.boot.actuate.autoconfigure.metrics.CompositeMeterRegistryAutoConfiguration;
import org.springframework.boot.actuate.autoconfigure.metrics.MetricsAutoConfiguration;
import org.springframework.boot.actuate.autoconfigure.metrics.export.simple.SimpleMetricsExportAutoConfiguration;
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.newrelic.telemetry.Attributes;
import com.newrelic.telemetry.micrometer.NewRelicRegistry;
import com.newrelic.telemetry.micrometer.NewRelicRegistryConfig;
import java.time.Duration;
import io.micrometer.core.instrument.config.MeterFilter;
import io.micrometer.core.instrument.util.NamedThreadFactory;
@Configuration
@AutoConfigureBefore({ CompositeMeterRegistryAutoConfiguration.class, SimpleMetricsExportAutoConfiguration.class })
@AutoConfigureAfter(MetricsAutoConfiguration.class)
@ConditionalOnClass(NewRelicRegistry.class)
public class MicrometerConfig {
@Bean
public NewRelicRegistryConfig newRelicConfig() {
return new NewRelicRegistryConfig() {
@Override
public String get(String key) {
return null;
}
@Override
public String apiKey() {
return "your_api_key"; // for production purposes take it from config file
}
@Override
public Duration step() {
return Duration.ofSeconds(5);
}
@Override
public String serviceName() {
return "your_service_name"; // take it from config file
}
};
}
@Bean
public NewRelicRegistry newRelicMeterRegistry(NewRelicRegistryConfig config) throws UnknownHostException {
NewRelicRegistry newRelicRegistry = NewRelicRegistry.builder(config)
.commonAttributes(new Attributes().put("host", InetAddress.getLocalHost().getHostName())).build();
newRelicRegistry.config().meterFilter(MeterFilter.ignoreTags("plz_ignore_me"));
newRelicRegistry.config().meterFilter(MeterFilter.denyNameStartsWith("jvm.threads"));
newRelicRegistry.start(new NamedThreadFactory("newrelic.micrometer.registry"));
return newRelicRegistry;
}
}
-
運行應用程序。
查看應用程序指標-
-
登錄到您的新文物帳戶。
轉到資源管理器選項卡。
點擊服務-開放遙測
您可以在那里看到您的應用程序的名稱(您在MicrometerConfig文件中提到過)。
單擊應用程序名稱。
儀表板應如下所示。
這篇關于利用千分尺實現新型文物與彈簧靴的集成的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,