साल्टस्टैक - दूरस्थ निष्पादन

नमक की मुख्य अवधारणाओं में से एक दूरस्थ निष्पादन है। नमक सेकंड के एक मामले में हजारों प्रणालियों में कमांड निष्पादित कर सकता है। इस कार्य को करने के लिए नमक अपने स्वयं के आदेश का उपयोग करता है। आइए अब अध्याय में दूरस्थ निष्पादन के लिए अलग-अलग साल्ट कमांड को समझते हैं।

नमक कमान

नमक आदेश नमक मास्टर को एक या अधिक के साथ संवाद करने में सक्षम बनाता है Salt minions। मूल सिंटैक्स निम्नानुसार है,

salt '<target>' <module.function> [arguments]

उपरोक्त कमांड सिंटैक्स में तीन मुख्य घटक होते हैं।

  • target - यह निर्धारित करता है कि कौन सा सिस्टम कमांड द्वारा लागू किया गया है।

  • module.function- यह एक कमांड है। कमांड में एक मॉड्यूल और फ़ंक्शन होता है।

  • arguments - फ़ंक्शन को कॉल करने के लिए आवश्यक अतिरिक्त डेटा।

आइए हम प्रत्येक घटक को विस्तार से समझें।

लक्ष्य घटक क्या है?

लक्ष्य एक घटक है, जो आपको फ़ंक्शन को चलाने के लिए minions (प्रबंधित सिस्टम) को फ़िल्टर करने की अनुमति देता है। लक्ष्य घटक का उपयोग करने वाला एक सरल कमांड नीचे परिभाषित किया गया है।

salt '*' test.ping

यह निम्नलिखित उत्पादन करेगा output -

minion2:
   True
minion1:
   True

यहाँ, लक्ष्य ‘*’सभी प्रबंधित प्रणालियों का प्रतिनिधित्व करता है। 'test'यहाँ एक मॉड्यूल है और pingएक समारोह है। इसका उपयोग दूरस्थ प्रणाली में पिंग सेवा का परीक्षण करने के लिए किया जाता है। हम बाद के अध्यायों में विभिन्न मॉड्यूल और उसके कार्यों के बारे में जानेंगे।

आईडी (मिनियन) का उपयोग कर लक्ष्य

आप इसके इस्तेमाल से किसी विशिष्ट मिनियन को कमांड भेज सकते हैं idलक्ष्य में। के बजाय का उपयोग करने का'*', आप इसका उपयोग करके प्रतिस्थापित कर सकते हैं minion id। इसे नीचे परिभाषित किया गया है।

salt 'minion1’ test.ping

यह निम्नलिखित उत्पादन करेगा output -

minion1:
   True

नियमित अभिव्यक्ति का उपयोग कर लक्ष्य

लक्ष्य को विशिष्ट नियमित अभिव्यक्ति द्वारा फ़िल्टर किया जा सकता है। इसे नीचे परिभाषित किया गया है।

salt -E 'minion[0-9]' test.ping

यह निम्नलिखित उत्पादन करेगा output -

minion2:
   True
minion1:
   True

सूची का उपयोग कर लक्ष्य

एक सूची में लक्ष्य स्पष्ट रूप से निर्दिष्ट किए जा सकते हैं। इसे निम्नलिखित कोड ब्लॉक में परिभाषित किया गया है।

salt -L 'minion1,minion2' test.ping

यह निम्नलिखित उत्पादन करेगा output -

minion2:
   True
minion1:
   True

हालत से लक्ष्य

नीचे दिए गए कोड ब्लॉक में दिखाए गए अनुसार लक्ष्य को एक कमांड में जोड़ा जा सकता है।

salt -C 'G@os:Ubuntu and minion* or [email protected].*' test.ping

यह निम्नलिखित उत्पादन करेगा output -

minion1:
   True
minion2:
   True

मॉड्यूल और कार्य (मॉड्यूल.फंक्शन)

नमक शेल कमांड निष्पादित कर सकता है; संकुल को अद्यतन करें और फ़ाइलों को वितरित करें, आदि, इसके सभी प्रबंधित सिस्टम में एक साथ। नमक इन ऑपरेशनों को मॉड्यूल का उपयोग करके करता है। सभी उपलब्ध कार्यात्मकताओं के लिए नमक में विशेष मॉड्यूल हैं। आइए इस अध्याय में कुछ सरल उदाहरण का उपयोग करते हुए अलग-अलग साल्ट मॉड्यूल को समझें।

शेल कमांड

