पर्ल - प्रक्रिया प्रबंधन
आप अपनी आवश्यकताओं के अनुसार नई प्रक्रियाओं को बनाने के लिए विभिन्न तरीकों से पर्ल का उपयोग कर सकते हैं। यह ट्यूटोरियल पर्ल प्रक्रियाओं को बनाने और प्रबंधित करने के कुछ महत्वपूर्ण और सबसे अधिक बार उपयोग किए जाने वाले तरीकों को सूचीबद्ध करेगा।
आप विशेष चर का उपयोग कर सकते हैं $$ या $PROCESS_ID वर्तमान प्रक्रिया आईडी प्राप्त करने के लिए।
किसी भी वर्णित विधियों का उपयोग करके बनाई गई प्रत्येक प्रक्रिया, अपने स्वयं के आभासी वातावरण को बनाए रखती है %ENV चर।
exit() फ़ंक्शन हमेशा केवल बच्चे की प्रक्रिया से बाहर निकलता है जो इस फ़ंक्शन को निष्पादित करता है और एक पूरे के रूप में मुख्य प्रक्रिया तब तक बाहर नहीं निकलेगी जब तक कि सभी चल रहे बच्चे-प्रक्रियाएं बाहर नहीं निकल जाती हैं।
सभी खुले हैंडल दुपट्टे () - बच्चे-प्रक्रियाओं में एड होते हैं, ताकि किसी भी प्रक्रिया में किसी भी हैंडल को बंद करना दूसरों को प्रभावित न करे।
बैकस्टिक ऑपरेटर
किसी भी यूनिक्स कमांड को निष्पादित करने का यह सबसे सरल तरीका है बैकस्टिक ऑपरेटर का उपयोग करना। आप बस बैकस्टेक ऑपरेटर के अंदर अपनी कमांड डालते हैं, जिसके परिणामस्वरूप कमांड का निष्पादन होगा और इसके परिणाम को लौटाएगा जो निम्नानुसार संग्रहीत किया जा सकता है -
#!/usr/bin/perl
@files = `ls -l`;
foreach $file (@files) {
print $file;
}
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह वर्तमान निर्देशिका में उपलब्ध सभी फाइलों और निर्देशिकाओं को सूचीबद्ध करता है -
drwxr-xr-x 3 root root 4096 Sep 14 06:46 9-14
drwxr-xr-x 4 root root 4096 Sep 13 07:54 android
-rw-r--r-- 1 root root 574 Sep 17 15:16 index.htm
drwxr-xr-x 3 544 401 4096 Jul 6 16:49 MIME-Lite-3.01
-rw-r--r-- 1 root root 71 Sep 17 15:16 test.pl
drwx------ 2 root root 4096 Sep 17 15:11 vAtrJdy
सिस्टम () फ़ंक्शन
आप भी उपयोग कर सकते हैं system()किसी भी यूनिक्स कमांड को निष्पादित करने के लिए फ़ंक्शन, जिसका आउटपुट पर्ल स्क्रिप्ट के आउटपुट पर जाएगा। डिफ़ॉल्ट रूप से, यह स्क्रीन है, यानी, STDOUT, लेकिन आप इसे रीडायरेक्शन ऑपरेटर> - का उपयोग करके किसी भी फ़ाइल पर रीडायरेक्ट कर सकते हैं।
#!/usr/bin/perl
system( "ls -l")
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह वर्तमान निर्देशिका में उपलब्ध सभी फाइलों और निर्देशिकाओं को सूचीबद्ध करता है -
drwxr-xr-x 3 root root 4096 Sep 14 06:46 9-14
drwxr-xr-x 4 root root 4096 Sep 13 07:54 android
-rw-r--r-- 1 root root 574 Sep 17 15:16 index.htm
drwxr-xr-x 3 544 401 4096 Jul 6 16:49 MIME-Lite-3.01
-rw-r--r-- 1 root root 71 Sep 17 15:16 test.pl
drwx------ 2 root root 4096 Sep 17 15:11 vAtrJdy
जब आपके कमांड में $ PATH या $ HOME जैसे शेल पर्यावरण चर हों तो सावधान रहें। तीन परिदृश्यों का अनुसरण करने का प्रयास करें -
#!/usr/bin/perl
$PATH = "I am Perl Variable";
system('echo $PATH'); # Treats $PATH as shell variable
system("echo $PATH"); # Treats $PATH as Perl variable
system("echo \$PATH"); # Escaping $ works.
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह शेल चर $ PATH में सेट किए गए के आधार पर निम्न परिणाम उत्पन्न करता है।
/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
I am Perl Variable
/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
कांटा () समारोह
पर्ल प्रदान करता है fork()फ़ंक्शन जो समान नाम के यूनिक्स सिस्टम कॉल से मेल खाती है। अधिकांश यूनिक्स जैसे प्लेटफ़ॉर्म पर जहां कांटा () सिस्टम कॉल उपलब्ध है, पर्ल का कांटा () बस इसे कॉल करता है। विंडोज जैसे कुछ प्लेटफार्मों पर जहां फोर्क () सिस्टम कॉल उपलब्ध नहीं है, दुभाषिया स्तर पर फोर्क () का अनुकरण करने के लिए पर्ल का निर्माण किया जा सकता है।
कांटा () फ़ंक्शन का उपयोग वर्तमान प्रक्रिया को क्लोन करने के लिए किया जाता है। यह कॉल उसी बिंदु पर समान प्रोग्राम चलाने वाली एक नई प्रक्रिया बनाती है। यह माता-पिता की प्रक्रिया, बच्चे की प्रक्रिया के लिए 0, या कांटा असफल होने पर अपरिभाषित होने पर बच्चे को वापस भेज देता है।
आप उपयोग कर सकते हैं exec() अनुरोधित निष्पादन योग्य को लॉन्च करने के लिए एक प्रक्रिया के भीतर कार्य करें, जिसे एक अलग प्रक्रिया क्षेत्र में निष्पादित किया जाएगा और निष्पादन () उस प्रक्रिया से बाहर निकलने की स्थिति से बाहर निकलने से पहले इसे पूरा करने के लिए इंतजार करेगा।
#!/usr/bin/perl
if(!defined($pid = fork())) {
# fork returned undef, so unsuccessful
die "Cannot fork a child: $!";
} elsif ($pid == 0) {
print "Printed by child process\n";
exec("date") || die "can't exec date: $!";
} else {
# fork returned 0 nor undef
# so this branch is parent
print "Printed by parent process\n";
$ret = waitpid($pid, 0);
print "Completed process id: $ret\n";
}
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Printed by parent process
Printed by child process
Tue Sep 17 15:41:08 CDT 2013
Completed process id: 17777
wait() तथा waitpid()एक छद्म प्रक्रिया आईडी के रूप में कांटा द्वारा लौटाया जा सकता है ()। ये कॉल ठीक से छद्म प्रक्रिया की समाप्ति की प्रतीक्षा करेंगे और अपनी स्थिति वापस करेंगे। यदि आप कभी भी अपने बच्चों का उपयोग किए बिना प्रतीक्षा कर रहे हैंwaitpid()फ़ंक्शन, आप लाश जमा करेंगे। यूनिक्स प्रणालियों पर, आप $ SIG {CHLD} को “IGNORE” पर इस प्रकार सेट करके इससे बच सकते हैं -
#!/usr/bin/perl
local $SIG{CHLD} = "IGNORE";
if(!defined($pid = fork())) {
# fork returned undef, so unsuccessful
die "Cannot fork a child: $!";
} elsif ($pid == 0) {
print "Printed by child process\n";
exec("date") || die "can't exec date: $!";
} else {
# fork returned 0 nor undef
# so this branch is parent
print "Printed by parent process\n";
$ret = waitpid($pid, 0);
print "Completed process id: $ret\n";
}
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Printed by parent process
Printed by child process
Tue Sep 17 15:44:07 CDT 2013
Completed process id: -1
मार () समारोह
पर्ल kill('KILL', (Process List)) फ़ंक्शन का उपयोग छद्म-प्रक्रिया को समाप्त करने के लिए किया जा सकता है, इसे आईडी द्वारा कांटे से लौटाकर ()।
ध्यान दें कि छद्म प्रक्रिया () पर किल ('KILL ’, (प्रोसेस लिस्ट)) का उपयोग करने से आमतौर पर मेमोरी लीक हो सकती है, क्योंकि जो धागा छद्म प्रक्रिया को लागू करता है, उसे अपने संसाधनों को साफ करने का मौका नहीं मिलता है।
आप उपयोग कर सकते हैं kill() लक्ष्य प्रक्रियाओं के लिए किसी अन्य संकेत को भेजने के लिए फ़ंक्शन, उदाहरण के लिए निम्नलिखित एक प्रक्रिया को SIGINT भेजेगा आईडी 104 और 102 -
#!/usr/bin/perl
kill('INT', 104, 102);
1;