بسم الله الرحمن الرحيم
السلام عليكم ورحمة الله وبركاته
عند محاولة اصلاح قاعدة او تنفيذ عملية Myismcheck من خلال سطر الأوامر يتطلب منا أن نقوم بإيقاف خادم MySQL عن العمل حتى نستطيع تنفيذ مانريد في القواعد. ولكن هذا الأمر يعتبر شيء مزعج خصوصاً اذا كان الخادم مخصص لإستضافة المواقع بالتالي سوف تتوقف جميع قواعد البيانات الخاصة بالعملاء من اجل قاعدة واحد فقط!. لهذا في بعض الأحيان نستخدم مثلاً PHPMyAdmin وغيرها من الأدوات. في هذه الدرس سوف استعرض طريقة تنفيذ العمليات هذه من خلال اداة mysqlcheck والتي تغنينا عن ايقاف الخادم والتعقيدات الاخرى, وهي اداة سهلة الإستخدام جداً.
متطلبات البدء في العمل
1-قاعدة بيانات مركبة وتعمل
2-صلاحيات root
3-تسجيل دخول إلى ssh, terminal
الأن لنفرض أن لدينا قاعدة بيانات بالأسم EGY2SERVER_mydb علماً أن EGY2SERVER هو المستخدم و mydb هو أسم القاعدة.
ونريد أن نقوم بعمل MyISMCheck يكون الامر
أو
دعونا نحلل الأمر السابق
1. mysqlcheck = هذه اسم الأداة, وهنا اخبرت النظام أني أريد استخدام هذه الأداة
2. -c = وهنا اخبرت الأداة أني أريد استخدام خاصية MyISMCheck
3. EGY2SERVER_mydb = هنا اخبرت الأداة أني أريد تنفيذ عملية MyISMCheck للقاعدة هذه.
أصلاح Repair للقاعدة. نقوم بتنفيذ الأمر التالي
تحسين optimize للقاعدة. سوف يكون الامر بالشكل التالي
تحليل analyze يتم بالشكل التالي
وفي حالة كنا نريد أن نقوم بجميع ماسبق مرة واحدة يكون الأمر كتالي
واذا كنت تريد عملها جميعاً ولجميع القواعد مرة واحدة. يكون الامر بهذا الشكل
ماذا عن جدول معين بداخل قاعدة معينة ؟ نحتاجها بعض الاحيان خصوصاً في القواعد الكبيرة والتي تتجاوز 2 جيجابايت. فليس من المعقول وعلى سبيل المثال أن نقوم بعمل اصلاح لقاعدة كاملة تتجاوز 2 جيجابايت من اجل جدول واحد قد لايتجاوز حجمة 50 ميجابايت. أذن نستخدم الطريقة التالية
لنفرض أن الجدول المعني هو EGY أذن
طيب نقطة أخرى. وهي أنو نحتاج نسوي اصلاح أو تحسين لقاعدتين بدل من أن نقوم بعمل ذالك على شكل فردي. نستخدم الطريقة التالية
في بعض الأحيان النظام لايتعرف على الأداة في حالة كتابة اسمها فقط دون كتابة المسار الكامل. في هذه الحالة يكون أمر تشغيل الأداة كتالي
ملاحظة: في حالة قمت بتشغيل الأداة بدون وضع اي خيارات, اي قمت بوضع اسم القاعدة مباشرة وقمت بتنفيذ الامر. في هذه الحالة سوف يكون الخيار الأفتراضي للأداة هو MyISMCheck
السلام عليكم ورحمة الله وبركاته
عند محاولة اصلاح قاعدة او تنفيذ عملية Myismcheck من خلال سطر الأوامر يتطلب منا أن نقوم بإيقاف خادم MySQL عن العمل حتى نستطيع تنفيذ مانريد في القواعد. ولكن هذا الأمر يعتبر شيء مزعج خصوصاً اذا كان الخادم مخصص لإستضافة المواقع بالتالي سوف تتوقف جميع قواعد البيانات الخاصة بالعملاء من اجل قاعدة واحد فقط!. لهذا في بعض الأحيان نستخدم مثلاً PHPMyAdmin وغيرها من الأدوات. في هذه الدرس سوف استعرض طريقة تنفيذ العمليات هذه من خلال اداة mysqlcheck والتي تغنينا عن ايقاف الخادم والتعقيدات الاخرى, وهي اداة سهلة الإستخدام جداً.
متطلبات البدء في العمل
1-قاعدة بيانات مركبة وتعمل
2-صلاحيات root
3-تسجيل دخول إلى ssh, terminal
الأن لنفرض أن لدينا قاعدة بيانات بالأسم EGY2SERVER_mydb علماً أن EGY2SERVER هو المستخدم و mydb هو أسم القاعدة.
ونريد أن نقوم بعمل MyISMCheck يكون الامر
PHP:
mysqlcheck EGY2SERVER_mydb
PHP:
mysqlcheck -c EGY2SERVER_mydb
1. mysqlcheck = هذه اسم الأداة, وهنا اخبرت النظام أني أريد استخدام هذه الأداة
2. -c = وهنا اخبرت الأداة أني أريد استخدام خاصية MyISMCheck
3. EGY2SERVER_mydb = هنا اخبرت الأداة أني أريد تنفيذ عملية MyISMCheck للقاعدة هذه.
أصلاح Repair للقاعدة. نقوم بتنفيذ الأمر التالي
PHP:
mysqlcheck -r EGY2SERVER_mydb
PHP:
mysqlcheck -o EGY2SERVER_mydb
PHP:
mysqlcheck -a EGY2SERVER_mydb
PHP:
mysqlcheck -aro EGY2SERVER_mydb
PHP:
mysqlcheck -aro --all-databases
لنفرض أن الجدول المعني هو EGY أذن
PHP:
mysqlcheck -r EGY2SERVER_mydb EGY
PHP:
mysqlcheck -r --databases EGY2SERVER_mydb1 EGY2SERVER_mydb2
PHP:
/usr/bin/mysqlcheck [-OPTIONS] [DATABASE]