लिनक्स एडमिन - शेल स्क्रिप्टिंग

बैश शैल का परिचय

जीएनयू लिनक्स के स्वादों की तरह, गोले कई किस्मों में आते हैं और संगतता में भिन्न होते हैं। CentOS में डिफ़ॉल्ट शेल को बैश या बॉर्न अगेन शेल के रूप में जाना जाता है। बैश शैल एक आधुनिक दिन है, जो स्टीफन बॉर्न द्वारा विकसित बॉर्न शेल का संशोधित संस्करण है। बैश केन थॉम्पसन और डेनिस रिची द्वारा बेल लैब्स में विकसित यूनिक्स ऑपरेटिंग सिस्टम पर मूल थॉम्पसन शेल का प्रत्यक्ष प्रतिस्थापन था (स्टीफन बॉर्न भी बेल लैब्स द्वारा नियोजित किया गया था)

हर किसी का पसंदीदा शेल होता है और प्रत्येक की ताकत और कठिनाइयाँ होती हैं। लेकिन अधिकांश भाग के लिए, बश सभी लिनक्स वितरणों में डिफ़ॉल्ट शेल होने वाला है और सबसे अधिक उपलब्ध है। अनुभव के साथ, हर कोई एक खोल का पता लगाना और उसका उपयोग करना चाहेगा जो उनके लिए सबसे अच्छा है। हालांकि एक ही समय में, हर कोई भी बैश शेल को मास्टर करना चाहेगा।

अन्य लिनक्स गोले में शामिल हैं: Tcsh, Csh, Ksh, Zsh और Fish।

एक विशेषज्ञ स्तर पर किसी भी लिनक्स शेल का उपयोग करने के लिए कौशल विकसित करना एक CentOS व्यवस्थापक के लिए अत्यंत महत्वपूर्ण है। जैसा कि हमने पहले उल्लेख किया है, विंडोज के विपरीत, इसके दिल में लिनक्स एक कमांड लाइन ऑपरेटिंग सिस्टम है। शेल केवल एक उपयोगकर्ता इंटरफ़ेस है जो किसी व्यवस्थापक (या उपयोगकर्ता) को ऑपरेटिंग सिस्टम को कमांड जारी करने की अनुमति देता है। यदि लिनक्स सिस्टम प्रशासक एक एयरलाइन पायलट था, तो शेल का उपयोग करना ऑटो-पायलट से प्लेन को उतारने और अधिक पैंतरेबाज़ी उड़ान के लिए मैनुअल नियंत्रण को हथियाने के समान होगा।

एक बैश की तरह लिनक्स खोल, कंप्यूटर विज्ञान के संदर्भ में एक के रूप में जाना जाता है Command Line Interpreter। Microsoft Windows में दो कमांड लाइन दुभाषिए भी हैं जिन्हें DOS कहा जाता है (मूल DOS ऑपरेटिंग सिस्टम के साथ भ्रमित नहीं होना चाहिए) और PowerShell।

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

निर्माण में शामिल हैं -

  • स्क्रिप्ट प्रवाह नियंत्रण (ifthen और अन्य)
  • तार्किक तुलना संचालन (तुलना में अधिक, समानता से कम)
  • Loops
  • Variables
  • ऑपरेशन को परिभाषित करने वाले पैरामीटर (कमांड के साथ स्विच के समान)

शैल स्क्रिप्ट बनाम स्क्रिप्टिंग भाषा का उपयोग करना

अक्सर जब एक कार्य प्रशासक प्रदर्शन करने के बारे में सोचता है तो खुद से पूछता है: क्या मुझे एक शेल स्क्रिप्ट या एक स्क्रिप्टिंग भाषा का उपयोग करना चाहिए जैसे पर्ल, रूबी या पायथन?

यहां कोई निर्धारित नियम नहीं है। गोले बनाम पटकथा भाषाओं के बीच केवल विशिष्ट अंतर हैं।

शेल

शैल लिनक्स के उपयोग के रूप में इस तरह के आदेश की अनुमति देता है sed , ग्रेप , टी , बिल्ली और अन्य सभी कमांड लाइन लिनक्स ऑपरेटिंग सिस्टम पर आधारित उपयोगिताओं। वास्तव में, बहुत ज्यादा किसी भी कमांड लाइन लिनक्स उपयोगिता को आपके शेल में स्क्रिप्ट किया जा सकता है।

DNS रिज़ॉल्यूशन के लिए मेजबानों की सूची की जांच करने के लिए एक शेल का उपयोग करने का एक शानदार उदाहरण एक त्वरित स्क्रिप्ट होगा।

DNS नामों की जांच करने के लिए हमारी सरल बैश स्क्रिप्ट -

