Skip to main content
PromptQuorumPromptQuorum
Home/Prompt Engineering/التحكم في إصدارات الموجّهات: التتبع والتراجع وسير عمل الفريق
Team Operations & Governance

التحكم في إصدارات الموجّهات: التتبع والتراجع وسير عمل الفريق

·١٠ دقائق للقراءة·By Hans Kuepper · Founder of PromptQuorum, multi-model AI dispatch tool · PromptQuorum

الموجّهات غير الخاضعة للتحكم في الإصدارات تفشل بصمت — بدون سجل تغييرات، لا توجد مسار للتراجع عندما يُدهور تحديث الموجّه جودة المخرجات أو يُعطل المُحلِّلات اللاحقة. الإصدار الدلالي (MAJOR.MINOR.PATCH) وسير عمل فروع Git واختبارات الانحدار الآلية وسجلات التغييرات المهيكلة تطبّق على إدارة الموجّهات نفس الانضباط الذي تستخدمه فرق البرمجيات بالفعل للكود.

التحكم في إصدارات الموجّهات يتتبع كل تغيير في موجّه الذكاء الاصطناعي باستخدام الإصدار الدلالي (MAJOR.MINOR.PATCH) وسير عمل Git. يُتيح التراجع الفوري والتعاون في الفريق واكتشاف الانحدارات — نفس الانضباط المطبّق على الكود، مطبَّق على الموجّهات.

Key Takeaways

  • طبّق MAJOR.MINOR.PATCH على الموجّهات: MAJOR لتغييرات تنسيق المخرجات التي تُعطل التوافق، MINOR لتحسينات الجودة، PATCH لتصحيح الأخطاء الإملائية/الصياغة
  • خزّن الموجّهات في مجلد `/prompts/` في Git — عامِلها ككود وليس كإعدادات
  • كل تغيير في الموجّه يفتح PR؛ تُشغَّل اختبارات الانحدار الآلية في كل PR قبل المراجعة اليدوية
  • سجل التغييرات للموجّه يتطلب 5 حقول: الإصدار والتاريخ والمؤلف ونوع التغيير والتغيير المتوقع في المخرجات
  • التراجع باستخدام `git revert` (قياسي)، أو feature flags (بدون توقف)، أو تجاوز متغير البيئة (hotfix)
  • عيّن مالكاً للموجّه لكل منطقة وظيفية لتجنب تعارضات الدمج والمسؤوليات غير الواضحة
  • مجموعة اختبار ذهبية من 10–20 مدخلاً تمثيلياً هي الحد الأدنى لأي موجّه إنتاجي

Quick Facts

  • ·الإصدار الدلالي للموجّهات: MAJOR عند تغييرات تنسيق المخرجات التي تُعطل التوافق، MINOR عند تحسينات الجودة، PATCH عند تصحيح الأخطاء الإملائية والتوضيحات
  • ·git revert على موجّه يستغرق ثوانٍ؛ إعادة الاختبار بدون سجل إصدارات يستغرق ساعات
  • ·سجلات التغييرات في الموجّهات تتطلب 5 حقول: الإصدار والتاريخ والمؤلف ونوع التغيير (MAJOR/MINOR/PATCH) والتغيير المتوقع في المخرجات
  • ·شغّل اختبارات الانحدار الآلية مقابل ≥10 حالات اختبار ذهبية في كل PR للموجّه قبل المراجعة اليدوية
  • ·ثلاثة أنماط تفريع للموجّهات: feature/ (قدرة جديدة)، fix/ (انحدار)، experiment/ (اختبار A/B)

🔍 TL;DR

طبّق إصدار MAJOR.MINOR.PATCH وسير عمل Git على كل موجّه. كل تغيير يفتح PR، وكل PR يُشغّل اختبارات انحدار آلية، وكل دمج يُوسَم بإصدار. التراجع هو `git revert` — يُنفَّذ في ثوانٍ مع الحفاظ الكامل على سجل التدقيق.

لماذا يمنع التحكم في إصدارات الموجّهات الانحدارات الصامتة

📍 In One Sentence

