Bash Parallel Jobs Using For Loop

Bash Parallel Jobs Using For Loop



קיימות דרכים רבות בלינוקס להפעלת מספר פקודות או סקריפטים של Bash במקביל. אחת הדרכים היא להשתמש בלולאה 'for' בסקריפט Bash כדי להפעיל עבודה מקבילה. לולאה זו שימושית מאוד להפעלת המשימות המקבילות באמצעות הפקודה 'seq'. הדרכים השונות לביצוע המשימות המקבילות באמצעות לולאת 'for' מוצגות במדריך זה.

דוגמאות שונות למשרות מקבילות

הדרכים השונות להפעיל את העבודות המקבילות באמצעות לולאת 'ל' מוצגות בחלק זה של המדריך.

דוגמה 1: הפעל את המשימות המקבילות באמצעות לולאת 'עבור'.

שימוש בלולאת 'for' היא הדרך הפשוטה יותר לבצע את העבודות המקבילות בסקריפט Bash. צור קובץ Bash עם הסקריפט הבא שמריץ את הלולאה 'for' 10000 פעמים והדפיס מספר לאחר איטרציה של 1000 פעמים. משימה זו מתבצעת במקביל באמצעות לולאת 'עבור'.







#!/bin/bash

#חזרו על הלולאה עד שתגיע ל-10000

ל val ב ` seq 0 1000 10000 ` ;

לַעֲשׂוֹת

#הדפס כל מספר 1000

הֵד $val

בוצע

הפלט הבא מופיע לאחר ביצוע הסקריפט. ישנם 10 מספרים בין 0 ל-10000 המודפסים בפלט:



  p3



דוגמה 2: הפעל את המשימות המקבילות באמצעות לולאת 'עבור' המקוננת

צור קובץ Bash עם הסקריפט הבא שמריץ את הלולאה המקוננת 'for' שיוצרת את המספר הסידורי באמצעות התווים האלפביתיים מ-'A' עד 'C' והמספרים 1 עד 3. באיטרציה הראשונה של הלולאה החיצונית ולאחריה השלמת האיטרציה של הלולאה הפנימית, 'A1. CodeIgniter', 'A2. Laravel', ו-'A3. CakePHP' מודפסים. באיטרציה השנייה של הלולאה החיצונית ולאחר השלמת האיטרציה של הלולאה הפנימית, 'B1. אורקל', 'B2. MySQL', ו-'B3. SQL' מודפסים. באיטרציה השלישית של הלולאה החיצונית ולאחר השלמת האיטרציה של הלולאה הפנימית, 'C1. CSS', 'C2. JQuery', ו-'C3. JavaScript' מודפסים.





#לולאה חיצונית

ל אלפא ב { א..צ }

לַעֲשׂוֹת

#לולאה פנימית

ל מספר ב { 1 .. 3 }

לַעֲשׂוֹת

#הדפס את הפלט על סמך התנאי

אם [ $alpha == 'א' ] ; לאחר מכן

רשימת מערך = ( 'CodeIgniter' 'לארב' 'CakePHP' )

אליף [ $alpha == 'ב' ] ; לאחר מכן

רשימת מערך = ( 'נבואה' 'MySQL' 'SQL' )

אליף [ $alpha == 'ג' ] ; לאחר מכן

רשימת מערך = ( 'CSS' 'JQuery' 'JavaScript' )

לִהיוֹת

הֵד ' $alpha $number . ${arrayList[$number-1]} '

בוצע

בוצע

הפלט הבא מופיע לאחר ביצוע הסקריפט:



דוגמה 3: הפעל את העבודות המקבילות באמצעות לולאת 'ל' ופקודת 'המתן'.

הפקודה 'המתנה' היא פקודה שימושית מאוד של Bash המשמשת להמתנה לעבודה אחת כדי להשלים את המשימה כאשר פועלות מספר עבודות. אם פועלות פחות משימות, הפקודה 'המתנה' מתחילה עבודה חדשה באופן אסינכרוני. צור קובץ Bash עם הסקריפט הבא שמריץ עבודת רקע בתוך לולאת 'for' המקוננת. הפקודה 'המתנה' משמשת להמתנה להשלמת כל תהליכי הצאצא. הפקודות 'תאריך' ו'שינה' מבוצעות כתהליך הרקע.

#לולאה חיצונית

ל אני ב { 1 .. 2 }

לַעֲשׂוֹת

#לולאה פנימית

ל י ב { 1 .. 3 }

לַעֲשׂוֹת

אם מִבְחָן ' $(משרות | wc -l) ' -ge 2 ; לאחר מכן

לַחֲכוֹת

לִהיוֹת

#תהליך רקע

{

תַאֲרִיך

לִישׁוֹן 1

} &

בוצע

בוצע

הפלט הבא מופיע לאחר ביצוע הסקריפט. התאריך והשעה הנוכחיים מודפסים 6 פעמים מתהליך הרקע כדי לחזור על לולאות 'עבור' המקוננות במשך 2×3=6 פעמים:

דוגמה 4: הבדלים בין ריצות עוקבות וקבילות

צור קובץ Bash עם הסקריפט הבא המציג את ההבדלים בין הריצה העוקבת לריצה המקבילה. הפונקציה prn_char() מוגדרת בסקריפט כדי להדפיס חמישה תווים עם משך 0.5 שניות. לאחר מכן, לולאת 'for' הראשונה משמשת להפעלת הפונקציה prn_char() ברצף. לולאת 'for' השנייה משמשת להפעלת הפונקציה prn_char() במקביל.

#הגדר פונקציה להדפסת 5 תווים עם משך 0.5 שניות

prn_char ( ) {

ל ג ב שלום; לַעֲשׂוֹת

לִישׁוֹן 0.5 ;

הֵד $c ;

בוצע

הֵד

}

#הפעל את הפונקציה באמצעות for loop ברצף

ל הַחוּצָה ב { 1 .. 3 } ; לַעֲשׂוֹת

prn_char ' $ בחוץ '

בוצע

#הפעל את הפונקציה באמצעות for loop במקביל

ל הַחוּצָה ב { 1 .. 3 } ; לַעֲשׂוֹת

prn_char ' $ בחוץ ' &

בוצע


הפלט הבא מופיע לאחר ביצוע הסקריפט. ההבדל בין הריצה העוקבת לריצה המקבילה מוצג בפלט. כאן, כל התווים של לולאת 'for' של הפונקציה prn_char() מודפסים בכל פעם בריצה הרציפה וכל תו מודפס שלוש פעמים בריצה המקבילה:

  p4

סיכום

הפעלת העבודות המקבילות באמצעות לולאה 'ל' נדרשת למטרות תכנות רבות. השיטות להפעלת המשימות המקבילות באמצעות לולאת 'ל' מוצגות במדריך זה.