Elastic
كيفية دمج Elasticsearch مع OpenReplay ورؤية أخطاء الـ backend جنبًا إلى جنب مع تسجيلات الجلسات.
1. إنشاء مفتاح API جديد
Section titled 1. إنشاء مفتاح API جديدإذا كنت تستخدم لوحة تحكم Kibana:
- سجّل الدخول إلى لوحة تحكم Kibana الخاصة بك.
- انتقل إلى Dev Tools > Console.
- انسخ كود وحدة التحكم التالي إلى وحدة التحكم لديك وقم بتشغيله.
إذا كنت تستخدم أوامر CURL:
- نفّذ أمر cURL التالي في الطرفية (terminal) الخاصة بك.
ملاحظة: بشكل افتراضي، سيبحث هذا التكامل عن السجلات داخل أي فهرس (index) يطابق *log*. إذا كان لديك فهرس محدد للسجلات لا يطابق هذا النمط، فيرجى تغيير اسم الفهرس في السطر 12 في الأمر التالي. إذا كنت تريد تحديد أكثر من فهرس واحد، يمكنك الفصل بين الأسماء باستخدام ,.
POST /_security/api_key
{
"name": "openreplay-api-key",
"role_descriptors": {
"openreplay-role": {
"cluster": [
"all"
],
"index": [
{
"names": [
"*log*"
],
"privileges": [
"read"
]
}
]
}
}
}
إذا استخدمت أيًا من الطرق السابقة لإنشاء مفتاح API، فستحصل على نتيجة كالتالي:
{
"id" : "eQWAIG0Bo0VqB8HXFH9-",
"name" : "openreplay-api-key",
"api_key" : "dZ5ycVRJTU-5UW_RYfi1_w"
}
تأكد من نسخ id وapi_key لأننا نحتاجهما من أجل التكامل لدينا. لمزيد من المعلومات حول إنشاء مفتاح API، يرجى الرجوع إلى هذه الوثائق.
2. تفعيل Elasticsearch في OpenReplay
Section titled 2. تفعيل Elasticsearch في OpenReplayضع عنوان host الخاص بك، وport، وid، وapi_key في لوحة تحكم OpenReplay ضمن ‘Preferences > Integration’.
إذا غيّرت الفهرس عند إنشاء api_key، فيرجى تحديد الاسم في indexes.

3. تمرير openReplaySessionToken
Section titled 3. تمرير openReplaySessionTokenلربط حدث Elasticsearch بجلسة المستخدم المسجَّلة، يجب تمرير رمز (token) فريد من الـ frontend إلى الـ backend الخاص بك في كل طلب ترغب في تتبعه. يمكن القيام بذلك باستخدام ترويسة HTTP مخصصة. في المثال أدناه، نستخدم الدالة fetch لإرسال تلك الترويسة.
const headers = {
Accept: 'application/json',
'Content-Type': 'application/json',
};
if (tracker.getSessionToken()) { // or window.OpenReplay instead of tracker if you're using the snippet
headers['X-OpenReplay-SessionToken'] = tracker.getSessionToken(); // Inject openReplaySessionToken
}
fetch('www.your-backend.com', {
'GET',
headers,
});
لكي يربط OpenReplay إدخال سجل Elasticsearch بجلسة المستخدم المسجَّلة، يجب تمرير رمز (token) فريد كجزء من كل خطأ في الـ backend ترغب في تتبعه.
فيما يلي مثال بلغة Python باستخدام Monkey Patching.
import sys
import traceback
#...
old_tb = traceback.print_exception
old_f = sys.stdout
old_e = sys.stderr
OPENREPLAY_SESSION_TOKEN = None
class F:
def write(self, x):
if OPENREPLAY_SESSION_TOKEN is not None and x != '\n':
old_f.write(f"[openReplaySessionToken={OPENREPLAY_SESSION_TOKEN}] {x}")
else:
old_f.write(x)
def flush(self):
pass
def tb_print_exception(etype, value, tb, limit=None, file=None, chain=True):
if OPENREPLAY_SESSION_TOKEN is not None:
value = type(value)(f"[openReplaySessionToken={OPENREPLAY_SESSION_TOKEN}] " + str(value))
old_tb(etype, value, tb, limit, file, chain)
traceback.print_exception = tb_print_exception
sys.stderr = F()
اسم الوسم openReplaySessionToken حساس لحالة الأحرف.
اعتبارات خاصة
Section titled اعتبارات خاصةبشكل افتراضي، نبحث عن كل سجل مرتبط بجلسة OpenReplay باستخدام السمتين message وutc_time. نحن مهتمون فقط بسجلات الأخطاء؛ ولتحديد سجلات الأخطاء نتحقق من أن السمة tags تحتوي على القيمة error.
لديك أسئلة؟
Section titled لديك أسئلة؟إذا واجهت أي مشكلات، تواصل معنا عبر Slack أو تفقّد المنتدى الخاص بنا واحصل على المساعدة من مجتمعنا.