أي أمر، ومتى
للتكرار اليومي المحلي ستحتاج تقريبًا دائمًا إلى
yarn twenty dev. يُستخدم النشر والإصدار لإطلاق الإصدارات، وليس للحلقة المحلية.| ترغب في… | أمر | الملاحظات |
|---|---|---|
| التكرار محليًا مع المزامنة الحية | yarn twenty dev | يراقب ملفاتك ويجري مزامنة عند كل تغيير. |
| مزامنة واحدة ثم إنهاء (CI، السكربتات، الخطّافات) | yarn twenty dev --once | عملية إنشاء واحدة + مزامنة، ثم إنهاء. |
| معاينة التغييرات بدون تطبيقها | yarn twenty dev --once --dry-run | يحتسب الفرق ويطبعه؛ ولا يكتب أي شيء. |
| إزالة التطبيق من مساحة العمل | yarn twenty app:uninstall | أضف --yes لتخطي رسالة التأكيد. |
| إرسال ملف tarball إلى خادم | yarn twenty app:publish --private | يتطلّب إصدارًا أعلى بشكل صارم في package.json — راجع قسم النشر. |
| النشر في السوق (npm) | yarn twenty app:publish | — |
| تثبيت / ترقية إصدار منشور | yarn twenty app:install | يُثبّت الإصدار المنشور حاليًا. |
| مسح الخادم المحلي والبدء من جديد | yarn twenty docker:reset | يحذف كل البيانات المحلية — كملاذ أخير. |
لا تحتاج المزامنة المحلية إلى زيادة في الإصدار
تنطبق قاعدةversion المتزايدة بدقة (VERSION_ALREADY_EXISTS عند النشر، وAPP_ALREADY_INSTALLED / CANNOT_DOWNGRADE_APPLICATION عند التثبيت) على app:publish / app:install — مسار الإصدارات. يقوم yarn twenty dev بمزامنة ملف manifest في مكانه ولا يتطلّب تغيير الإصدار أبدًا، لذا لست بحاجة إلى تعديل package.json للتكرار. إذا وجدت نفسك تزيد الإصدار لاختبار تغيير محلي، فأنت تستخدم مسار الإصدارات بينما ما تريده هو حلقة التطوير.
قراءة مخرجات المزامنة
كل عملية مزامنة تطبع التغييرات في البيانات الوصفية التي تم تطبيقها (أو التي سيتم تطبيقها، مع خيار--dry-run):
universalIdentifier الخاص به، على سبيل المثال:
معاينة التغييرات (تشغيل تجريبي dry run)
يبنيyarn twenty dev --once --dry-run ملف manifest الخاص بك، ويطلب من الخادم خطة الترحيل، ويطبعها — بدون تطبيق أي شيء. إنها الطريقة الآمنة للإجابة عن سؤال “ما الذي ستغيّره هذه المزامنة؟” قبل الالتزام بها.
- لا يكتب أي شيء — لا ترحيل لبيانات وصفية، ولا تحديث لسجل التطبيق، ولا تغييرات في الأدوار/التبويبات الافتراضية، ولا توليد لعميل API.
- يُرجع نفس الفرق الذي ستُطبِّقه مزامنة حقيقية، حتى تتمكن من مراجعة الكيانات التي سيتم إنشاؤها/تحديثها/حذفها مسبقًا.
- يكون مفيدًا قبل إجراء تغيير محفوف بالمخاطر، أو عند مراجعة تغيير تم إنشاؤه بواسطة الذكاء الاصطناعي، أو في سكربت يجب أن يفشل إذا كان تغيير غير متوقَّع على وشك الحدوث.
يُعاين التشغيل التجريبي فقط تغييرات البيانات الوصفية، ويتطلّب أن يكون التطبيق قد تمت مزامنته مرة واحدة على الأقل (حتى تعرف به مساحة العمل). إذا شغّلته ضد تطبيق لم تتم مزامنته من قبل، سيبلغ الخادم أن التطبيق غير مُثبّت — شغّل
yarn twenty dev مرة واحدة أولًا.سلّم الاستعادة
عندما تبدو البيانات الوصفية المحلية غير صحيحة، صعِّد الإجراءات بهذا الترتيب وتوقّف بمجرد زوال العائق. كل خطوة أكثر إرباكًا من التي قبلها.- أعد المزامنة. شغّل
yarn twenty dev --onceمرة أخرى. عمليات المزامنة متطابِقة الأثر (idempotent) — إعادة تشغيل ملف manifest النظيف آمنة وغالبًا ما تحل تعثرًا عابرًا. - عاين الخطة. شغّل
yarn twenty dev --once --dry-runلرؤية ما الذي تنوي المزامنة التالية تغييره بالضبط، بدون تطبيقه. - اقرأ الخطأ المسمّى. إذا فشلت المزامنة، لاحظ نوع البيانات الوصفية و
universalIdentifierفي الرسالة (انظر أعلاه) وحدّد ذلك الكيان في ملف manifest الخاص بك. يشير التعارض عادةً إلى معرّف مكرر أو مُعاد استخدامه. - إلغاء التثبيت وإعادة التثبيت. شغّل
yarn twenty app:uninstall، ثم أجرِ مزامنة مرة أخرى (yarn twenty dev). هذا يعيد بناء بيانات التطبيق الوصفية من نقطة بداية نظيفة مع إبقاء باقي مساحة العمل سليمة. - إعادة تعيين كاملة (الملاذ الأخير). شغّل
yarn twenty docker:reset، ثم أعد التهيئة والمزامنة.
هل واجهت خطأ في البيانات الوصفية؟ يرجى فتح مشكلة وإرفاق رسالة الترحيل الفاشلة (بما في ذلك نوع البيانات الوصفية و
universalIdentifier)، ومخرجات Metadata changes من عملية المزامنة، والأوامر التي شغّلتها.تجنّب إجراء مزامنات متزامنة على مساحة عمل واحدة
تطبّق المزامنة عمليات ترحيل للبيانات الوصفية. قد يؤدّي تشغيل عدة عمليات مزامنة أو نشر أو تثبيت ضد نفس مساحة العمل في الوقت نفسه — على سبيل المثال، عدّة نوافذ طرفية أو وكلاء ذكاء اصطناعي يتكرّرون بالتوازي — إلى تداخل عمليات الترحيل تلك وترك البيانات الوصفية في حالة مطبَّقة جزئيًا. يقوم الخادم بتسلسل عمليات المزامنة لكل مساحة عمل لمنع ذلك، لكن ما زال ينبغي عليك تمرير عمليات البيانات الوصفية الحساسة عبر عملية واحدة بدلًا من تنفيذها بالتوازي. إذا كنت تنظّم التطوير باستخدام عدة وكلاء، فمرّر استدعاءات المزامنة/النشر/التثبيت عبر طابور واحد حتى تعمل واحدة فقط في الوقت نفسه.تمييز أنواع الإخفاقات
عندما يحدث خلل ما، يتيح لك فرق البيانات الوصفية والأخطاء المسمّاة تحديد موضع الفشل:- خطأ في إنشاء ملف manifest — يفشل الـ CLI قبل إجراء المزامنة (
MANIFEST_BUILD_FAILED،TYPECHECK_FAILED)؛ أصلِح كود التطبيق لديك. - خطأ في المزامنة / الترحيل — تنجح عملية الإنشاء لكن يفشل تطبيق الفرق، مع تسمية الكيان و
universalIdentifier؛ أصلِح البيانات الوصفية المتعارِضة. - خطأ في وقت تشغيل كود التطبيق — تتم المزامنة بنجاح، ولكن دوال المنطق أو المكوّنات لديك لا تعمل بشكل صحيح أثناء وقت التشغيل؛ تحقّق من سجلات الدوال.
- حالة المثيل المحلي — لا ينطبق أيّ مما سبق وما زالت مساحة العمل تبدو غير صحيحة؛ تابع النزول في سلّم الاستعادة.