التحكم في إصدارات الموجّهات هو نظام يتتبع كل تغيير في موجّه الذكاء الاصطناعي، ويتيح التراجع إلى أي إصدار سابق، ويسجّل المؤلف وسبب كل تعديل.

بدون التحكم في الإصدارات، تغيير الموجّه الذي يُدهور جودة المخرجات لا يترك أثراً — بدون سجل خطأ، بدون diff، بدون مسار للتراجع. يُعيد النموذج ردوداً معقولة لكنها غير صحيحة بدلاً من رمي استثناءات. عندما تُكتشف انخفاض الجودة (عبر شكاوى المستخدمين أو مقاييس الدقة أو أخطاء التحليل اللاحقة)، قد يكون الموجّه الأصلي قد ضاع.

ثلاثة أنماط فشل يمنعها التحكم في الإصدارات: (1) الانحدار الصامت — تغيير في الصياغة يُعدّل سلوك النموذج بشكل خفي، مما يُدهور جودة المخرجات في آلاف الطلبات قبل أن يلاحظ أحد. (2) فخ بلا تراجع — بدون سجل، استعادة الموجّه السابق تتطلب إعادة بنائه من الذاكرة أو سجلات النشر القديمة. (3) التعارض أثناء التعاون — مهندسان يُعدّلان نفس الموجّه بشكل مستقل ويُكتب أحدهما فوق تغيير الآخر بدون سجل لما ضاع.

🔍 الانحدار الصامت

الموجّهات تفشل بصمت — تُعيد ردوداً معقولة لكنها غير صحيحة بدلاً من أخطاء. سجلات الأخطاء لديك لن تكتشف انخفاضات الجودة. فقط اختبارات الانحدار مقابل مجموعة اختبار ذهبية ستفعل ذلك.

كيف يعمل الإصدار الدلالي لموجّهات الذكاء الاصطناعي

إصدار MAJOR.MINOR.PATCH يُخبر كل مستدعٍ إذا كان تغيير الموجّه آمناً للتبني بدون إعادة اختبار الكود اللاحق. MAJOR يعني أن تنسيق المخرجات تغيّر (المحللات اللاحقة ستنكسر). MINOR يعني أن الجودة تحسّنت لكن التنسيق مستقر. PATCH يعني أن الصياغة أو الوضوح فقط تغيّرا بدون تأثير على السلوك.

نوع التغييرمتى ترفع الرقممثالمتوافق للخلف؟

🔍 مُشغّل MAJOR

ارفع MAJOR في كل مرة ينكسر فيها الكود اللاحق الذي يُحلّل مخرجات موجّهك. إذا تغيّرت المخرجات من مصفوفة JSON إلى قائمة markdown، فهذا رفع MAJOR حتى لو كان المحتوى متطابقاً.

🔍 وسم في Git

وسّم كل إصدار بعد الدمج: `git tag v2.1.0 -m "تحسين استنتاج استخراج التواريخ"`. هذا ينشئ مرجعاً دائماً للتراجع.

كيفية إعداد سير عمل Git لتغييرات الموجّهات

سير العمل القياسي هو: إنشاء فرع → تعديل الموجّه → تشغيل اختبارات الانحدار → فتح PR → دمج ووسم. كل خطوة تعكس تغيير كود البرنامج — لأن الموجّه هو كود.

  1. 1
    أنشئ فرع feature: `git checkout -b feature/add-json-output`. استخدم بوادئ `feature/` (قدرة جديدة)، `fix/` (تصحيح انحدار)، أو `experiment/` (اختبار A/B).
  2. 2
    عدّل ملف الموجّه في `/prompts/name.txt`. حدّث تعليق الإصدار في البداية: `# version: 2.0.0 | changed: JSON output format | author: jane`.
  3. 3
    شغّل مجموعة الانحدار الآلية مقابل مجموعة الاختبار الذهبية (10 حالات على الأقل). يجب أن تشمل الاختبارات: التحقق من التنسيق، ومقارنة المخرجات مقابل الردود الذهبية، وعلم الهلوسة، والكمون. يجب أن تنجح جميع الاختبارات قبل فتح PR.
  4. 4
    افتح PR بوصف يغطي: ما الذي تغيّر، ولماذا، وأي رفع للإصدار (MAJOR/MINOR/PATCH) والتغيير المتوقع في المخرجات. المراجع يتحقق من: الوضوح، مخاطر الهلوسة، تنسيق المخرجات، والأمان.
  5. 5
    بعد الموافقة، ادمج في main وسّم الإصدار: `git tag v2.0.0 -m "JSON output format — MAJOR"` ثم `git push origin v2.0.0`.
