نظرة عامة على عملية التمهيد CentOS 7 و RHEL 7 واستكشاف الأخطاء وإصلاحها

توضح هذه المقالة عملية التمهيد لأنظمة CentOS / RHEL 7.x. في حين أنه قد يظل مشابهًا للإصدارات السابقة ، مع RHEL 7 ، يتم عرض systemd. بالإضافة إلى عملية التمهيد ، سأقدم نصائح وحيل حول استكشاف الأخطاء وإصلاحها على طول الطريق.

تحتاج إلى فهم عملية التمهيد قبل أن تتمكن من استكشاف مشكلة عند التمهيد وإصلاحها بنشاط. راجع الخطوات أدناه حتى تكون على دراية بالعملية.

نظرة عامة عالية المستوى

  • قوة + وظيفة.
  • البحث عن جهاز البرامج الثابتة.
  • يقرأ البرنامج الثابت أداة تحميل التشغيل.
  • تحميل محمل التمهيد التكوين (grub2).
  • محمّل التمهيد يُحمِّل kernel و initramfs.
  • يقوم محمل التمهيد بتمرير التحكم إلى النواة.
  • يقوم Kernel بتهيئة الأجهزة + وتنفيذها على /sbin/initأنها pid 1.
  • ينفذ Systemd جميع الأهداف الأولى (يعمل نظام الملفات على /sysroot).
  • تحول Kernel root FS من initramfs root ( /sysroot) إلى rootfs ( /) ثم تمت إعادة تنفيذ النظام كإصدار نظام.
  • يبحث Systemd عن الهدف الافتراضي ويبدأ / يتوقف عن الوحدات كما تم تكوينها أثناء حل التبعيات تلقائيًا وتظهر صفحة تسجيل الدخول.

لمزيد من المعلومات حول عملية التمهيد ، ارجع إلى وثائق نظام التشغيل الرسمية لنظامك.

أهداف Systemd

الأهداف هي في الأساس اختبارات التبعية. لديهم تكوين "قبل" و "بعد" للخدمات المطلوبة بالضبط لتحقيق هذا الهدف. على سبيل المثال: arp.ethernet.service، firewalld.serviceوما إلى ذلك تحتاج إلى البدء والعمل قبل network.targetالوصول إلى. إذا لم يتم التوصل إلى ذلك، الخدمات مثل httpd، nfsو ldapلا يمكن أن تبدأ. هناك 4 أهداف يمكن تحديدها في RHEL / CentOS 7.

  • رسم بياني للاستهداف (واجهة GUI)
  • برنامج multi-user.target (وضع مستخدم متعدد ، تسجيل دخول مستند إلى نص)
  • هدف إنقاذ (موجه sulogin ، تهيئة النظام الأساسية)
  • Emergency.target (موجه sulogin ، تمحور initramfs وتم تثبيت جذر النظام على / للقراءة فقط)

لعرض هدف التمهيد الافتراضي الحالي ، استخدم ما يلي:

systemctl get-default

ضع في اعتبارك أنه يمكنك تغيير هذا في وقت التشغيل عن طريق عزل الهدف. سيؤدي هذا إلى بدء / إيقاف جميع الخدمات المرتبطة بالهدف الجديد ، لذا كن حذرًا (انظر systemctl isolate new.target).

وضع مستخدم واحد

هناك أوقات ستحتاج فيها إلى التمهيد في وضع مستخدم واحد لإصلاح مشكلة في نظام التشغيل. في هذا المثال ، سأوضح لك كيفية استخدام rescue.target"وضع المستخدم الفردي" على RHEL / CentOS 7.

  1. قم بمقاطعة قائمة grub2 بالضغط على "e" للتحرير عند المطالبة بقائمة grub.
  2. ابحث عن السطر الذي يحدد إصدار kernel ( vmlinuz ) وأضف إليه ما يلي:systemd.unit=rescue.target
  3. اضغط على "Ctrl + x" للبدء.
  4. ستتم مطالبتك بعد ذلك بكلمة مرور الجذر للمتابعة ، بمجرد خروجك من غلاف الإنقاذ ، ستستمر عملية التمهيد في تحميل هدفك الافتراضي.