नमक कई प्रणालियों के उपयोग से दूरस्थ रूप से शेल कमांड निष्पादित करता है cmd.runआदेश। cmd मुख्य मॉड्यूल है और run में उपलब्ध फ़ंक्शन में से एक है cmdमापांक। run फ़ंक्शन किसी भी शेल कमांड को रिमोट सिस्टम में निष्पादित करने में सक्षम बनाता है जैसा कि नीचे दिए गए कोड ब्लॉक में दिखाया गया है।

salt '*' cmd.run 'ls -l /etc'

यह निम्नलिखित उत्पादन करेगा output -

minion2:
   total 868
   drwxr-xr-x 7 root root    4096 Jan 26 22:10 X11
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 acpi
   -rw-r--r-- 1 root root    2981 Jan 26 20:48 adduser.conf
   -rw-r--r-- 1 root root      10 Jan 26 21:04 adjtime
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 alternatives
   drwxr-xr-x 3 root root    4096 Jan 26 20:53 apm
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apparmor
   drwxr-xr-x 9 root root    4096 Jan 26 21:02 apparmor.d
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apport
   drwxr-xr-x 6 root root    4096 Jan 29 07:14 apt
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 at-spi2
……………
……………
minion1:
   total 868
   drwxr-xr-x 7 root root    4096 Jan 26 22:10 X11
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 acpi
   -rw-r--r-- 1 root root    2981 Jan 26 20:48 adduser.conf
   -rw-r--r-- 1 root root      10 Jan 26 21:04 adjtime
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 alternatives
   drwxr-xr-x 3 root root    4096 Jan 26 20:53 apm

   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apparmor
   drwxr-xr-x 9 root root    4096 Jan 26 21:02 apparmor.d
   drwxr-xr-x 3 root root    4096 Jan 26 21:02 apport
   drwxr-xr-x 6 root root    4096 Jan 29 07:09 apt
   drwxr-xr-x 2 root root    4096 Jan 26 22:10 at-spi2
   -rw-r----- 1 root daemon   144 Oct 21  2013 at.deny
   -rw-r--r-- 1 root root    2177 Apr  9  2014 bash.bashrc
   -rw-r--r-- 1 root root      45 Mar 22  2014 bash_completion
……………
……………

डिस्क उपयोग दिखाएँ

नमक एक विशेष मॉड्यूल प्रदान करता है, diskप्रबंधित सिस्टम का पूरा डिस्क विवरण प्राप्त करने के लिए। diskmodule एक usage विवरण क्वेरी करने के लिए कार्य करते हैं।

salt '*' disk.usage

यह निम्नलिखित उत्पादन करेगा output -

minion1:
   ----------
   /:
      ----------
      1K-blocks:
         41251136
      available:
         37852804
      capacity:
         5%
      filesystem:
         /dev/sda1
      used:
         1662420
   /dev:
      ----------
      1K-blocks:
         503908
      available:
         503896
      capacity:
         1%
      filesystem:
         udev
      used:
         12
   /run:
      ----------
      1K-blocks:
         101780
      available:
         101412
      capacity:
         1%
      filesystem:
         tmpfs
      used:
         368
   /run/lock:
      ----------
      1K-blocks:
         5120
      available:
         5120
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /run/shm:
      ----------
      1K-blocks:
         508884
      available:
         508872
      capacity:
         1%
      filesystem:
         none
      used:
         12
   /run/user:
      ----------
      1K-blocks:
         102400
      available:
         102400
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /sys/fs/cgroup:
      ----------
      1K-blocks:
         4
      available:
         4
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /vagrant:
      ----------
      1K-blocks:
         303114632
      available:
         252331440
      capacity:
         17%
      filesystem:
         none
      used:
         50783192
minion2:
   ----------
   /:
      ----------
      1K-blocks:
         41251136
      available:
         37852804
      capacity:
         5%
      filesystem:
         /dev/sda1
      used:
         1662420
   /dev:
      ----------
      1K-blocks:
         503908
      available:
         503896
      capacity:
         1%
      filesystem:
         udev
      used:
         12
   /run:
      ----------
      1K-blocks:
         101780
      available:
         101412
      capacity:
         1%
      filesystem:
         tmpfs
      used:
         368
   /run/lock:
      ----------
      1K-blocks:
         5120
      available:
         5120
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /run/shm:
      ----------
      1K-blocks:
         508884
      available:
         508872
      capacity:
         1%
      filesystem:
         none
      used:
         12
   /run/user:
      ----------
      1K-blocks:
         102400
      available:
         102400
      capacity:
         0%
      filesystem:
         none
      used:
            0
   /sys/fs/cgroup:
      ----------
      1K-blocks:
         4
      available:
         4
      capacity:
         0%
      filesystem:
         none
      used:
         0
   /vagrant:
      ----------
      1K-blocks:
         303114632
      available:
         252331440
      capacity:
         17%
      filesystem:
         none
      used:
         50783192

नेटवर्क इंटरफेस

नमक एक अलग मॉड्यूल, नेटवर्क और फ़ंक्शन प्रदान करता है, प्रबंधित सिस्टम के बारे में नेटवर्क इंटरफ़ेस जानकारी को क्वेरी करने के लिए मॉड्यूल के अंदर इंटरफेस।

salt '*' network.interfaces

यह निम्नलिखित उत्पादन करेगा output -

minion1:
   ----------
   eth0:
      ----------
      hwaddr:
         08:00:27:04:3e:28
      inet:
         |_
            ----------
            address:
               10.0.2.15
            broadcast:
               10.0.2.255
            label:
               eth0
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe04:3e28
            prefixlen:
               64
            scope:
               link
      up:
         True
   eth1:
      ----------
      hwaddr:
         08:00:27:34:10:52
      inet:
         |_
            ----------
            address:
               192.168.50.11
            broadcast:
               192.168.50.255
            label:
               eth1
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe34:1052
            prefixlen:
               64
            scope:
               link
      up:
         True
   lo:
      ----------
      hwaddr:
         00:00:00:00:00:00
      inet:
         |_
            ----------
            address:
               127.0.0.1
            broadcast:
               None
            label:
               lo
            netmask:
               255.0.0.0
      inet6:
         |_
            ----------
            address:
               ::1
            prefixlen:
               128
            scope:
               host
      up:
         True
minion2:
   ----------
   eth0:
      ----------
      hwaddr:
         08:00:27:04:3e:28
      inet:
         |_
            ----------
            address:
               10.0.2.15
            broadcast:
               10.0.2.255
            label:
               eth0
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fe04:3e28
            prefixlen:
               64
            scope:
               link
      up:
         True
   eth1:
      ----------
      hwaddr:
         08:00:27:a7:31:8e
      inet:
         |_
            ----------
            address:
               192.168.50.12
            broadcast:
               192.168.50.255
            label:
               eth1
            netmask:
               255.255.255.0
      inet6:
         |_
            ----------
            address:
               fe80::a00:27ff:fea7:318e
            prefixlen:
               64
            scope:
               link
      up:
         True
   lo:
      ----------
      hwaddr:
         00:00:00:00:00:00
      inet:
         |_
            ----------
            address:
               127.0.0.1
            broadcast:
               None
            label:
               lo
            netmask:
               255.0.0.0
      inet6:
         |_
            ----------
            address:
               ::1
            prefixlen:
               128
            scope:
               host
      up:
         True

sys.doc निष्पादन मॉड्यूल

नमक कार्यों के लिए भेजा जा सकता है sys.docनिष्पादन मॉड्यूल। इसका उपयोग कमांड लाइन से सीधे किसी भी मॉड्यूल पर विवरण प्राप्त करने के लिए किया जाता है। नमक कार्य स्वयं-दस्तावेज हैं। सभी फ़ंक्शन प्रलेखन को sys.doc () फ़ंक्शन के माध्यम से मिनटों से पुनर्प्राप्त किया जा सकता है, जिसे नीचे परिभाषित किया गया है।

salt '*' sys.doc

एक फंक्शन कॉल के लिए तर्क

फ़ंक्शन कॉल के लिए अतिरिक्त डेटा प्रदान करने के लिए तर्क का उपयोग किया जाता है। एक सरल तर्क उदाहरण नीचे दिया गया है।

salt '*' sys.doc pkg.install

यहाँ, तर्क pkg.install विशिष्ट पैकेजों को स्थापित करने के लिए एक मॉड्यूल है।

पायथन फंक्शन

तर्क कार्य करने के लिए स्थान-सीमांकित पैरामीटर हैं। यह नीचे दिए गए तर्क के रूप में अजगर कोड को पारित करने की अनुमति देता है।

salt '*' cmd.exec_code python 'import sys;print sys.version'

यह निम्नलिखित उत्पादन करेगा output -

minion2:
   2.7.6 (default, Oct 26 2016, 20:30:19) 
   [GCC 4.8.4]
minion1:
   2.7.6 (default, Oct 26 2016, 20:30:19) 
   [GCC 4.8.4]

इसी तरह, आप वैकल्पिक कीवर्ड और का उपयोग कर सकते हैं YAML साथ ही प्रारूप।