yaml
# .github/workflows/prompt-regression.yml
name: Prompt Regression Tests
on:
  pull_request:
    paths:
      - 'prompts/**'

jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - name: Run prompt regression tests
        run: npm run test:prompts
        env:
          OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}

🔍 هيكل المجلدات

خزّن الموجّهات في `/prompts/` وأدوات الاختبار في `/prompts/tests/`. هذا يجعل ملفات الموجّهات قابلة للمراجعة بشكل مستقل، منفصلة عن كود التطبيق، بينما تبقى في نفس المستودع.

ما يجب أن تتضمنه كل إدخال في سجل التغييرات للموجّه

إدخال سجل التغييرات للموجّه يتطلب 5 حقول: الإصدار والتاريخ والمؤلف ونوع التغيير والتغيير المتوقع في المخرجات. التغيير في المخرجات هو الحقل الأهم: يصف كيف ستختلف استجابة النموذج بعد التغيير، لكي يعرف المستدعون اللاحقون ما يجب تحديثه.

الحقلمطلوبمثال
markdown
## [v2.1.0] — 2026-04-30

**Author:** jane.smith@empresa.com
**Change type:** MINOR — improved date extraction reasoning
**Expected output delta:** Date fields now consistently use ISO 8601 format (YYYY-MM-DD).
  Previous behavior: returned MM/DD/YYYY in ~30% of edge cases.
  Backwards-compatible — parsers accepting ISO 8601 require no update.

**Test results:** 18/18 golden test cases passed (previously 15/18).

🔍 اكتب سجل التغييرات أولاً

اكتب إدخال سجل التغييرات قبل كتابة تغيير الموجّه — هذا يُجبرك على توضيح النية. إذا لم تستطع وصف التغيير المتوقع في المخرجات، فأنت لم تفهم بعد ما تُغيّره.

متى وكيف تتراجع عن موجّه إلى إصدار سابق

`git revert` هو مسار التراجع القياسي — ينشئ commit جديداً يتراجع عن التغيير الإشكالي بدون حذف السجل. اعرف مُشغّلات التراجع وكيّف الطريقة حسب الإلحاح.

مُشغّلات التراجع: (1) انخفاض الجودة في الإنتاج مكتشف عبر مقاييس الدقة أو تقارير المستخدمين. (2) مشكلة أمنية وُجدت في الموجّه المنشور. (3) تحديث إصدار النموذج يُعطل التوافق مع الموجّه الحالي. (4) منطق الأعمال تغيّر مما يجعل تنسيق المخرجات السابق غير صحيح.

طريقة التراجعالسرعةالمخاطرمتى تستخدمها

🔍 اختبر قبل التراجع

لا تتراجع أبداً بدون تشغيل اختبارات الانحدار أولاً — قد تُعيد إدخال خطأ تم تصحيحه سابقاً. الخطأ الذي كان الإصدار المتراجع عنه قد صحّحه قد يكون أسوأ من الانحدار الذي تهرب منه.

كيف تتعاون الفرق على تغييرات الموجّهات بدون تعارضات

الملكية تمنع تعارضات الدمج: عيّن مالكاً للموجّه لكل منطقة وظيفية، وكل التغييرات على هذا الموجّه تتطلب مراجعة ذلك المالك. بدون ملكية واضحة، مهندسان يُعدّلان نفس الموجّه بالتوازي والدمج اللاحق يُكتب بصمت فوق التغيير السابق.

نمطان للمستودع يعملان للفرق: (1) Monorepo مع مجلد `/prompts/` — أفضل عندما تكون الموجّهات مرتبطة ارتباطاً وثيقاً بخدمة واحدة وتحتاج تغييرات الموجّهات للنشر مع التطبيق. (2) مستودع أو حزمة موجّهات مخصصة — أفضل عندما تُشارَك الموجّهات بين خدمات متعددة، أو عندما يحتاج مهندسو الموجّهات إلى دورات مراجعة مستقلة بدون الوصول إلى مستودع التطبيق.

🔍 نموذج الملكية

عيّن مالكاً للموجّه لكل منطقة وظيفية (مثلاً، مالك موجّه الاستخراج، مالك موجّه التصنيف). كل تغيير على هذا الموجّه يمر بمراجعة ذلك المالك — بدون استثناءات.

ما تكتشفه الاختبارات الآلية قبل نشر تغيير الموجّه

اختبارات الانحدار تكتشف كسر التنسيق؛ LLM-as-judge يكتشف انخفاضات الجودة. أربعة أنواع من الاختبارات تغطي أنماط الفشل الرئيسية قبل أن يصل تغيير الموجّه إلى الإنتاج.

الأنواع الأربعة من الاختبارات: (1) التحقق من التنسيق — يتحقق أن المخرجات تتطابق مع المخطط المتوقع (هيكل JSON، الحقول المطلوبة، أنواع البيانات). يُشغَّل في ميلي ثانية، يكتشف 60–70% من التغييرات الإشكالية. (2) مقارنة المجموعة الذهبية — يقارن المخرجات مقابل ردود صحيحة تحقق منها يدوياً البشر على 10–20 مدخلاً تمثيلياً. LLM-as-judge أو مقاييس تشابه السلاسل تُقيّم المقارنة. (3) علم الهلوسة — يكتشف الادعاءات الواقعية في المخرجات غير المستندة إلى السياق المُقدَّم. يُعلّم أي رد يدّعي حقائق غير موجودة في المدخل. (4) فحص الكمون — يتحقق أن متوسط وقت الاستجابة يبقى ضمن نطاق مقبول (مثلاً p95 ≤ 3s). يكتشف الموجّهات التي تُسبّب حوسبة مفرطة للنموذج.

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

مجموعة اختبار ذهبية من 10–20 مدخلاً تمثيلياً هي الحد الأدنى لأي موجّه إنتاجي. تغطي: المسار الطبيعي، الحالات الحدية (مدخل فارغ/طويل جداً)، المدخلات التعارضية وأنماط الفشل المعروفة.

الأخطاء الشائعة في التحكم في إصدارات الموجّهات

بدون مخطط إصدار منذ اليوم الأول

Why it hurts: التغييرات الإشكالية الصامتة تُنشر عندما يكبر الفريق ويُعدّل مهندسون متعددون الموجّهات بدون اتفاقية إصدار مشتركة

Fix: تبنَّ MAJOR.MINOR.PATCH من أول موجّه في الإنتاج — حتى لو كان مهندس واحد فقط يكتب الموجّهات اليوم، المُوظَّف التالي يرث النظام

تخزين الموجّهات داخل كود التطبيق بدلاً من مجلد `/prompts/`

Why it hurts: الموجّهات المدفونة في كود التطبيق لا يمكن مراجعتها أو اختبارها أو إصدارها بشكل مستقل — تتغيّر مع كل نشر للتطبيق

Fix: انقل جميع الموجّهات إلى `/prompts/` مع أدوات الاختبار في `/prompts/tests/`. هذا يجعلها قابلة للمراجعة كمنتجات مستقلة بدون لمس كود التطبيق

بدون اشتراط سجل تغييرات لكل PR

Why it hurts: عندما تظهر انحدارات بعد أسابيع، لا يوجد سجل لما تغيّر، متى، أو لماذا — مما يُجبر على تنقيب مُضنٍ عبر git log

Fix: اجعل إدخال CHANGELOG.md إلزامياً كاشتراط PR عبر فحص CI — يفشل PR إذا لم يوجد إدخال سجل تغييرات لملف الموجّه المُعدَّل

اختبار المسار الطبيعي فقط