استعادة كلمة المرور الجذرية

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

  1. أعد تشغيل النظام.
  2. قم بمقاطعة قائمة grub2 بالضغط على "e" للتحرير عند المطالبة بقائمة grub.
  3. حرك المؤشر إلى نهاية السطر الذي يحدد النواة ( vmlinuz ). قد ترغب في إزالة جميع وحدات التحكم الأخرى بخلاف TTY0 ، ولكن قد لا تكون هذه الخطوة ضرورية في بيئتك.
  4. إلحاق rd.break( بدون علامات اقتباس ) التي ستقطع عملية التمهيد قبل تسليم عنصر التحكم من initramfs إلى النظام الفعلي.
  5. Ctrl + x للإقلاع.

عند هذه النقطة ، يتم تقديم قذيفة الجذر مع نظام ملفات الجذر المثبت في وضع القراءة فقط /sysroot. سنحتاج إلى إعادة تحميلها بامتيازات الكتابة.

إعادة /sysroot.

# mount -oremount,rw /sysroot

التبديل إلى سجن chroot.

# chroot /sysroot

قم بتغيير كلمة مرور المستخدم الذي لدينا بيانات اعتماد قديمة.

# passwd <username>

إذا كنت تستخدم SElinux ، يجب أن تفكر في إعادة تسمية جميع الملفات قبل متابعة عملية التمهيد. يمكن تخطي هذا الجزء إذا كنت لا تستخدم SElinux.

# touch /.autorelabel

اخرج مرتين وسيبدأ النظام في التمهيد من النقطة التي قطعناها عليه.

مراجعة السجلات من الأحذية السابقة

قد يكون من المفيد عرض سجلات محاولات التمهيد الفاشلة السابقة. إذا تم جعل سجلات journald ثابتة (يتم تخزينها عادةً في الذاكرة وإصدارها عند التمهيد) ، فيمكن القيام بذلك باستخدام journalctlالأداة. اتبع هذه الخطوات إذا كنت بحاجة إلى إعداد تسجيل التمهيد المستمر.

كجذر ، قم بإنشاء ملف السجل لتخزين هذه المعلومات.

# mkdir -p 2775 /var/log/journal && chown :systemd-journal /var/log/journal
# systemctl restart systemd-journald

لفحص سجلات التمهيد السابق ، استخدم -bالخيار مع journalctl. بدون أي وسيطات ، -bسيتم تصفية الإخراج فقط للرسائل المتعلقة التمهيد الأخير. سيتم تصفية عدد سالب لهذه الحجة على الأحذية السابقة. فمثلا:

# journalctl -b-1 -p err

سيعرض لك ذلك سجلات الأخطاء من التمهيد التي حدثت قبل الأحدث. يجب عليك تغيير القيمة العددية لتعكس التمهيد الذي تحتاج إلى عرضه.

إصلاح أخطاء القرص ونظام الملفات

أحد أكثر أخطاء وقت التمهيد شيوعًا هو /etc/fstabالملف الذي تمت تهيئته بشكل خاطئ . أنت لا يمكن استخدام rescue.targetلإصلاح /etc/fstabالخطأ. سوف تتطلب منا معظم هذه القضايا استخدام emergency.targetلأن "الإنقاذ" يتطلب نظامًا أكثر فاعلية.

فيما يلي أمثلة على المشكلات التي تتطلب emergency.target:

  1. نظام ملفات تالف.
  2. UUID غير موجود في /etc/fstab.
  3. نقطة تحميل غير موجودة في /etc/fstab.
  4. خيار تحميل غير صحيح في /etc/fstab.

هام : بعد تحرير /etc/fstabالملف في وضع الطوارئ ، يجب تشغيل ما يلي لإجراءات السلامة:

# systemctl daemon-reload