#!/bin/bash 
for name in $(cat $1);
   do 
      host $name.$2 | grep "has address" 
   done 
exit

DNS रिज़ॉल्यूशन का परीक्षण करने के लिए छोटी वर्डलिस्ट -

dns 
www 
test 
dev 
mail 
rdp 
remote

Google.com डोमेन के खिलाफ आउटपुट -

[rdc@centos ~]$  ./dns-check.sh dns-names.txt google.com
-doing dns
dns.google.com has address 172.217.6.46
-doing www
www.google.com has address 172.217.6.36
-doing test
-doing dev
-doing mail
googlemail.l.google.com has address 172.217.6.37
-doing rdp
-doing remote

[rdc@centos ~]$

हमारे शेल में सरल लिनक्स कमांड का उपयोग करते हुए, हम एक शब्द सूची से DNS नामों का ऑडिट करने के लिए एक सरल 5-लाइन स्क्रिप्ट बनाने में सक्षम थे। यह अच्छी तरह से कार्यान्वित डीएनएस लाइब्रेरी का उपयोग करते समय पर्ल, पायथन या रूबी में कुछ काफी समय लगा होगा।

भाषा का अंकन

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

इसके अलावा, एक उच्च बनाए रखा स्क्रिप्टिंग भाषा के साथ हम जानते हैं कि हमारे कार्य अधिकांश भाग के लिए विभिन्न प्रणालियों में काम करेंगे। उदाहरण के लिए, Python 3.5, Python 3.5 को चलाने वाले किसी अन्य सिस्टम पर उसी लाइब्रेरी के साथ काम करेगा। ऐसा नहीं है, अगर हम लिनक्स और HP-UX दोनों पर अपनी BASH स्क्रिप्ट को चलाना चाहते हैं।

कभी-कभी एक स्क्रिप्टिंग भाषा और एक शक्तिशाली शेल के बीच की रेखाएं धुंधली हो सकती हैं। सेंटोस लिनक्स प्रशासन कार्यों को पायथन, पर्ल या रूबी के साथ स्वचालित करना संभव है। ऐसा करना वास्तव में काफी सामान्य बात है। इसके अलावा, संपन्न शेल-स्क्रिप्ट डेवलपर्स ने बैश में एक सरल, लेकिन अन्यथा कार्यात्मक, वेब-सर्वर डेमन बनाया है।

भाषाओं में स्क्रिप्टिंग और गोले में स्वचालित कार्यों के अनुभव के साथ, एक CentOS प्रशासक जल्दी से यह निर्धारित कर सकेगा कि किसी समस्या को हल करने के लिए कब शुरू करना है। शेल स्क्रिप्ट के साथ प्रोजेक्ट शुरू करना काफी आम है। फिर एक प्रोजेक्ट के रूप में स्क्रिप्टिंग (या संकलित) भाषा की प्रगति अधिक जटिल हो जाती है।

इसके अलावा, किसी प्रोजेक्ट के विभिन्न हिस्सों के लिए स्क्रिप्टिंग भाषा और शेल स्क्रिप्ट दोनों का उपयोग करना ठीक है। एक उदाहरण एक वेबसाइट को परिमार्जन करने के लिए एक पर्ल स्क्रिप्ट हो सकता है। फिर, साथ पार्स करने के लिए एक खोल स्क्रिप्ट और स्वरूप का उपयोग sed , awk , और egrep । अंत में, एक वेब GUI का उपयोग करके MySQL डेटाबेस में स्वरूपित डेटा डालने के लिए एक PHP स्क्रिप्ट का उपयोग करें।

गोले के पीछे कुछ सिद्धांत के साथ, आइए CentOS में बैश शेल से कार्यों को स्वचालित करने के लिए बुनियादी भवन ब्लॉकों के साथ शुरू करें।

इनपुट आउटपुट और पुनर्निर्देशन

एक और कमांड के लिए प्रसंस्करण stdout -

[rdc@centos ~]$ cat ~/output.txt | wc -l 
6039 
[rdc@centos ~]$

ऊपर, हमने पाइप के चरित्र के साथ प्रसंस्करण के लिए wc को कैटस्टौड पास किया है । wc ने तब आउटपुट से बिल्ली को प्रोसेस किया , output.txt की लाइन काउंट को टर्मिनल पर प्रिंट किया। एक कमांड से पाइप कैरेक्टर को "कमांड" के रूप में पास करने के बारे में सोचें , जिसे अगले कमांड द्वारा प्रोसेस किया जाए।

कमांड पुनर्निर्देशन से निपटने के दौरान याद रखने वाली प्रमुख अवधारणाएँ निम्नलिखित हैं -

संख्या फ़ाइल विवरणक चरित्र
0 मानक इनपुट <
1 मानक उत्पादन >
2 मानक त्रुटि
स्टेंडआउट अपेंड करें >>
पुनर्निर्देशन सौंपें और
स्टड में पाइप स्टडआउट |

हमने इसे पुनर्निर्देशन के बारे में अधिक बात किए बिना या पुनर्निर्देशन को निर्दिष्ट किए बिना अध्याय एक में पेश किया। लिनक्स में टर्मिनल खोलते समय, आपके शेल को डिफ़ॉल्ट लक्ष्य के रूप में देखा जाता है -

  • मानक इनपुट <0
  • मानक उत्पादन> 1
  • मानक त्रुटि २

आइए देखें कि यह कैसे काम करता है -

[rdc@centos ~]$ lsof -ap $BASHPID -d 0,1,2 
 COMMAND   PID   USER    **FD**   TYPE DEVICE   SIZE/OFF   NODE      NAME 
 bash    13684    rdc    **0u**   CHR  136,0      0t0     3      /dev/pts/0 
 bash    13684    rdc    **1u**   CHR  136,0      0t0     3      /dev/pts/0 
 bash    13684    rdc    **2u**   CHR  136,0      0t0     3      /dev/pts/0
 
[rdc@centos ~]$

/ dev / pts / 0 हमारा छद्म टर्मिनल है। CentOS Linux इसे देखता है और हमारे खुले टर्मिनल एप्लिकेशन के बारे में सोचता है, जिसमें कीबोर्ड के साथ एक वास्तविक टर्मिनल और सीरियल इंटरफ़ेस के माध्यम से प्लग किया गया है। हालाँकि, एक हाइपरविजर एब्स्ट्रैक्ट हार्डवेयर की तरह एक ऑपरेटिंग सिस्टम / dev / pts एब्स्ट्रैक्ट्स हमारे टर्मिनल टू एप्लिकेशन को करता है।

उपरोक्त lsof कमांड से, हम नीचे देख सकते हैंFDस्तंभ जो सभी तीन फ़ाइल-डिस्क्रिप्टर हमारे वर्चुअल टर्मिनल (0,1,2) पर सेट हैं। अब हम कमांड भेज सकते हैं, कमांड आउटपुट देख सकते हैं, साथ ही कमांड से जुड़ी कोई भी त्रुटि।

STDIN और STDOUT के लिए उदाहरण निम्नलिखित हैं -

STDOUT

[root@centosLocal centos]# echo "I am coming from Standard output or STDOUT." >
output.txt && cat output.txt
I am coming from Standard output or STDOUT. 
[root@centosLocal centos]#

अलग-अलग फ़ाइलों के लिए stdout और stderr दोनों को भेजना भी संभव है -

bash-3.2# find / -name passwd 1> good.txt 2> err.txt
bash-3.2# cat good.txt
/etc/pam.d/passwd
/etc/passwd
bash-3.2# cat err.txt 
find: /dev/fd/3: Not a directory
find: /dev/fd/4: Not a directory
bash-3.2#

संपूर्ण फ़ाइल सिस्टम की खोज करते समय, दो त्रुटियां सामने आई थीं। प्रत्येक को बाद की गड़बड़ी के लिए एक अलग फ़ाइल में भेजा गया था, जबकि वापस आए परिणामों को एक अलग पाठ फ़ाइल में रखा गया था।

टेक्स्ट फ़ाइल में भेजने वाले स्टेंडर को उन चीज़ों को करते समय उपयोगी हो सकता है जो टर्मिनल के लिए ढेर सारे डेटा का उत्पादन करते हैं जैसे अनुप्रयोगों को संकलित करना। यह उन त्रुटियों के लिए अनुमति देगा जो टर्मिनल स्क्रॉलबैक इतिहास से खो सकते हैं।

टेक्स्ट फ़ाइल में STDOUT पास करते समय एक नोट के बीच अंतर है >> तथा >। डबल ">>" एक फाइल के लिए अपील करेगा, जबकि एकवचन फॉर्म फाइल को क्लोब करेगा और नई सामग्री लिखेगा (इसलिए पिछले सभी डेटा खो जाएगा)।

STDIN

[root@centosLocal centos]# cat < stdin.txt
Hello,
I am being read form Standard input, STDIN.

[root@centosLocal centos]#

उपरोक्त कमांड में, टेक्स्ट फाइल stdin.txt को कैट कमांड पर पुनर्निर्देशित किया गया था जो STDOUT को अपनी सामग्री को प्रतिध्वनित करता था ।

पाइप चरित्र "|"

पाइप चरित्र पहले कमांड से आउटपुट लेगा, इसे अगले कमांड में इनपुट के रूप में पास करके, सेकंड कमांड को आउटपुट पर संचालन करने की अनुमति देगा।

अब, चलो "पाइप" एक और कमांड के लिए बिल्ली का स्टडआउट -

[root@centosLocal centos]# cat output.txt | wc -l
2
[root@centosLocal centos]#

ऊपर, डब्ल्यूसी बिल्ली से आउटपुट पर गणना करता है जो पाइप से पारित किया गया था। पाइप कमांड विशेष रूप से उपयोगी है जब grep या egrep से आउटपुट को फ़िल्टर करते हुए -

[root@centosLocal centos]# egrep "^[0-9]{4}$" /usr/dicts/nums | wc -l  
9000 
[root@centosLocal centos]#

उपरोक्त कमांड में, हमने प्रत्येक 4 अंकीय संख्या को एक पाठ फ़ाइल से wc में पारित किया, जिसमें 65535 से सभी संख्याएँ हैं, जैसे कि एक egrep फ़िल्टर।

साथ पुनर्निर्देशित उत्पादन और

आउटपुट का उपयोग करके पुनर्निर्देशित किया जा सकता है &चरित्र। अगर हम STDOUT और STDERR दोनों को आउटपुट एक ही फाइल में निर्देशित करना चाहते हैं, तो इसे निम्न प्रकार से पूरा किया जा सकता है -

[root@centosLocal centos]# find / -name passwd > out.txt 2>&1
[root@centosLocal centos]# cat out.txt  
find: /dev/fd/3: Not a directory 
find: /dev/fd/4: Not a directory 
/etc/passwd

[root@centosLocal centos]#

का उपयोग कर पुनर्निर्देशन &चरित्र इस तरह से काम करता है: पहला, आउटपुट को आउटटैक्स में रीडायरेक्ट किया जाता है । दूसरा, STDERR या फ़ाइल वर्णनकर्ता 2 इस मामले में STDOUT के रूप में एक ही स्थान पर पुन: सौंपा गया है, out.txt

पुनर्निर्देशन अत्यंत उपयोगी है और बड़ी टेक्स्ट-फाइल्स में हेरफेर, सोर्स कोड को कंपाइल करने, शेल स्क्रिप्ट में आउटपुट को रीडायरेक्ट करने और जटिल लिनक्स कमांड जारी करने के दौरान आने वाली समस्याओं को हल करते समय काम आता है।

जबकि शक्तिशाली, पुनर्निर्देशन नए CentOS व्यवस्थापकों के लिए जटिल हो सकता है। लिनक्स फोरम (जैसे स्टैक ओवरफ्लो लिनक्स) के अभ्यास, अनुसंधान और सामयिक प्रश्न उन्नत समाधानों को हल करने में मदद करेंगे।

बैश शैल निर्माण

अब हमारे पास एक अच्छा विचार है कि बैश शेल कैसे काम करता है, आइए स्क्रिप्ट लिखने के लिए आमतौर पर उपयोग किए जाने वाले कुछ बुनियादी निर्माण सीखें। इस भाग में हम खोज करेंगे -

  • Variables
  • Loops
  • Conditionals
  • लूप नियंत्रण
  • फाइलों को पढ़ना और लिखना
  • बुनियादी गणित संचालन

BASH समस्या निवारण संकेत

समर्पित स्क्रिप्टिंग भाषा की तुलना में BASH थोड़ा मुश्किल हो सकता है। BASH स्क्रिप्ट्स में कुछ सबसे बड़ी हैंग अप गलत तरीके से भागने या स्क्रिप्ट ऑपरेशन से बचने के लिए नहीं है। यदि आपने किसी स्क्रिप्ट पर कुछ समय के लिए देखा है और यह अपेक्षित रूप से काम नहीं कर रहा है, तो झल्लाहट न करें। यह उन लोगों के साथ भी आम है, जो रोजाना जटिल स्क्रिप्ट बनाने के लिए BASH का उपयोग करते हैं।

Google की त्वरित खोज या प्रश्न पूछने के लिए विशेषज्ञ लिनक्स फोरम में साइन अप करने से त्वरित समाधान प्राप्त होगा। इस बात की बहुत संभावना है कि कोई व्यक्ति सटीक मुद्दे पर आया है और इसे पहले ही हल कर लिया गया है।

BASH स्क्रिप्टिंग प्रशासन के कार्यों को स्वचालित करने से लेकर उपयोगी उपकरण बनाने तक हर चीज के लिए जल्दी से शक्तिशाली स्क्रिप्ट बनाने की एक शानदार विधि है। एक विशेषज्ञ स्तर BASH स्क्रिप्ट डेवलपर बनना समय और अभ्यास लेता है। इसलिए, जब भी संभव हो, BASH लिपियों का उपयोग करें, यह आपके CentOS व्यवस्थापन टूलबॉक्स में एक महान उपकरण है।