Why it hurts: الحالات الحدية التي تعمل في الإصدار السابق تفشل بصمت بعد تغيير الموجّه — تُكتشف فقط من خلال شكاوى المستخدمين أو أخطاء التحليل اللاحقة في الإنتاج

Fix: اشترط 10 حالات اختبار ذهبية على الأقل تشمل حالتين حديتين على الأقل ومدخلاً تعارضياً واحداً — لا يُدمج أي PR بدون نجاح مجموعة الاختبار الكاملة

التراجع بدون تشغيل اختبارات الانحدار

Why it hurts: الإصدار المتراجع عنه يُعيد إدخال خطأ كان التغيير المُتراجَع عنه قد صحّحه، مما يخلق انحداراً ثانياً فوق الأول

Fix: شغّل دائماً مجموعة الانحدار الكاملة قبل دمج PR للتراجع — عامِل commits التراجع كتغييرات إنتاج تتطلب نفس بوابة الاختبار للتغييرات الأمامية

متطلبات الامتثال والتدقيق لتغييرات الموجّهات

EU AI Act، المطبَّق على الأنظمة عالية المخاطر في الصحة والمالية والموارد البشرية والبنية التحتية الحيوية، يتطلب قابلية التتبع لمخرجات الذكاء الاصطناعي في المجالات المنظّمة. سجل إصدارات الموجّهات المُتحكَّم فيه مع المؤلف والتاريخ ونوع التغيير وسجلات الموافقة يُلبّي متطلب قابلية التتبع بدون أدوات إضافية.

GDPR المادة 22 تنطبق على الموجّهات التي تتخذ أو تدعم قرارات آلية تؤثر على الأفراد. التحكم في الإصدارات وسجلات التدقيق تُثبت الإشراف البشري — git log مع commits موقّعة يوفر هذه الأدلة. فرق الصحة والمالية العاملة تحت أنظمة قطاعية محددة (MiFID II، HIPAA) عادةً ما تتطلب أكثر من 12 شهراً من سجل إصدارات الموجّهات مع تخزين مقاوم للتلاعب. في منطقة الشرق الأوسط وشمال أفريقيا، تُوجّه هيئة الاتصالات وتقنية المعلومات (CITC) في المملكة العربية السعودية والجهات التنظيمية في الإمارات العربية المتحدة نحو معايير حوكمة الذكاء الاصطناعي التي تُوصي بقابلية تتبع أنظمة الذكاء الاصطناعي كممارسة إدارة مسؤولة. CAC في الصين تفرض متطلبات سجل كاملة لأنظمة الذكاء الاصطناعي في التطبيقات المنظّمة.

الأسئلة الشائعة

ما هو التحكم في إصدارات الموجّهات؟

التحكم في إصدارات الموجّهات هو نظام يتتبع كل تغيير في موجّه الذكاء الاصطناعي، ويتيح التراجع إلى أي إصدار سابق، ويسجّل المؤلف وسبب كل تعديل. يطبّق الإصدار الدلالي (MAJOR.MINOR.PATCH) على الموجّهات: MAJOR لتغييرات تنسيق المخرجات التي تُعطل التوافق، MINOR لتحسينات الجودة، PATCH لتصحيح الأخطاء الإملائية/الصياغة. تُخزَّن الموجّهات في Git كملفات نصية، التغييرات تمر بمراجعة PR، والإصدارات تُوسَم.

هل أحتاج مستودع Git منفصل للموجّهات أم يمكنني استخدام مستودع التطبيق الحالي؟

للفرق التي تضم أقل من 5 مهندسين أو أقل من 20 موجّهاً: استخدم مجلد /prompts/ في مستودع تطبيقك الحالي. للفرق الأكبر أو عندما تُشارَك الموجّهات بين خدمات متعددة: مستودع موجّهات مخصص يوفر ملكية أوضح، إصداراً مستقلاً، وتحكماً في الوصول. استخدم مستودع التطبيق إذا كانت الموجّهات مرتبطة ارتباطاً وثيقاً بمنطق التطبيق؛ استخدم مستودعاً منفصلاً إذا كانت الموجّهات تخدم خدمات أو فرقاً متعددة.