هنا مثال تجريبي. سنقوم بالتمهيد في وضع الطوارئ لإزالة إدخال خاطئ في /etc/fstab.

  1. قم بمقاطعة قائمة grub2 بالضغط على "e" للتحرير عند المطالبة بقائمة grub.
  2. ابحث عن السطر الذي يحدد إصدار kernel ( vmlinuz ) وأضف إليه ما يلي:systemd.unit=emergency.target
  3. اضغط على "Ctrl + x" للتمهيد.
  4. ستتم مطالبتك بكلمة مرور الجذر للمتابعة.
  5. إعادة الحساب /حتى نتمكن من إجراء تغييرات على fstabالملف:# mount -oremount,rw /
  6. يمكننا استخدام mountالأمر لمعرفة أي إدخال يسبب الخطأ:# mount -a
  7. إزالة الإدخال المخالف من fstabالملف.
  8. استخدم mount -aمرة أخرى للتأكد من حل الخطأ.
  9. استخدم systemctl daemon-reloadكما ذكرت سابقًا لإعادة تحميل جميع ملفات الوحدة ، وإعادة إنشاء شجرة التبعية بالكامل.

بمجرد خروجك من غلاف الطوارئ ، سينهي النظام التمهيد من هدف الطوارئ ، ثم ستتمكن من المتابعة كالمعتاد من تلك النقطة. تم استخدام هذا المثال لتظهر لك عملية استخدام هدف الطوارئ لإجراء تغييرات مستمرة على الملفات الموجودة على النظام.

مشكلات محمل التمهيد مع Grub 2

و /boot/grub2/grub.cfgالملف هو ملف التكوين الرئيسي. لا تقم أبدًا بتحرير هذا الملف يدويًا. بدلاً من ذلك ، استخدم grub2-mkconfigلإنشاء تكوين grub2 الجديد باستخدام مجموعة من ملفات التكوين المختلفة وقائمة النوى المثبتة. و grub2-mkconfigسوف ننظر في الأمر /etc/default/grubلخيارات مثل المهلة القائمة الافتراضية وسطر الأوامر نواة الاستخدام، ثم استخدام مجموعة من النصوص في /etc/grub.d/لتوليد ملف التكوين الناتجة عن ذلك.

هنا رسم تخطيطي لهذه العلاقة.

