पर्ल - प्रक्रिया प्रबंधन

आप अपनी आवश्यकताओं के अनुसार नई प्रक्रियाओं को बनाने के लिए विभिन्न तरीकों से पर्ल का उपयोग कर सकते हैं। यह ट्यूटोरियल पर्ल प्रक्रियाओं को बनाने और प्रबंधित करने के कुछ महत्वपूर्ण और सबसे अधिक बार उपयोग किए जाने वाले तरीकों को सूचीबद्ध करेगा।

  • आप विशेष चर का उपयोग कर सकते हैं $$ या $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;