كيف يختلف إصدار الموجّهات عن إصدار النماذج؟

إصدار الموجّهات يتتبع التغييرات في تعليمات النص التي ترسلها إلى نموذج. إصدار النماذج يتتبع أي إصدار من الذكاء الاصطناعي تستدعيه تطبيقاتك. كلاهما يتطلب تحكماً مستقلاً في الإصدارات. عندما تغيّر النموذج المستهدف، عامِله كرفع MAJOR لإصدار الموجّه حتى لو كان نص الموجّه متطابقاً — نماذج مختلفة تستجيب بشكل مختلف لنفس الموجّه.

ما الحجم الأدنى الموصى به لمجموعة الاختبار لموجّه إنتاجي؟

10–20 حالة اختبار ذهبية هي الحد الأدنى. تغطي: المسار الطبيعي، الحالات الحدية (مدخل فارغ، مدخل طويل جداً)، المدخلات التعارضية (محاولات تجاوز التعليمات) وأنماط الفشل المعروفة. أقل من 10 حالات يفوّت حالات حدية كثيرة؛ أكثر من 50 حالة مكلف الصيانة بدون فائدة متناسبة.

كيف أدير الإصدار عندما يُستخدم نفس الموجّه على نماذج مختلفة؟

احتفظ بسجل إصدارات منفصل لكل مجموعة موجّه+نموذج. استخدم رأس بيانات وصفية في ملف موجّهك: `# version: 2.1.0 | model: gpt-4o`. عند نشره على نموذج جديد، أنشئ ملف متغير جديد بدلاً من الكتابة فوق الموجود. شغّل مجموعة اختبارك الذهبية الكاملة مقابل كل متغير نموذج قبل ترقيته.

هل يجب أن يرفع كل تغيير في الصياغة الإصدار؟

نعم — كل تغيير يرفع الإصدار على مستوى ما. تصحيحات الأخطاء الإملائية: PATCH. تحسينات الجودة بدون تغييرات في التنسيق: MINOR. تغييرات التنسيق/الهيكل التي تُعطل المحللات اللاحقة: MAJOR. لا تتخطَّ رفع الإصدار أبداً — حتى تغييرات الصياغة الصغيرة يمكن أن تؤثر بشكل غير متوقع على سلوك النموذج، وتغيير بدون إصدار لا يمكن التراجع عنه.

ما الأدوات التي تدعم التحكم في إصدارات الموجّهات بشكل أصلي؟

Braintrust وPromptLayer وVellum توفر إصداراً أصلياً للموجّهات مع لوحات تحكم للمقارنة بين الإصدارات وتشغيل التقييمات وعرض سجل الفروق. LangSmith لديه تتبع إصدارات الموجّهات في محوره. PromptQuorum يضيف التحقق متعدد النماذج — يُشغّل موجّهاً مُصدَراً على أكثر من 25 مزوداً للتأكد من أنه يعمل باتساق قبل النشر. للإعدادات الأبسط، Git النقي مع مجلد /prompts/ يعمل جيداً — الموجّهات ملفات نصية وGit يدير الفروق والسجل والتراجع بشكل أصلي.

كيف أتراجع عن موجّه إذا كنت لا أستخدم Git؟

إذا كنت تستخدم منصة إدارة موجّهات (Braintrust، Vellum، PromptLayer)، استخدم سجل الإصدارات المدمج للرجوع إلى الإصدار المعتمد السابق. إذا كنت تخزّن الموجّهات في متغيرات البيئة، احتفظ بنسخة احتياطية قبل كل تغيير واستعدها عبر pipeline النشر. مستقبلاً، أضف على الأقل ملف CHANGELOG.md — حتى بدون Git، هذا يمنحك مرجعاً للتراجع.

قراءات ذات صلة

المصادر

Apply these techniques with a local LLM or your own API keys — PromptQuorum works with any backend.

Try PromptQuorum free →

← Back to Prompt Engineering

التحكم في إصدارات الموجّهات: Git وSemver والتراجع