/boot/grub2/grub.cfg
               |
               |__________________
               |                  |
         /etc/default/grub         /etc/grub.d/*

هام: لتحرير ملف grub.cfg الرئيسي ، ستحتاج إلى إجراء التغييرات المطلوبة /etc/default/grubعلى الملفات وإليها /etc/grub.d/ثم إنشاء ملف جديد grub.cfgعن طريق تشغيل:

# grub2-mkconfig > /boot/grub2/grub.cfg

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

من المهم فهم بناء جملة /boot/grub2/grub.cfgالملف قبل استكشاف الأخطاء وإصلاحها.

  • أولاً ، يتم ترميز الإدخالات القابلة للتمهيد داخل كتل 'menuentry'. في هذه الكتل، linux16و initrd16خطوط تشير إلى نواة ليتم تحميلها من القرص (جنبا إلى جنب مع سطر الأوامر النواة) وinitramfs ليتم تحميلها. أثناء التحرير التفاعلي في التمهيد ، يتم استخدام علامة التبويب للعثور على هذه الخطوط.
  • لا تشير أسطر "تعيين الجذر" داخل تلك الكتل إلى نظام الملفات الجذر لنظام RHEL / CentOS 7 ، بل تشير بدلاً من ذلك إلى نظام الملفات الذي يجب على grub2 تحميل ملفات kernel و initramfs منه. بناء الجملة هو harddrive.partitionمكان hd0القرص الصلب الأول في النظام hd1والثاني. يشار إلى الأقسام msdos1بالنسبة لقسم MBR الأول أو gpt1لقسم GPT الأول.

مثال من /boot/grub2/grub.cfg:

### BEGIN /etc/grub.d/10_linux ###
menuentry 'CentOS Linux (3.10.0-514.26.2.el7.x86_64) 7 (Core)' --class centos --class gnu-linux --class gnu --class os --unrestricted $menuentry_id_option 'gnulinux-3.10.0-514.el7.x86_64-advanced-a2531d12-46f8-4a0f-8a5c-b48d6ef71275' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  123455ae-46f8-4a0f-8a5c-b48d6ef71275
    else
      search --no-floppy --fs-uuid --set=root 123455ae-46f8-4a0f-8a5c-b48d6ef71275
    fi

إذا كنت بحاجة إلى إعادة تثبيت أداة تحميل التشغيل على أحد الأجهزة ، فاستخدم الأمر التالي.

# grub2-install <device>

إصلاح تثبيت اليرقة المكسور

للحالات التي لا يتم فيها تشغيل النظام بعد الوصول إلى قائمة grub2.

  • يجب أن تبدأ بتحرير قائمة grub والبحث عن أخطاء في بناء الجملة. إذا وجدت واحدًا ، فقم بتصحيحه وادخل إلى النظام لإجراء تغييرات مستمرة لإصلاح المشكلة.
  • إذا لم تتمكن من العثور على أي أخطاء ، فراجع القسم أعلاه حيث نقوم بالتمهيد في هدف الطوارئ. ستحتاج إلى إعادة تحميل root ( /) مرة أخرى.
  • عرض تكوين grub2 الحالي باستخدام الأمر التالي: # grub2-mkconfig
  • إذا كنت لا ترى أي أخطاء ، فمن المحتمل أن شخصًا ما قام بتحرير /boot/grub2/grub.cfgالملف. لا تقم بتعديل هذا الملف. إعادة إنشاء التكوين باستخدام الأمر التالي:# grub2-mkconfig > /boot/grub2/grub.cfg

بمجرد إعادة إنشاء تكوين grub ، يجب أن تكون قادرًا على إعادة التشغيل دون مواجهة أي مشاكل.



Leave a Comment

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت CMS أكتوبر على CentOS 7

كيفية تثبيت CMS أكتوبر على CentOS 7

أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة

كيفية تثبيت المجدول المحجوز على CentOS 7

كيفية تثبيت المجدول المحجوز على CentOS 7

استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th

تثبيت Netdata على CentOS 7

تثبيت Netdata على CentOS 7

استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:

كيفية تثبيت DreamFactory Open Source على CentOS 7

كيفية تثبيت DreamFactory Open Source على CentOS 7

DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي

كيفية تثبيت خادم Starbound على CentOS 7

كيفية تثبيت خادم Starbound على CentOS 7

استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Django على CentOS 7

كيفية تثبيت Django على CentOS 7

Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها

تثبيت Revive Adserver على CentOS 7

تثبيت Revive Adserver على CentOS 7

Revive Adserver هو نظام عرض إعلانات مجاني ومفتوح المصدر يمكن استخدامه لإدارة الإعلانات على مواقع الويب و / أو التطبيقات و / أو مشغلات الفيديو. في هذه المقالة ،

قم بتثبيت Elgg على CentOS 7

قم بتثبيت Elgg على CentOS 7

استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po

نشر Kubernetes مع Kubeadm على CentOS 7

نشر Kubernetes مع Kubeadm على CentOS 7

نظرة عامة تهدف هذه المقالة إلى مساعدتك في إنشاء مجموعة Kubernetes وتشغيلها باستخدام kubeadm في لمح البصر. سيقوم هذا الدليل بنشر خادمين في

قم بإعداد Sails.js للتطوير على CentOS 7

قم بإعداد Sails.js للتطوير على CentOS 7

استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver

كيفية تجميع Nginx من المصدر على CentOS 7

كيفية تجميع Nginx من المصدر على CentOS 7

استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت

كيفية تثبيت dotCMS على CentOS 7

كيفية تثبيت dotCMS على CentOS 7

استخدام نظام مختلف؟ dotCMS هو نظام إدارة محتوى من فئة مفتوحة المصدر مفتوح بلغة جافا. أنه يحتوي تقريبا على كل ميزة مطلوبة ر

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد