Apache Camel-এর সাথে Prometheus এবং Grafana একত্রিত করা একটি শক্তিশালী পদ্ধতি, যা আপনাকে আপনার Camel অ্যাপ্লিকেশন থেকে পারফরম্যান্স মেট্রিক্স সংগ্রহ এবং বিশ্লেষণ করার সুযোগ দেয়। Prometheus একটি ওপেন সোর্স সিস্টেম মনিটরিং এবং অ্যালার্টিং টুল, এবং Grafana একটি শক্তিশালী ড্যাশবোর্ড তৈরি করার টুল।
প্রথমে আপনার Maven প্রোজেক্টে প্রয়োজনীয় ডিপেন্ডেন্সি যুক্ত করুন। নিম্নলিখিত ডিপেন্ডেন্সিগুলি pom.xml
ফাইলে যুক্ত করুন:
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-prometheus</artifactId>
<version>3.14.0</version> <!-- Use the latest version -->
</dependency>
Camel কনফিগার করার সময় Prometheus মেট্রিক্স সক্রিয় করতে হবে। নিচে একটি উদাহরণ দেওয়া হলো:
import org.apache.camel.CamelContext;
import org.apache.camel.impl.DefaultCamelContext;
import org.apache.camel.builder.RouteBuilder;
public class PrometheusIntegrationExample {
public static void main(String[] args) throws Exception {
CamelContext camelContext = new DefaultCamelContext();
// Enable Prometheus metrics
camelContext.getManagementStrategy().getManagementAgent().setUseJmx(false); // JMX off for Prometheus
camelContext.getManagementStrategy().getManagementAgent().setEnabled(true);
// Register Prometheus endpoint
camelContext.addRoutes(new RouteBuilder() {
@Override
public void configure() throws Exception {
from("direct:start")
.to("prometheus:myMetrics"); // Custom metrics route
// Other routes can be defined here
}
});
camelContext.start();
// Keep running for some time
Thread.sleep(60000); // Run for 1 minute
// Stop the Camel context
camelContext.stop();
}
}
Camel অ্যাপ্লিকেশন চলাকালীন Prometheus মেট্রিক্স সংগ্রহ করার জন্য একটি HTTP endpoint তৈরি করুন। এটি সাধারণত /metrics
পাথ ব্যবহার করে।
import org.apache.camel.builder.RouteBuilder;
public class MetricsRoute extends RouteBuilder {
@Override
public void configure() throws Exception {
// Expose metrics for Prometheus
from("jetty:http://0.0.0.0:8080/metrics")
.to("prometheus:myMetrics");
}
}
Prometheus কে আপনার Camel অ্যাপ্লিকেশন থেকে মেট্রিক্স সংগ্রহ করার জন্য কনফিগার করুন। prometheus.yml
ফাইলটি সম্পাদনা করুন:
scrape_configs:
- job_name: 'camel-app'
metrics_path: '/metrics'
static_configs:
- targets: ['localhost:8080']
Grafana-তে Prometheus ডাটা সোর্স যুক্ত করুন:
http://localhost:9090
দিন (যেখানে Prometheus চালু আছে)।camel_myMetrics_total
অথবা অন্যান্য আপনার মেট্রিক্স)।Apache Camel-এর সাথে Prometheus এবং Grafana একত্রিত করা আপনার অ্যাপ্লিকেশনটির কার্যকারিতা এবং পারফরম্যান্সের বিশ্লেষণ করতে সাহায্য করে। Prometheus মেট্রিক্স সংগ্রহ করে এবং Grafana ভিজ্যুয়ালাইজেশন সরবরাহ করে, যা একটি কার্যকর মনিটরিং এবং অ্যালার্টিং ব্যবস্থা তৈরি করে। এই একত্রিতকরণ আপনার সিস্টেমের স্থিতিশীলতা এবং কর্মক্ষমতা বাড়ানোর জন্য অপরিহার্য।