الانتقال إلى المحتوى الرئيسي
باختصارراقب تطبيقات JVM في ClickStack باستخدام وكيل OpenTelemetry لـ Java. يتضمن مجموعة بيانات تجريبية ولوحة معلومات مُعدّة مسبقًا.

التكامل مع تطبيق JVM موجود

يوضح هذا القسم كيفية تهيئة تطبيق JVM الموجود لديك لإرسال المقاييس إلى ClickStack باستخدام وكيل OpenTelemetry لـ Java. إذا كنت ترغب في اختبار التكامل قبل تهيئة إعداد الإنتاج لديك، يمكنك الاختبار باستخدام مجموعة البيانات التجريبية الخاصة بنا في قسم مجموعة البيانات التجريبية.
المتطلبات المسبقة
  • مثيل ClickStack قيد التشغيل
  • تطبيق Java موجود مسبقًا (Java 8+)
  • إمكانية تعديل وسيطات بدء تشغيل JVM
1

احصل على مفتاح API لـ ClickStack

يرسل وكيل OpenTelemetry لـ Java البيانات إلى OTLP endpoint الخاص بـ ClickStack، والذي يتطلب المصادقة.
  1. افتح HyperDX على عنوان URL الخاص بـ ClickStack (على سبيل المثال: http://localhost:8080)
  2. أنشئ حسابًا أو سجّل الدخول إذا لزم الأمر
  3. انتقل إلى إعدادات الفريق → مفاتيح API
  4. انسخ مفتاح API للإدخال الخاص بك
2

نزّل وكيل OpenTelemetry لـ Java

نزّل ملف JAR الخاص بوكيل OpenTelemetry لـ Java:
curl -L -O https://github.com/open-telemetry/opentelemetry-java-instrumentation/releases/download/v2.22.0/opentelemetry-javaagent.jar
سيؤدي هذا إلى تنزيل الوكيل إلى الدليل الحالي. ويمكنك وضعه في أي مكان يناسب عملية النشر لديك (على سبيل المثال: /opt/opentelemetry/ أو بجوار ملف JAR الخاص بتطبيقك).
3

اضبط وسيطات بدء تشغيل JVM

أضف وكيل Java إلى أمر بدء تشغيل JVM. يجمع الوكيل تلقائيًا مقاييس JVM ويرسلها إلى ClickStack.
الخيار 1: خيارات سطر الأوامر
java -javaagent:opentelemetry-javaagent.jar \
  -Dotel.service.name=my-java-app \
  -Dotel.exporter.otlp.endpoint=http://localhost:4318 \
  -Dotel.exporter.otlp.protocol=http/protobuf \
  -Dotel.exporter.otlp.headers="authorization=YOUR_API_KEY" \
  -Dotel.metrics.exporter=otlp \
  -Dotel.logs.exporter=none \
  -Dotel.traces.exporter=none \
  -jar my-application.jar
استبدل ما يلي:
  • opentelemetry-javaagent.jar → المسار الكامل إلى ملف JAR الخاص بالوكيل (على سبيل المثال: /opt/opentelemetry/opentelemetry-javaagent.jar)
  • my-java-app → اسمًا واضحًا لخدمتك (على سبيل المثال: payment-service، user-api)
  • YOUR_API_KEY → مفتاح API الخاص بـ ClickStack من الخطوة أعلاه
  • my-application.jar → اسم ملف JAR الخاص بتطبيقك
  • http://localhost:4318 → OTLP endpoint الخاص بـ ClickStack (استخدم localhost:4318 إذا كان ClickStack يعمل على الجهاز نفسه، وإلا فاستخدم http://your-clickstack-host:4318)
الخيار 2: متغيرات البيئة
بدلًا من ذلك، استخدم متغيرات البيئة:
export JAVA_TOOL_OPTIONS="-javaagent:opentelemetry-javaagent.jar"
export OTEL_SERVICE_NAME="my-java-app"
export OTEL_EXPORTER_OTLP_ENDPOINT="http://localhost:4318"
export OTEL_EXPORTER_OTLP_PROTOCOL="http/protobuf"
export OTEL_EXPORTER_OTLP_HEADERS="authorization=YOUR_API_KEY"
export OTEL_METRICS_EXPORTER="otlp"
export OTEL_LOGS_EXPORTER="none"
export OTEL_TRACES_EXPORTER="none"

java -jar my-application.jar
استبدل ما يلي:
  • opentelemetry-javaagent.jar → المسار الكامل إلى ملف JAR الخاص بالوكيل
  • my-java-app → اسم خدمتك
  • YOUR_API_KEY → مفتاح API الخاص بـ ClickStack
  • http://localhost:4318 → OTLP endpoint الخاص بـ ClickStack
  • my-application.jar → اسم ملف JAR الخاص بتطبيقك
يجمع وكيل OpenTelemetry لـ Java تلقائيًا مقاييس JVM التالية:
  • الذاكرة: jvm.memory.used, jvm.memory.limit, jvm.memory.committed, jvm.memory.used_after_last_gc
  • جمع البيانات المهملة: jvm.gc.duration
  • الخيوط: jvm.thread.count
  • الفئات: jvm.class.count, jvm.class.loaded, jvm.class.unloaded
  • CPU: jvm.cpu.time, jvm.cpu.count
4

تحقّق من المقاييس في HyperDX

بعد تشغيل تطبيقك باستخدام الوكيل، تحقّق من أن المقاييس تتدفّق إلى ClickStack:
  1. افتح HyperDX على http://localhost:8080 (أو عنوان URL الخاص بـ ClickStack)
  2. انتقل إلى مستكشف الرسوم البيانية
  3. ابحث عن المقاييس التي تبدأ بـ jvm. (على سبيل المثال: jvm.memory.used، jvm.gc.duration، jvm.thread.count)

مجموعة البيانات التجريبية

بالنسبة إلى المستخدمين الذين يريدون اختبار تكامل مقاييس JVM قبل تزويد تطبيقاتهم بأدوات الرصد، نوفر مجموعة بيانات نموذجية تحتوي على مقاييس مُولَّدة مسبقًا تُظهر سلوك JVM واقعيًا لخدمة مصغّرة متوسطة الحجم ذات حركة مرور ثابتة ومعتدلة.
1

تنزيل مجموعة البيانات النموذجية

# نزّل مقاييس Gauge ‏(الذاكرة، والخيوط، وCPU، والفئات)
curl -O https://datasets-documentation.s3.eu-west-3.amazonaws.com/clickstack-integrations/jvm/jvm-metrics-gauge.jsonl

# نزّل مقاييس Sum ‏(أحداث GC)
curl -O https://datasets-documentation.s3.eu-west-3.amazonaws.com/clickstack-integrations/jvm/jvm-metrics-sum.jsonl
تتضمن مجموعة البيانات 24 ساعة من مقاييس JVM، وتُظهر:
  • نمو ذاكرة Heap مع أحداث garbage collection دورية
  • تغيّرات في عدد الخيوط
  • أزمنة توقّف GC واقعية
  • نشاط تحميل الفئات
  • أنماط استخدام CPU
2

تشغيل ClickStack

إذا لم يكن ClickStack قيد التشغيل لديك بالفعل:
docker run -d --name clickstack \
  -p 8080:8080 -p 4317:4317 -p 4318:4318 \
  clickhouse/clickstack-all-in-one:latest
انتظر بضع لحظات حتى يكتمل تشغيل ClickStack بالكامل.
3

استيراد مجموعة البيانات التجريبية

# استورد مقاييس Gauge ‏(الذاكرة، والخيوط، وCPU، والفئات)
docker exec -i clickstack clickhouse-client --query="
  INSERT INTO default.otel_metrics_gauge FORMAT JSONEachRow
" < jvm-metrics-gauge.jsonl

# استورد مقاييس Sum ‏(أحداث GC)
docker exec -i clickstack clickhouse-client --query="
  INSERT INTO default.otel_metrics_sum FORMAT JSONEachRow
" < jvm-metrics-sum.jsonl
يؤدي ذلك إلى استيراد المقاييس مباشرةً إلى جداول المقاييس في ClickStack.
4

التحقق من البيانات التجريبية

بعد اكتمال الاستيراد:
  1. افتح HyperDX على http://localhost:8080 وسجّل الدخول (أنشئ حسابًا إذا لزم الأمر)
  2. انتقل إلى Search view واضبط source على Metrics
  3. اضبط time range على 2025-12-06 14:00:00 - 2025-12-09 14:00:00
  4. ابحث عن jvm.memory.used أو jvm.gc.duration
يُفترض أن ترى مقاييس الخدمة التجريبية.
عرض المنطقة الزمنيةيعرض HyperDX timestamps وفقًا للمنطقة الزمنية المحلية في متصفحك. تمتد البيانات التجريبية عبر 2025-12-07 14:00:00 - 2025-12-08 14:00:00 (UTC). اضبط time range على 2025-12-06 14:00:00 - 2025-12-09 14:00:00 لضمان ظهور المقاييس التجريبية بغض النظر عن موقعك. وبعد ظهور المقاييس، يمكنك تضييق النطاق إلى فترة 24 ساعة للحصول على visualizations أوضح.

لوحات المعلومات والتصورات

لمساعدتك في مراقبة تطبيقات JVM باستخدام ClickStack، نوفر لوحة معلومات مُعدّة مسبقًا تتضمن المرئيات الأساسية لمقاييس JVM.
1

إعداد لوحة المعلومات

2

استيراد لوحة المعلومات المُعدّة مسبقًا

  1. افتح HyperDX وانتقل إلى قسم Dashboards
  2. انقر على Import Dashboard في الزاوية العلوية اليمنى ضمن قائمة النقاط الثلاث
  1. حمّل الملف jvm-metrics-dashboard.json ثم انقر على Finish Import
3

عرض لوحة المعلومات

سيتم إنشاء لوحة المعلومات مع تهيئة جميع المرئيات مسبقًا:
بالنسبة إلى مجموعة البيانات التجريبية، اضبط النطاق الزمني على 2025-12-07 14:00:00 - 2025-12-08 14:00:00 (UTC). وعدّل ذلك وفقًا لمنطقتك الزمنية المحلية.

استكشاف الأخطاء وإصلاحها

تعذّر بدء تشغيل الوكيل

تأكّد من وجود ملف JAR الخاص بالوكيل:
ls -lh /path/to/opentelemetry-javaagent.jar
تحقّق من توافق إصدار Java (يتطلّب Java 8+):
java -version
تحقّق من ظهور رسالة في السجل عند بدء تشغيل العامل: عند بدء تشغيل تطبيقك، يُفترض أن ترى ما يلي:
[otel.javaagent] OpenTelemetry Javaagent v2.22.0 started

عدم ظهور أي مقاييس في HyperDX

تحقّق من أن ClickStack قيد التشغيل ويمكن الوصول إليه:
docker ps | grep clickstack
curl -v http://localhost:4318/v1/metrics
تحقق من تهيئة مُصدِّر المقاييس:
# If using environment variables, verify:
echo $OTEL_METRICS_EXPORTER
# Should output: otlp
تحقّق من سجلات التطبيق بحثًا عن أخطاء OpenTelemetry: ابحث عن أي رسائل error مرتبطة بـ OpenTelemetry أو حالات فشل التصدير عبر OTLP في سجلات تطبيقك. تحقّق من اتصال الشبكة: إذا كان ClickStack مستضافًا على host بعيد، فتأكّد من إمكانية الوصول إلى المنفذ 4318 من خادم التطبيق لديك. تحقّق من إصدار agent: تأكّد من أنك تستخدم أحدث إصدار مستقر من agent (حاليًا 2.22.0)، إذ تتضمّن الإصدارات الأحدث غالبًا تحسينات في الأداء.

الخطوات التالية

الانتقال إلى بيئة الإنتاج

يوضح هذا الدليل كيفية تهيئة وكيل OpenTelemetry لـ Java للاختبار المحلي. أما في عمليات النشر على بيئة الإنتاج، فأدرِج ملف JAR الخاص بالوكيل ضمن صور الحاويات، واضبط التهيئة عبر متغيرات البيئة لتسهيل الإدارة. وفي البيئات الأكبر التي تضم عددًا كبيرًا من مثيلات JVM، انشر OpenTelemetry Collector مركزيًا لتجميع المقاييس وإعادة توجيهها من عدة تطبيقات بدلًا من إرسالها مباشرةً إلى ClickStack. راجع إدخال البيانات باستخدام OpenTelemetry للاطلاع على أنماط النشر في بيئة الإنتاج وأمثلة على تهيئة OpenTelemetry Collector.
آخر تعديل في ٢٥ يونيو ٢٠٢٦