كيفية تثبيت Matomo Analytics على Fedora 28
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
Tiny Tiny RSS Reader هو قارئ ومجمّع أخبار مستوحى ذاتيًا ومفتوح المصدر ومُستضاف ذاتيًا على الويب (RSS / Atom) ، مصمم ليتيح لك قراءة الأخبار من أي مكان ، مع الشعور بأقرب ما يكون من تطبيق سطح مكتب حقيقي. يدعم Tiny Tiny RSS Reader تجميع الخلاصة ومشاركتها ، استيراد وتصدير OPML ، المشاركة الاجتماعية ، التدويل ، الكشف عن المقالات المكررة ، تصفية المقالات المرنة ، الإضافات والموضوعات ، واجهة برمجة تطبيقات JSON ، والمزيد!
في هذا البرنامج التعليمي ، سنقوم بتثبيت Tiny Tiny RSS Reader 17.4 على Fedora 26 LAMP VPS باستخدام خادم الويب Apache و PHP 7.1 وقاعدة بيانات MariaDB.
سنبدأ بإضافة sudo
مستخدم جديد .
أولاً ، قم بتسجيل الدخول إلى الخادم الخاص بك على النحو التالي root
:
ssh root@YOUR_VULTR_IP_ADDRESS
أضف مستخدمًا جديدًا يسمى user1
(أو اسم المستخدم المفضل لديك):
useradd user1
بعد ذلك ، قم بتعيين كلمة المرور user1
للمستخدم:
passwd user1
عند المطالبة ، أدخل كلمة مرور آمنة ولا تنسى.
تحقق الآن من /etc/sudoers
الملف للتأكد من sudoers
تمكين المجموعة:
visudo
ابحث عن قسم مثل هذا:
%wheel ALL=(ALL) ALL
وتأكد من أنه غير منقطع. يخبرنا هذا السطر أن المستخدمين الذين هم أعضاء في wheel
المجموعة يمكنهم استخدام sudo
الأمر للحصول على root
الامتيازات.
بمجرد تحرير الملف ، يمكنك الحفظ والخروج بالضغط Esc
ثم الدخول :wq
إلى "كتابة" و "إنهاء" الملف.
بعد ذلك نحتاج إلى إضافة user1
إلى wheel
المجموعة:
usermod -aG wheel user1
يمكننا التحقق من user1
عضوية المجموعة والتحقق من أن usermod
الأمر يعمل مع groups
الأمر:
groups user1
الآن استخدم su
الأمر للتبديل إلى user1
حساب مستخدم sudo الجديد :
su - user1
سيتم تحديث موجه الأوامر للإشارة إلى أنك قمت بتسجيل الدخول الآن إلى user1
الحساب. يمكنك التحقق من ذلك باستخدام whoami
الأمر:
whoami
الآن ، أعد تشغيل sshd
الخدمة بحيث يمكنك تسجيل الدخول عبر ssh
حساب مستخدم sudo الجديد غير الجذر الذي أنشأته للتو:
sudo systemctl restart sshd
الخروج من user1
الحساب:
exit
اخرج من root
الحساب (الذي سيؤدي إلى قطع جلستك ssh
).
exit
يمكنك الآن ssh
الدخول إلى مثيل الخادم من مضيفك المحلي باستخدام user1
حساب مستخدم sudo الجديد غير الجذر :
ssh user1@YOUR_VULTR_IP_ADDRESS
إذا كنت تريد تنفيذ sudo دون الحاجة إلى كتابة كلمة مرور في كل مرة ، فافتح /etc/sudoers
الملف مرة أخرى باستخدام visudo
:
sudo visudo
قم بتحرير قسم wheel
المجموعة بحيث يبدو كالتالي:
%wheel ALL=(ALL) NOPASSWD: ALL
يرجى ملاحظة ما يلي: تعطيل متطلبات كلمة المرور لمستخدم sudo ليس ممارسة موصى بها ، ولكن يتم تضمينه هنا لأنه يمكن أن يجعل تكوين الخادم أكثر ملاءمة وأقل إحباطًا ، خاصة خلال جلسات إدارة الأنظمة الأطول. إذا كنت قلقًا بشأن الآثار الأمنية ، فيمكنك دائمًا إعادة تغيير التكوين إلى الإعداد الأصلي بعد الانتهاء من مهام الإدارة.
عندما تريد تسجيل الدخول إلى root
حساب المستخدم من داخل sudo
حساب المستخدم ، يمكنك استخدام أحد الأوامر التالية:
sudo -i
sudo su -
يمكنك الخروج من root
الحساب والعودة إلى sudo
حساب المستخدم الخاص بك في أي وقت ببساطة عن طريق كتابة:
exit
قبل تثبيت أي حزم على مثيل خادم Fedora ، سنقوم أولاً بتحديث النظام.
تأكد من تسجيل دخولك إلى الخادم باستخدام مستخدم sudo غير الجذر وتشغيل الأمر التالي:
sudo dnf -y update
قم بتثبيت خادم الويب Apache:
sudo dnf -y install httpd
ثم استخدم systemctl
الأمر لبدء وتمكين Apache من التنفيذ تلقائيًا في وقت التمهيد.
sudo systemctl enable httpd
sudo systemctl start httpd
تحقق من ملف تكوين Apache للتأكد من أن DocumentRoot
التوجيه يشير إلى الدليل الصحيح.
sudo vi /etc/httpd/conf/httpd.conf
و DocumentRoot
خيار التكوين ينبغي أن تبدو هذه:
DocumentRoot "/var/www/html"
الآن ، لنتأكد من mod_rewrite
تحميل وحدة Apache. يمكننا القيام بذلك عن طريق البحث في ملف تكوين وحدات Apache الأساسية للمصطلح " mod_rewrite
".
افتح الملف:
sudo vi /etc/httpd/conf.modules.d/00-base.conf
ابحث عن المصطلح mod_rewrite
.
إذا mod_rewrite
تم تحميل وحدة Apache ، فيجب أن تجد خط تكوين يبدو كالتالي:
LoadModule rewrite_module modules/mod_rewrite.so
إذا بدأ السطر أعلاه بفاصلة منقوطة ، فستحتاج إلى إزالة الفاصلة المنقوطة لإلغاء تعليق الخط وتحميل الوحدة. ينطبق هذا بالطبع على أي وحدات أباتشي أخرى مطلوبة أيضًا.
نحتاج الآن إلى تحرير ملف التكوين الافتراضي الخاص بـ Apache حتى mod_rewrite
يعمل بشكل صحيح مع Tiny Tiny RSS.
افتح الملف:
sudo vi /etc/httpd/conf/httpd.conf
ثم ابحث عن القسم الذي يبدأ بـ <Directory "/var/www/html">
والتغيير AllowOverride none
إليه AllowOverride All
. يجب أن تبدو النتيجة النهائية (مع إزالة جميع التعليقات) كما يلي:
<Directory "/var/www/html">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
الآن احفظ وأغلق ملف تكوين Apache.
سنعيد تشغيل Apache في نهاية هذا البرنامج التعليمي ، ولكن إعادة تشغيل Apache بانتظام أثناء التثبيت والتكوين هي بالتأكيد عادة جيدة ، لذلك دعونا نفعل ذلك الآن.
sudo systemctl restart httpd
ونحن الآن بحاجة إلى فتح الافتراضي HTTP
و HTTPS
الموانئ حيث سيتم حظره من قبل firewalld
افتراضيا.
افتح منافذ جدار الحماية:
sudo firewall-cmd --permanent --add-port=80/tcp
sudo firewall-cmd --permanent --add-port=443/tcp
أعد تحميل جدار الحماية لتطبيق التغييرات.
sudo firewall-cmd --reload
سترى الكلمة success
معروضة في جهازك الطرفي بعد كل أمر تكوين ناجح لجدار الحماية.
يمكننا التحقق بسرعة من أن HTTP
منفذ Apache مفتوح من خلال زيارة عنوان IP أو مجال مثيل الخادم في المستعرض:
http://YOUR_VULTR_IP_ADDRESS/
إذا تم إعداد كل شيء بشكل صحيح ، فسترى صفحة ويب Apache الافتراضية في المستعرض الخاص بك.
SELinux تعني "لينكس المحسن بالأمان". إنه تحسين أمني لنظام Linux يسمح للمستخدمين والمسؤولين بمزيد من التحكم في التحكم في الوصول. يتم تمكينه افتراضيًا في Fedora 26 ، ولكنه بالتأكيد ليس ضروريًا لأمان الخادم لأن العديد من توزيعات خادم Linux لا يتم شحنها مع تثبيته أو تمكينه افتراضيًا.
لتجنب مشاكل إذن الملف مع Tiny Tiny RSS لاحقًا ، سنقوم بتعطيل SELinux في الوقت الحالي. لذا افتح ملف تكوين SELinux باستخدام محرر المحطة الطرفية المفضل لديك:
sudo vi /etc/selinux/config
غيّر SELINUX=enforcing
إلى SELINUX=disabled
، ثم احفظ الملف.
لتطبيق تغيير التكوين ، يتطلب SELinux إعادة تشغيل الخادم ، بحيث يمكنك إما إعادة تشغيل الخادم باستخدام لوحة تحكم Vultr أو يمكنك ببساطة استخدام shutdown
الأمر لإيقاف تشغيل الخادم وإعادة تشغيله بشكل نظيف:
sudo shutdown -r now
عند إعادة تشغيل الخادم ، سيتم قطع اتصال جلسة SSH الخاصة بك وقد ترى رسالة تخبرك عن 'broken pipe'
أو تخبرك 'Connection closed by remote host'
. لا داعي للقلق ، فما عليك سوى الانتظار لمدة 20 ثانية أو نحو ذلك ، ثم إعادة SSH مرة أخرى (باستخدام اسم المستخدم والمجال):
ssh user1@YOUR_DOMAIN
أو (باستخدام اسم المستخدم وعنوان IP الخاص بك):
ssh user1@YOUR_VULTR_IP_ADDRESS
بمجرد تسجيل الدخول مرة أخرى ، يجب عليك التحقق من حالة SELinux باستخدام sestatus
الأمر للتأكد من أنه تم تعطيله بشكل صحيح:
sudo sestatus
سترى رسالة تقول SELinux status: disabled
. إذا رأيت رسالة تقول SELinux status: enabled
(أو شيء مشابه) ، فستحتاج إلى تكرار الخطوات المذكورة أعلاه والتأكد من إعادة تشغيل الخادم بشكل صحيح.
يمكننا الآن تثبيت PHP 7.1 مع جميع وحدات PHP اللازمة التي تتطلبها Tiny Tiny RSS.
sudo dnf -y install php php-mysqlnd php-mbstring php-gd php-common php-pdo php-pecl-imagick php-xml php-zip
افتراضيات Fedora 26 هي استخدام خادم قاعدة بيانات MariaDB ، وهو مصدر محسن ومفتوح المصدر بالكامل ، تم تطويره من قبل المجتمع ، واستبدال بديل لخادم MySQL.
تثبيت خادم قاعدة بيانات MariaDB:
sudo dnf -y install mariadb-server
ابدأ وتمكين خادم MariaDB من التنفيذ تلقائيًا في وقت التمهيد.
sudo systemctl enable mariadb
sudo systemctl start mariadb
تأمين تثبيت خادم MariaDB الخاص بك:
sudo mysql_secure_installation
و root
سوف تكون فارغة كلمة المرور، وذلك ببساطة تصل إلى تدخل عند المطالبة للحصول على root
كلمة المرور.
عندما يُطلب منك إنشاء root
مستخدم MariaDB / MySQL ، حدد "ص" (نعم) ثم أدخل root
كلمة مرور آمنة . ما عليك سوى الإجابة بـ "Y" على جميع الأسئلة الأخرى بنعم / لا لأن الاقتراحات الافتراضية هي الخيارات الأكثر أمانًا.
قم بتسجيل الدخول إلى shell MariaDB root
كمستخدم MariaDB عن طريق تشغيل الأمر التالي.
sudo mysql -u root -p
للوصول إلى موجه أوامر MariaDB ، ما عليك سوى إدخال root
كلمة مرور MariaDB عند مطالبتك بذلك.
قم بتشغيل الاستعلامات التالية لإنشاء قاعدة بيانات ومستخدم قاعدة بيانات MariaDB لـ Tiny Tiny RSS.
CREATE DATABASE tiny_db CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'tiny_user'@'localhost' IDENTIFIED BY 'UltraSecurePassword';
GRANT ALL PRIVILEGES ON tiny_db.* TO 'tiny_user'@'localhost';
FLUSH PRIVILEGES;
EXIT;
يمكنك استبدال اسم قاعدة البيانات واسم tiny_db
المستخدم tiny_user
بشيء أكثر ترضيك ، إذا كنت تفضل ذلك. تأكد أيضًا من استبدال "UltraSecurePassword" بكلمة مرور آمنة بالفعل.
قم بتغيير دليل العمل الحالي إلى دليل الويب الافتراضي.
cd /var/www/html/
إذا تلقيت رسالة خطأ تقول شيئًا مثل ، 'No such file or directory'
فجرّب الأمر التالي:
cd /var/www/ ; sudo mkdir html ; cd html
ودليل العمل الحالي الخاص بك سيكون الآن: /var/www/html/
. يمكنك التحقق من ذلك باستخدام الأمر pwd
(طباعة دليل العمل):
pwd
استخدم الآن wget
لتنزيل حزمة تثبيت Tiny Tiny RSS.
sudo wget --content-disposition https://git.tt-rss.org/git/tt-rss/archive/17.4.zip
يرجى ملاحظة ما يلي: كان عنوان URL الخاص بحزمة Tiny Tiny RSS أعلاه صحيحًا وقت كتابة هذا التقرير ، ولكن يجب عليك بالتأكيد التحقق من أحدث إصدار من خلال زيارة صفحة تنزيل Tiny Tiny RSS .
قم بسرد الدليل الحالي للتحقق من أنك قمت بتنزيل الملف بنجاح.
ls -la
دعنا نثبت بسرعة unzip
حتى نتمكن من فك ضغط الملف.
sudo dnf -y install unzip
الآن قم بفك ضغط الملف المضغوط.
sudo unzip tt-rss-17.4.zip
انقل جميع ملفات التثبيت إلى دليل جذر الويب:
sudo mv -v tt-rss/* tt-rss/.* /var/www/html 2>/dev/null
تغيير ملكية ملفات الويب لتجنب أي مشاكل في الأذونات.
sudo chown -R apache:apache * ./
أعد تشغيل Apache مرة أخرى.
sudo systemctl restart httpd
الآن نحن على استعداد للانتقال إلى الخطوة النهائية.
حان الوقت الآن لزيارة عنوان IP لمثيل الخادم الخاص بك في متصفحك ، أو إذا قمت بالفعل بتكوين إعدادات Vultr DNS الخاصة بك (ومنحت الوقت الكافي للنشر) يمكنك ببساطة زيارة نطاقك بدلاً من ذلك.
للوصول إلى صفحة تثبيت Tiny Tiny RSS ، أدخل عنوان IP لمثيل Vultr في شريط عنوان المتصفح ، متبوعًا بـ /install/
:
http://YOUR_VULTR_IP_ADDRESS/install/
في Database Settings
قسم Tiny Tiny RSS Installer
الصفحة ، أدخل قيم قاعدة البيانات التالية:
Database type: MySQL
Username: u1
Password: usecpass1
Database name: db1
Host name: localhost
Port: 3306
و Tiny Tiny RSS URL
ينبغي أن تملأ الحقل في مع URL الخاص بك تلقائيا حتى تتمكن من ترك الأمر مع القيمة الافتراضية (التي ستكون عنوان IP الخاص بك إذا كنت لم تقم بإعداد DNS الخاص بك حتى الآن). إذا قررت فيما بعد إعداد Vultr DNS الخاص بك ، فستتمكن من تعديل هذه القيمة في إعدادات تكوين Tiny Tiny RSS.
عندما تملأ التفاصيل الصحيحة ، ما Test Configuration
عليك سوى النقر للمتابعة.
إذا سار كل شيء بسلاسة سترى رسالتين تقول Configuration check succeeded
و Database test succeeded
. ببساطة انقر على Initialize Databse
الزر للمتابعة.
سيقوم المثبت بإنشاء ملف تكوين لك باستخدام القيم التي أدخلتها بالفعل. انقر فوق Save Configuration
لحفظ الملف تلقائيًا.
سترى رسالة تقول Successfully saved config.php
.
يمكنك الآن الوصول إلى قسم المسؤول عن طريق النقر على loading tt-rss now
الرابط وإدخال اسم المستخدم وكلمة المرور الافتراضيين الموضحين أدناه:
Login: admin
Password: password
إذا لم تتم إعادة توجيهك إلى صفحة تسجيل دخول المسؤول ، فيمكنك إدخال عنوان المسؤول يدويًا:
http://YOUR_VULTR_IP_ADDRESS/
بمجرد تسجيل الدخول ، أول شيء يجب عليك فعله هو تغيير كلمة مرور المسؤول من الإعداد الافتراضي إلى شيء أكثر أمانًا ، لذلك انقر فوق Actions...
في الزاوية العلوية اليمنى من الصفحة وحدد Preferences...
.
الآن انقر على Users
علامة التبويب ثم انقر على admin
المستخدم. سيظهر User editor
مربع حوار منبثق ، لذا أدخل كلمة المرور الجديدة في Change Password
الحقل وانقر عليهاSave
إذا لم تقم بتكوين إعدادات Vultr DNS الخاصة بك حتى الآن ، فيمكنك القيام بذلك باستخدام لوحة تحكم Vultr DNS.
يُنصح أيضًا بتكوين موقعك لاستخدام طبقة المقابس الآمنة لأن معظم المتصفحات الحديثة ستقدم تحذيرات عندما لا يتم تمكين طبقة المقابس الآمنة في المواقع وتكون شهادات طبقة المقابس الآمنة متاحة الآن مجانًا.
على أي حال ، أنت حر الآن لبدء استكشاف العديد من إعدادات التكوين لـ Tiny Tiny RSS ويمكنك تكوينه وفقًا لتفضيلاتك الشخصية. تأكد من مراجعة موقع Tiny Tiny RSS wiki لمزيد من المعلومات حول كيفية تكوين القارئ وتحسينه.
آمل أن تكون قد استمتعت بهذا البرنامج التعليمي ، وآمل أن تستمتع بالاستضافة الذاتية لمجمّع موجز RSS المخصص الخاص بك مع Tiny Tiny RSS Reader!
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
استخدام نظام مختلف؟ Omeka Classic 2.4 CMS هو نظام نشر رقمي مجاني ومفتوح المصدر ونظام إدارة المحتوى (CMS) لمشاركة الصور الرقمية
استخدام نظام مختلف؟ Ghost هي منصة تدوين مفتوحة المصدر اكتسبت شعبية بين المطورين والمستخدمين العاديين منذ عام 201
استخدام نظام مختلف؟ NodeBB هو منتدى قائم على Node.js. يستخدم مقابس الويب للتفاعل الفوري والإشعارات في الوقت الحقيقي. كود مصدر NodeBB i
استخدام نظام مختلف؟ WonderCMS هو ملف CMS مفتوح المصدر وسريع وصغير مكتوب بلغة PHP. يتم استضافة كود مصدر WonderCMS على جيثب. فيل هذا الدليل
Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب
استخدام نظام مختلف؟ Directus 6.4 CMS هو نظام إدارة محتوى بلا محتوى قوي ومرن ومفتوح المصدر ومفتوح المصدر يوفر للمطورين
استخدام نظام مختلف؟ Lychee 3.1 Photo Album هو أداة إدارة صور بسيطة ومرنة ومجانية ومفتوحة المصدر تعمل على خادم VPS. يتم تثبيته
استخدام نظام مختلف؟ Fork هو CMS مفتوح المصدر مكتوب بلغة PHP. رمز مصدر فوركس مستضاف على جيثب. سيوضح لك هذا الدليل كيفية تثبيت Fork CM
استخدام نظام مختلف؟ RainLoop هو عميل بريد إلكتروني بسيط وحديث وسريع يعتمد على الويب. يتم استضافة كود مصدر RainLoop على جيثب. هذا الدليل سوف يظهر لك حو
استخدام نظام مختلف؟ PyroCMS هو CMS مفتوح المصدر مكتوب بلغة PHP. يتم استضافة شفرة مصدر PyroCMS على GitHub. في هذا الدليل تمشي جيدًا عبر الكل
استخدام نظام مختلف؟ مقدمة TaskBoard هي أداة مجانية ومفتوحة المصدر يمكن استخدامها لتتبع الأشياء التي تحتاج إلى إنجازها. أنه يوفر
استخدام نظام مختلف؟ TextPattern CMS 4.6.2 هو نظام إدارة محتوى بسيط ومرن ومجاني ومفتوح المصدر (CMS) يتيح لمصممي الويب
استخدام نظام مختلف؟ BookStack عبارة عن منصة بسيطة ذاتية الاستضافة لتنظيم المعلومات وتخزينها. BookStack مجاني تمامًا ومفتوح المصدر ، أ
استخدام نظام مختلف؟ Gitea هو نظام بديل مفتوح المصدر للتحكم في الإصدار يعمل بواسطة Git. Gitea هو مكتوب في Golang وهو
استخدام نظام مختلف؟ Couch CMS هو نظام إدارة محتوى (CMS) بسيط ومرن ومجاني ومفتوح يسمح لمصممي الويب بتصميم
استخدام نظام مختلف؟ MyBB هو برنامج منتدى مجاني ومفتوح المصدر وبديهي وقابل للتوسيع. يتم استضافة رمز مصدر MyBB على GitHub. هذا الدليل سوف يظهر
استخدام نظام مختلف؟ Microweber هو سحب مفتوح المصدر وإفلات CMS ومتجر عبر الإنترنت. يتم استضافة شفرة مصدر Microweber على GitHub. هذا الدليل سيظهر لك
استخدام نظام مختلف؟ Osclass هو مشروع مفتوح المصدر يسمح لك بإنشاء موقع مصنف بسهولة دون أي معرفة تقنية. مصدره
استخدام نظام مختلف؟ سيقوم HTMLDoc بتحليل مستندات Postcript (PDF 1.6) ديناميكيًا من النص التشعبي المكتوب بشكل صحيح (HTML 3.2). هذا سيسمح لك ر
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد