URI Statistics
Last updated
Was this helpful?
Last updated
Was this helpful?
|
URI statistics menu is newly added to Pinpoint in v2.5.0. Pinpoint Agent aggregates URI templates and send them to Pinpoint collector via GRPC. Pinpoint Collector saves the data to Pinot via Apache Kafka. Pinpoint Web accesses Pinot to display the data.
Create a topic with the name uri-stat
Above guide gives you the way to run Pinot locally, in Docker, and in Kubernetes.
Table uriStat
should be created. Use pinot-uriStat-schema.json
and pinot-uriStat-table.json
to create the table.
This section describes the URI stat configuration values added for URI statistics.
1.5.1 Configuration values for URI Statistics
Below are default agent configuration values for URI statistics.
profiler.uri.stat.enable: whether Pinpoint Agent collects URI statistics or not.
true
: collects URI statistics
false
: doesn't collect URI statistics
profiler.uri.stat.spring.webmvc.enable: whether Pinpoint Agent collects URI statistics from Spring Web MVC applications.
true
: collects URI statistics from Spring Web MVC applications.
false
: doesn't collect URI statistics from Spring Web MVC applications.
profiler.uri.stat.spring.webmvc.useuserinput: whether Pinpoint Agent uses user-input request attribute values for URI templates when available.
true
: uses user-input request attribute values.
false
: ignores user-input request attribute values.
Set attribute pinpoint.metric.uri-template
to your Spring web request as shown below to override default URI template provided by Pinpoint.
profiler.uri.stat.spring.webflux.enable: whether Pinpoint Agent collects URI statistics from Spring Webflux applications.
true
: collects URI statistics from Spring Webflux applications.
false
: doesn't collect URI statistics from Spring Webflux applications.
profiler.uri.stat.spring.webflux.useuserinput: whether Pinpoint Agent uses user-input request attribute values for URI templates when available.
true
: uses user-input request attribute values.
false
: ignores user-input request attribute values.
Set attribute pinpoint.metric.uri-template
to your Spring web request as shown below to override default URI template provided by Pinpoint.
profiler.uri.stat.vertx.enable: whether Pinpoint Agent collects URI statistics from Vert.x applications.
true
: collects URI statistics from Vert.x applications.
false
: doesn't collect URI statistics from Vert.x applications.
profiler.uri.stat.vertx.useuserinput: whether Pinpoint Agent uses user-input routing context attribute values for URI templates when available.
true
: uses user-input routing context attribute values.
false
: ignores user-input routing context attribute values.
Set attribute pinpoint.metric.uri-template
to your Vert.x routing context as shown below to override default URI template provided by Pinpoint.
Instead of the default Pinpoint Collector and Web binaries, you should use those compiled under metric-module.
pinpoint.collector.type=METRIC
argument should be used to collect URI statistics in collector.
Click URL Statistic
on the side bar menu in Pinpoint web.
Search for the application name you used to configure Pinpoint Agent.
Top 50 URIs used in your application will be displayed below the empty chart.
Click each URI to load the chart.
URI ํต๊ณ ๊ธฐ๋ฅ์ ํํฌ์ธํธ v2.5.0์ ์ ๊ท๋ก ์ถ๊ฐ๋์๋ค. ํํฌ์ธํธ ์์ด์ ํธ์์ URI ํ ํ๋ฆฟ ์ ๋ณด๋ฅผ ์์งํ์ฌ GRPC๋ฅผ ์ฌ์ฉํด ํํฌ์ธํธ ์ฝ๋ ํฐ์ ์ ๋ฌํ๊ณ , ํํฌ์ธํธ ์ฝ๋ ํฐ๋ ์ํ์น ์นดํ์นด๋ฅผ ํตํด ์ํ์น ํผ๋ ธ์ ๊ฐ์ ์ ์ฅํ๋ค. ํํฌ์ธํธ ์น์์ ์ ์ฅ๋ URI ํต๊ณ ๋ฐ์ดํฐ๋ฅผ ํ์ธํ ์ ์๋ค.
์๋์ ๊ฐ์ด uri-stat
ํ ํฝ์ ์์ฑํ๋ค.
๋ค์ํ ํ๊ฒฝ (local, docker, kubernetes)์์ ํผ๋ ธ ์คํ ํ๊ฒฝ์ ๊ตฌ์ฑํ ์ ์์ผ๋ ์ ๊ฐ์ด๋๋ฅผ ์ฐธ๊ณ ํ์.
์ ๊ฒฝ๋ก์์ pinot-uriStat-schema.json
์ pinot-uriStat-table.json
๋ฅผ ์ฐธ๊ณ ํ์ฌ uriStat
ํ
์ด๋ธ์ ์์ฑํ๋ค.
URI ํต๊ณ ์์ง์ ์ํด ํํฌ์ธํธ ์์ด์ ํธ์ ์ค์ ํด์ผ ํ๋ ๊ฐ๋ค์ ์๋ดํ๋ค.
1.5.1 URI ํต๊ณ ์์ง์ ์ํ ์ค์ ๊ฐ
URI ํต๊ณ ์์ง๊ณผ ๊ด๋ จ๋ ํํฌ์ธํธ ์์ด์ ํธ์ ์ค์ ๊ธฐ๋ณธ๊ฐ๋ค์ ์๋์ ๊ฐ๋ค.
profiler.uri.stat.enable: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ URI ํต๊ณ๋ฅผ ์์งํ๋์ง ์ฌ๋ถ.
true
: URI ํต๊ณ๋ฅผ ์์งํ๋ค.
false
: URI ํต๊ณ๋ฅผ ์์งํ์ง ์๋๋ค.
profiler.uri.stat.spring.webmvc.enable: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ ์คํ๋ง ์น MVC ์ดํ๋ฆฌ์ผ์ด์ ์์ URI ํต๊ณ๋ฅผ ์์งํ๋์ง ์ฌ๋ถ.
true
: ์คํ๋ง ์น MVC ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ๋ค.
false
: ์คํ๋ง ์น MVC ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ์ง ์๋๋ค.
profiler.uri.stat.spring.webmvc.useuserinput: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ ์คํ๋ง ์น ์ดํ๋ฆฌ์ผ์ด์ ์์ ์ฌ์ฉ์ ์ ์ URI ํ ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋์ง ์ฌ๋ถ.
true
: ์คํ๋ง ์น ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋ค.
false
: ์คํ๋ง ์น ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ํ์ธํ์ง ์๊ณ ํํฌ์ธํธ๊ฐ ์์งํ ํ
ํ๋ฆฟ๋ง ์ฌ์ฉํ๋ค.
ํํฌ์ธํธ์์ ์์งํ๋ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ์ง ์๊ณ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ๊ณ ์ถ๋ค๋ฉด, ์๋ ์์ ์ ๊ฐ์ด ์คํ๋ง ์น ๋ฆฌํ์คํธ ๊ฐ์ฒด attribute์ pinpoint.metric.uri-template
๋ฅผ key ๊ฐ์ผ๋ก ํ๋ ์์ฑ ๊ฐ์ ์ค์ ํด์ผ ํ๋ค.
profiler.uri.stat.spring.webflux.enable: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์ ์์ URI ํต๊ณ๋ฅผ ์์งํ๋์ง ์ฌ๋ถ.
true
: ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ๋ค.
false
: ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ์ง ์๋๋ค.
profiler.uri.stat.spring.webflux.useuserinput: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์ ์์ ์ฌ์ฉ์ ์ ์ URI ํ ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋์ง ์ฌ๋ถ.
true
: ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋ค.
false
: ์คํ๋ง ์นํ๋ญ์ค ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ํ์ธํ์ง ์๊ณ ํํฌ์ธํธ๊ฐ ์์งํ ํ
ํ๋ฆฟ๋ง ์ฌ์ฉํ๋ค.
ํํฌ์ธํธ์์ ์์งํ๋ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ์ง ์๊ณ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ๊ณ ์ถ๋ค๋ฉด, ์๋ ์์ ์ ๊ฐ์ด ์คํ๋ง ์น ๋ฆฌํ์คํธ ๊ฐ์ฒด attribute์ pinpoint.metric.uri-template
๋ฅผ key ๊ฐ์ผ๋ก ํ๋ ์์ฑ ๊ฐ์ ์ค์ ํด์ผ ํ๋ค.
profiler.uri.stat.vertx.enable: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ Vert.x ์ดํ๋ฆฌ์ผ์ด์ ์์ URI ํต๊ณ๋ฅผ ์์งํ๋์ง ์ฌ๋ถ.
true
: Vert.x ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ๋ค..
false
: Vert.x ์ดํ๋ฆฌ์ผ์ด์
์์ URI ํต๊ณ๋ฅผ ์์งํ์ง ์๋๋ค.
profiler.uri.stat.vertx.useuserinput: ํํฌ์ธํธ ์์ด์ ํธ๊ฐ Vert.x ์ดํ๋ฆฌ์ผ์ด์ ์์ ์ฌ์ฉ์ ์ ์ URI ํ ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋์ง ์ฌ๋ถ.
true
: Vert.x ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฐ์ ์ ์ผ๋ก ์ฌ์ฉํ๋ค.
false
: Vert.x ์ดํ๋ฆฌ์ผ์ด์
์์ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ํ์ธํ์ง ์๊ณ ํํฌ์ธํธ๊ฐ ์์งํ ํ
ํ๋ฆฟ๋ง ์ฌ์ฉํ๋ค.
ํํฌ์ธํธ์์ ์์งํ๋ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ์ง ์๊ณ ์ฌ์ฉ์ ์ ์ URI ํ
ํ๋ฆฟ์ ์ฌ์ฉํ๊ณ ์ถ๋ค๋ฉด, ์๋ ์์ ์ ๊ฐ์ด Vert.x RoutingContext ๊ฐ์ฒด์ pinpoint.metric.uri-template
๋ฅผ key ๊ฐ์ผ๋ก ํ๋ ์์ฑ ๊ฐ์ ์ค์ ํด์ผ ํ๋ค.
URI ํต๊ณ๋ฅผ ์์งํ๊ณ ๊ฐ์ ํ์ธํ๋ ค๋ฉด, ํํฌ์ธํธ v2.5.0 ์ด์ ๋ฒ์ ์์ ์ฌ์ฉํ๋ ์ฝ๋ ํฐ์ ์น JAR ํ์ผ์ด ์๋๋ผ metric-module ๋ฐ์ ์์ฑ๋๋ ํ์ผ์ ์ฌ์ฉํด์ผ ํ๋ค.
URI ํต๊ณ๋ฅผ ์์งํ๊ธฐ ์ํด์๋ ์ฝ๋ ํฐ๋ฅผ ์์ํ ๋ pinpoint.collector.type=METRIC
argument๋ฅผ ๋ฃ์ด์ผ ํ๋ค.
ํํฌ์ธํธ ๋ฉํธ๋ฆญ ์น์ ์คํํ์ฌ ์ผ์ชฝ URL Statistic
๋ฉ๋ด๋ฅผ ์ ํํ๋ค.
์๋จ์ seslect box์์ ํํฌ์ธํธ ์์ด์ ํธ์ ์ค์ ํ ์ดํ๋ฆฌ์ผ์ด์ ์ด๋ฆ์ ์กฐํํ๋ค..
์ด๊ธฐ ํ๋ฉด์์๋ ์ ํํ ์ดํ๋ฆฌ์ผ์ด์ ์์ ๊ฐ์ฅ ๋ง์ด ์ฌ์ฉํ ์์ 50๊ฐ URI๊ฐ ๋น ์ฐจํธ ๋ฐ์ ํ์๋๋ค.
์ํ๋ URI๋ฅผ ํด๋ฆญํ๋ฉด ์ฐจํธ์ ๋ฐ์ดํฐ๊ฐ ํ์๋๋ค.
Kafka enables real-time streaming of URI statistics data from Pinpoint collector to Pinot. If you have already , please skip this step.
Please refer to to get Kafka and start the Kafka environment.
This section describes how to install Pinot which is used in Pinpoint to save URI statistics data. If you have already , please skip this step.
Install Pinot according to .
Pinot table schema for Pinpoint URI statistics is provided in .
Please refer to to create necessary tables in your Pinot cluster.
To change the configuration values described above, update pinpoint.config
under and rebuild the project. Or, you can simply pass these properties when starting your application with Pinpoint Agent (e.g. -Dprofiler.uri.stat.enable=false
).
Please check for Pinpoint Metric Collector properties.
Enable URI statistics by adding the below line at :
Please check for Pinpoint Metric Web properties.
Enable URI statistics by adding the below line at :
์ค์๊ฐ์ผ๋ก ํํฌ์ธํธ ์ฝ๋ ํฐ์์ ๋ฐ์ดํฐ๋ฅผ ์ ๋ฌ๋ฐ์ ํผ๋ ธ์ ์ ์ฅํ๊ธฐ ์ํด์ ์นดํ์นด๋ฅผ ์ค์นํด์ผ ํ๋ค. ์ด๋ฏธ ํ์๋ค๋ฉด, ์ด ๋ถ๋ถ์ ๊ฑด๋๋ฐ์ญ์์ค.
๋ฅผ ์ฐธ๊ณ ํ์ฌ kafka๋ฅผ ์ค์นํ๋ค.
URI ํต๊ณ ๊ฐ์ ์ ์ฅํ๋ ํผ๋ ธ๋ฅผ ์ค์นํ๋ ๋ฒ์ ์๋ดํ๋ค. ์ด๋ฏธ ํ์๋ค๋ฉด, ์ด ๋ถ๋ถ์ ๊ฑด๋๋ฐ์ญ์์ค.
๋ฅผ ์ฐธ๊ณ ํ์ฌ ํผ๋ ธ๋ฅผ ์ค์นํ๋ค.
์ URI ํต๊ณ๋ฅผ ์ํ ํผ๋ ธ ํ ์ด๋ธ ์คํค๋ง์ ํ ์ด๋ธ ์ ๋ณด๊ฐ ์๋ค.
ํผ๋ ธ์ ํ์ํ ํ ์ด๋ธ์ ๊ตฌ์ฑํ๋ ๋ฐฉ๋ฒ์ ๋ฅผ ์ฐธ๊ณ ํ์.
์ ์ค์ ๊ฐ๋ค์ ๋ณ๊ฒฝํ๋ ค๋ฉด ์ํ๋ ์ pinpoint.config
ํ์ผ์์ ๊ฐ์ ๋ณ๊ฒฝํ์ฌ ํํฌ์ธํธ๋ฅผ ์ฌ๋น๋ํ๋ค. ํ์ผ์ ์์ ํ์ง ์๊ณ , ํํฌ์ธํธ ์์ด์ ํธ๋ฅผ ๋ถํ ์ดํ๋ฆฌ์ผ์ด์
์ ์คํํ ๋ -Dprofiler.uri.stat.enable=false
์ ๊ฐ์ด ๊ฐ์ ๋ฃ์ด๋ ๋๋ค.
์ ์์ธํ ์ค๋ช ์ด ์์ผ๋ ์ฐธ๊ณ ํด์ ๋ฉํธ๋ฆญ ์ฝ๋ ํฐ ์ค์ ๊ฐ์ ์ธํ ํ์.
์ ์ค์ ์ธ์ URI ํต๊ณ๋ฅผ ์ํด ์ ์๋ ์ค์ ๊ฐ์ด ์ถ๊ฐ๋์๋ค:
์ ์์ธํ ์ค๋ช ์ด ์์ผ๋ ์ฐธ๊ณ ํด์ ๋ฉํธ๋ฆญ ์น ์ค์ ๊ฐ์ ์ธํ ํ์.
์ ์ค์ ์ธ์ URI ํต๊ณ๋ฅผ ์ํด ์ ์๋ ์ค์ ๊ฐ์ด ์ถ๊ฐ๋์๋ค: