| CRONTAB(5) | دليل مستخدم crontab | CRONTAB(5) |
الاسم¶
crontab - جداول لتشغيل cron
الوصف¶
ملف crontab يحتوي على تعليمات لخفيض cron(8) بالشكل العام: “شغل هذا الأمر في هذا الوقت في هذا التاريخ”. لكل مستخدم crontab خاص به، وتُنفذ الأوامر في أي crontab معين كمستخدم يملك crontab. عادةً ما يكون لـ Uucp و News crontabs خاصة بهما، مما يلغي الحاجة إلى تشغيل su(1) صراحةً كجزء من أمر cron.
لاحظ أن التعليقات على نفس سطر أوامر cron لا تُفسر كتعليقات بمعنى cron، بل تُعتبر جزءًا من الأمر وتُمرر إلى الصدفة. هذا صحيح بالمثل للتعليقات على نفس سطر إعدادات متغيرات البيئة.
سطر نشط في crontab سيكون إما إعداد بيئة أو أمر cron. إعداد البيئة يكون بالشكل،
name = value
حيث المسافات حول علامة التساوي (=) اختيارية، وأي مسافات غير بادئة لاحقة في value ستكون جزءًا من القيمة المخصصة لـ name. يمكن وضع سلسلة value بين علامتي اقتباس (مفردة أو مزدوجة، لكن متطابقة) للحفاظ على الفراغات البادئة أو التابعة. لتعريف متغير فارغ، يمكن استخدام علامات الاقتباس.
سلسلة value لا تُحلل لاستبدالات بيئية أو استبدال متغيرات أو توسيع علامة التلدة (~)، لذا أسطر مثل
PATH=$HOME/bin:$PATH PATH=~/bin:/usr/bin
لن تعمل كما قد تتوقع. ولن يعمل هذا أيضًا.
A=1 B=2 C=$A $B
لن يكون هناك أي استبدال للمتغيرات المعرفة في القيمة الأخيرة. ومع ذلك، مع معظم الصدف يمكنك أيضًا تجربة مثلًا:
P=PATH=/a/b/c:$PATH 33 22 1 2 3 eval $P && some commands
تُعد عدة متغيرات بيئة آليًا بواسطة خفيض cron(8). يُضبط SHELL على /usr/bin/sh، ويُضبط LOGNAME و HOME من سطر /etc/passwd لمالك crontab. يمكن تجاوز HOME و SHELL بإعدادات في crontab؛ لا يمكن تجاوز LOGNAME.
(ملاحظة أخرى: متغير LOGNAME يُسمى أحيانًا USER على أنظمة BSD... على هذه الأنظمة، سيُضبط USER أيضًا.)
بالإضافة إلى LOGNAME و HOME و SHELL، سينظر cron(8) إلى MAILTO إذا كان لديه أي سبب لإرسال بريد نتيجة تشغيل أوامر في “هذا” crontab. إذا كان MAILTO معرّفًا (وغير فارغ)، يُرسل البريد إلى المستخدم المسمى بذلك. إذا كان MAILTO معرّفًا لكن فارغًا (MAILTO="")، لن يُرسل أي بريد. وإلا يُرسل البريد إلى مالك crontab. هذا الخيار مفيد إذا اخترت /usr/bin/mail بدلاً من /usr/lib/sendmail كمرسل بريدك عند تثبيت cron -- /usr/bin/mail لا يقوم بالاسم المستعار، و UUCP عادةً لا يقرأ بريده.
تنسيق أمر cron مشابه جدًا لمعيار V7، مع عدد من الامتدادات المتوافقة مع الإصدارات الأحدث. كل سطر يحتوي على خمسة حقول للوقت والتاريخ، يتبعها أمر، يتبعها حرف سطر جديد ('\n'). يستخدم crontab النظام (/etc/crontab) نفس التنسيق، باستثناء أن اسم المستخدم للأمر يُحدد بعد حقول الوقت والتاريخ وقبل الأمر. يمكن فصل الحقول بمسافات أو علامات تبويب. الحد الأقصى المسموح به لحقل الأمر هو 998 حرفًا.
تُنفذ الأوامر بواسطة cron(8) عندما تتطابق حقول الدقيقة والساعة وشهر السنة مع الوقت الحالي، وعندما يتطابق حقل واحد على الأقل من حقلي اليوم (يوم الشهر أو يوم الأسبوع) مع الوقت الحالي (انظر “ملاحظة” أدناه). يفحص cron(8) إدخالات cron مرة كل دقيقة. حقول الوقت والتاريخ هي:
| field | القيم المسموح بها |
| minute | 0-59 |
| hour | 0-23 |
| day of month | 1-31 |
| month | 1-12 (أو أسماء، انظر أدناه) |
| day of week | 0-7 (0 or 7 is Sun, or use names) |
قد يكون الحقل علامة نجمية (*)، والتي تعني دائمًا “الأول-الأخير”.
نطاقات الأرقام مسموح بها. النطاقات عبارة عن رقمين مفصولين بواصلة. النطاق المحدد شامل. على سبيل المثال، 8-11 لإدخال “ساعات” يحدد التنفيذ في الساعات 8 و9 و10 و11.
القوائم مسموح بها. القائمة عبارة عن مجموعة من الأرقام (أو النطاقات) مفصولة بفواصل. أمثلة: “1,2,5,9”، “0-4,8-12”.
يمكن استخدام قيم الخطوة بالتزامن مع النطاقات. إتباع نطاق بـ “/<رقم>” يحدد تخطي قيمة الرقم عبر النطاق. على سبيل المثال، يمكن استخدام “0-23/2” في حقل الساعات لتحديد تنفيذ الأمر كل ساعة أخرى (البديل في معيار V7 هو “0,2,4,6,8,10,12,14,16,18,20,22”). الخطوات مسموح بها أيضًا بعد علامة النجمة، لذا إذا أردت قول “كل ساعتين”، استخدم فقط “*/2”.
يمكن استخدام الأسماء أيضًا لحقلي “الشهر” و“يوم الأسبوع”. استخدم الأحرف الثلاثة الأولى من اليوم أو الشهر المحدد (حالة الأحرف غير مهمة). أمثلة للشهر: “يناير-مارس” أو “يناير،مارس” . أمثلة ليوم الأسبوع: “الإثنين-الأربعاء” أو “الإثنين-الأربعاء”. الأسماء باللغة الإنجليزية.
الحقل “السادس” (بقية السطر) يحدد الأمر الذي سيتم تشغيله. جزء الأمر بأكمله من السطر، حتى حرف سطر جديد أو %، سيتم تنفيذه بواسطة /usr/bin/sh أو بواسطة الصدفة المحددة في متغير SHELL لملف cron. علامات النسبة المئوية (%) في الأمر، ما لم يتم تخطيها بشرطة مائلة عكسية (\)، ستتحول إلى أحرف سطر جديد، وكل البيانات بعد أول % سترسل إلى الأمر كمدخل قياسي.
ملاحظة: يمكن تحديد يوم تنفيذ الأمر بواسطة حقلين — يوم الشهر، ويوم الأسبوع. إذا كان كلا الحقلين مقيدين (أي ليسا *)، سيتم تشغيل الأمر عندما يطابق أي حقل الوقت الحالي. على سبيل المثال، “30 4 1,15 * 5” سيؤدي إلى تشغيل الأمر في الساعة 4:30 صباحًا في اليومين 1 و15 من كل شهر، بالإضافة إلى كل يوم جمعة. ومع ذلك، يمكن تحقيق النتيجة المرجوة بإضافة اختبار إلى الأمر (انظر المثال الأخير في مثال ملف cron أدناه).
بدلاً من الحقول الخمسة الأولى، قد يظهر واحد من ثمانية سلاسل خاصة:
| string | المعنى |
| @reboot | تشغيل مرة واحدة، عند بدء التشغيل. |
| @yearly | تشغيل مرة واحدة في السنة، "0 0 1 1 *". |
| @annually | (نفس @yearly) |
| @monthly | تشغيل مرة واحدة في الشهر، "0 0 1 * *". |
| @weekly | تشغيل مرة واحدة في الأسبوع، "0 0 * * 0". |
| @daily | تشغيل مرة واحدة في اليوم، "0 0 * * *". |
| @midnight | (نفس @daily) |
| @hourly | تشغيل مرة واحدة في الساعة، "0 * * * *". |
يرجى ملاحظة أن بدء التشغيل، فيما يتعلق بـ @reboot، هو الوقت الذي يبدأ فيه برنامج الخفي cron(8). على وجه الخصوص، قد يكون قبل بدء تشغيل بعض برامج الخفي للنظام، أو خدمات أخرى. هذا بسبب تسلسل ترتيب الإقلاع للجهاز.
مثال لملف CRON¶
# use /usr/bin/sh to run commands, no matter what /etc/passwd says SHELL=/usr/bin/sh # mail any output to `paul', no matter whose crontab this is MAILTO=paul # # run five minutes after midnight, every day 5 0 * * * $HOME/bin/daily.job >> $HOME/tmp/out 2>&1 # run at 2:15pm on the first of every month -- output mailed to paul 15 14 1 * * $HOME/bin/monthly # run at 10 pm on weekdays, annoy Joe 0 22 * * 1-5 mail -s "It's 10pm" joe%Joe,%%Where are your kids?% 23 0-23/2 * * * echo "run 23 minutes after midn, 2am, 4am ..., everyday" 5 4 * * sun echo "run at 5 after 4 every Sunday" 0 */4 1 * mon echo "run every 4th hour on the 1st and on every Monday" 0 0 */2 * sun echo "run at midn on every Sunday that's an uneven date" # Run on every second Saturday of the month 0 4 8-14 * * test $(date +\%u) -eq 6 && echo "2nd Saturday" # Same thing, efficient too: 0 4 * * * Sat d=$(date +e) && test $d -ge 8 -a $d -le 14 && echo "2nd Saturday" #Execute early the next morning following the first #Thursday of each month 57 2 * * 5 case $(date +d) in 0[2-8]) echo "After 1st Thursday"; esac
جميع الأمثلة أعلاه تشغل برامج غير تفاعلية. إذا كنت ترغب في تشغيل برنامج يتفاعل مع سطح مكتب المستخدم، يجب عليك التأكد من تعيين متغير البيئة المناسب DISPLAY.
# Execute a program and run a notification every day at 10:00 am 0 10 * * * $HOME/bin/program | DISPLAY=:0 notify-send "Program run" "$(cat)"
مثال لملف cron النظامي¶
ما يلي يسرد محتوى ملف crontab نظامي عادي. على عكس crontab الخاص بالمستخدم، يحتوي هذا الملف على حقل اسم المستخدم، كما هو مستخدم بواسطة /etc/crontab.
# /etc/crontab: system-wide crontab # Unlike any other crontab you don't have to run the `crontab' # command to install the new version when you edit this file # and files in /etc/cron.d. These files also have username fields, # that none of the other crontabs do. SHELL=/bin/sh PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin # Example of job definition: # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .------- month (1 - 12) OR jan,feb,mar,apr ... # | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat # m h dom mon dow usercommand 17 * * * * root cd / && run-parts --report /etc/cron.hourly 25 6 * * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily ) 47 6 * * 7 root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly ) 52 6 1 * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly ) #
لاحظ أن جميع المهام النظامية ستشغل، بشكل مبدئي، من الساعة 6 صباحًا إلى 7 صباحًا. في حالة الأنظمة التي لا تعمل بالطاقة خلال تلك الفترة الزمنية، سيتم تنفيذ المهام الساعية فقط ما لم يتم تغيير الإعدادات المبدئية أعلاه.
مثال آخر¶
في ذلك المثال، يمكن رؤية أن الأرقام يمكن أن تُسبق ببعض الأصفار، بهدف محاذاة الأعمدة.
17 * * * * root cd / && run-parts --report /etc/cron.hourly 25 16 * * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily ) 47 06 * * 7 root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly ) 52 06 1 * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly )
انظر أيضًا¶
الامتدادات¶
عند تحديد يوم الأسبوع، يُعتبر كل من اليوم 0 واليوم 7 يوم الأحد. يبدو أن BSD و AT&T يختلفان حول هذا.
يُسمح للقوائم والنطاقات بالتعايش في نفس الحقل. "1-3,7-9" سيُرفض بواسطة AT&T أو BSD cron -- فهما يريدان رؤية "1-3" أو "7,8,9" فقط.
يمكن أن تتضمن النطاقات "خطوات"، لذا "1-9/2" هو نفسه "1,3,5,7,9".
يمكن تحديد أسماء الأشهر أو أيام الأسبوع بالاسم.
يمكن تعيين متغيرات البيئة في crontab. في BSD أو AT&T، البيئة المُسلّمة للعمليات الفرعية هي أساسًا تلك من /etc/rc.
يُرسل مخرجات الأمر بالبريد إلى مالك crontab (لا يمكن لـ BSD فعل هذا)، يمكن إرسالها بالبريد إلى شخص غير مالك crontab (لا يمكن لـ SysV فعل هذا)، أو يمكن إيقاف تشغيل الميزة ولن يُرسل أي بريد على الإطلاق (لا يمكن لـ SysV فعل هذا أيضًا).
جميع أوامر “@” التي يمكن أن تظهر بدلاً من الحقول الخمسة الأولى هي امتدادات.
القيود¶
يعمل البرنامج الخفي cron بمنطقة زمنية محددة. لا يدعم حاليًا مناطق زمنية لكل مستخدم. جميع المهام: مهام النظام ومهام المستخدم ستُشغّل بناءً على المنطقة الزمنية المُهيأة. حتى إذا حدد مستخدم متغير البيئة TZ في crontab الخاص به، سيؤثر هذا فقط على الأوامر المنفذة في crontab، وليس على تنفيذ مهام crontab نفسها. إذا أراد شخص تحديد منطقة زمنية معينة لمهام crontab، يمكنه التحقق من التاريخ في السكريبت الفرعي، على سبيل المثال:
# m h dom mon dow command TZ=UTC 0 * * * * [ "$(date +\%R)" = 00:00 ] && run_some_script
يحدد POSIX أن حقلي يوم الشهر ويوم الأسبوع كلاهما يحتاجان لمطابقة الوقت الحالي إذا كان أي منهما هو *. ومع ذلك، يتحقق هذا التنفيذ فقط مما إذا كان الحرف الأول هو *. لهذا السبب يعمل "0 0 */2 * sun" كل يوم أحد يكون تاريخًا فرديًا بينما معيار POSIX سيجعله يعمل كل يوم أحد وفي كل تاريخ فردي.
لا يجعل بناء جملة crontab من الممكن تعريف جميع الفترات الممكنة التي يمكن تخيلها. على سبيل المثال، ليس من السهل تعريف آخر يوم عمل في الشهر. لتشغيل مهمة في فترة زمنية لا يمكن تعريفها باستخدام بناء جملة crontab، أفضل نهج هو جعل البرنامج نفسه يتحقق من معلومات التاريخ والوقت ويواصل التنفيذ فقط إذا تطابقت الفترة مع الفترة المطلوبة.
إذا لم يتمكن البرنامج نفسه من إجراء التحققات، فسيكون سكريبت غلاف مطلوبًا. الأدوات المفيدة التي يمكن استخدامها لتحليل التاريخ هي ncal(1) أو calendar(1). على سبيل المثال، لتشغيل برنامج في آخر سبت من كل شهر، يمكنك استخدام كود الغلاف التالي:
0 4 * * Sat [ "$(date +\%e)" = "$(LANG=C ncal | sed -n 's/^Sa .* \([0-9]\+\) *$/\1/p')" ] && echo "Last Saturday" && program_to_run
الطول الأقصى المسموح به لحقل الأمر هو 998 محرفاً.
الطول الموصى به يجب أن يكون أقل من 80 محرفاً، مثل السطور في ملفات المصدر المقروءة. عندما يضطر المرء لاستخدام أمر طويل، فمن الجدير إنشاء سكريبت مخصص، والذي بدوره يمكن أن يحتوي على تعليقات قيّمة.
استخدام EVAL لتغليف إعدادات البيئة المتنوعة¶
النصيحة التالية مقدمة بلطف من 積丹尼 Dan Jacobson:
CONTENT_TYPE="text/plain; charset=UTF-8" d=eval LANG=zh_TW.UTF-8 w3m -dump 26 22 16 1-12 * $d https://www.ptt.cc/bbs/transgender/index.html
لن يعمل بدون eval. قول
d=LANG=zh_TW.UTF-8 w3m -dump
سيحصل على
/bin/sh: LANG=zh_TW.UTF-8: command not found
التشخيص¶
يتطلب cron أن ينتهي كل إدخال في crontab بحرف سطر جديد. إذا كان الإدخال الأخير في crontab يفتقد سطرًا جديدًا (أي يُنهى بـ EOF)، فسيعتبر cron أن crontab معطل (جزئيًا على الأقل). سيُكتب تحذير إلى syslog.
المؤلفون¶
بول فيكسي <paul@vix.com>
ستيف غرينلاند <stevegr@debian.org>
خافيير فيرنانديز سانغينو بينيا <jfs@debian.org>
كريستيان كاستنر <ckk@debian.org>
جورج خزندار <georgesk@debian.org>
حقوق النسخ¶
حقوق
النشر © 1994
بول فيكسي
وزع البرنامج بحرية، باستثناء: لا تحذف اسمي من المصدر أو التوثيق (لا تنسب عملي إليك)، حدد تغييراتك (لكي لا أُلام على عللك المحتملة)، لا تغير أو تحذف هذا التنويه. يمكن بيعه إذا قُدم المصدر القابل للبناء للمشتري. لا يتضمن هذا البرنامج أي ضمان من أي نوع، صريحًا كان أو ضمنيًا؛ استخدمه على مسؤوليتك الخاصة، وتقع مسؤولية الأضرار (إن وجدت) التي تلحق بأي شخص نتيجة استخدام هذا البرنامج بالكامل على المستخدم.
منذ عام 1994، أُجريت العديد من التعديلات على صفحة الدليل هذه، صاغها مطورو دبيان الذين صانوا cron(TM)؛ أعلاه قائمة قصيرة، ويمكن العثور على مزيد من المعلومات في ملف /usr/share/doc/cron/copyright.
ترجمة¶
تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>
هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.
إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.
| 27 أبريل 2026 | crontab |