उत्तर देने योग्य - समस्या निवारण

डिसएबल प्लेबुक की डिबगिंग के लिए सबसे आम रणनीतियाँ नीचे दिए गए मॉड्यूल का उपयोग कर रही हैं -

डिबग और रजिस्टर

ये दोनों अंसिबल में उपलब्ध मॉड्यूल हैं। डिबगिंग उद्देश्य के लिए, हमें दो मॉड्यूल का विवेकपूर्ण उपयोग करने की आवश्यकता है। उदाहरण नीचे प्रदर्शित किए गए हैं।

वर्बोसिटी का उपयोग करें

Ansible कमांड के साथ, कोई वर्बोसिटी स्तर प्रदान कर सकता है। आप वर्बोसिटी स्तर एक (-v) या दो (-v) के साथ कमांड चला सकते हैं।

महत्वपूर्ण बिंदु

इस खंड में, हम कुछ अवधारणाओं को समझने के लिए कुछ उदाहरणों से गुजरेंगे।

यदि आप एक तर्क को उद्धृत नहीं कर रहे हैं जो एक चर के साथ शुरू होता है। उदाहरण के लिए,

vars: 
   age_path: {{vivek.name}}/demo/ 
   
{{vivek.name}}

यह एक त्रुटि फेंक देगा।

समाधान

vars: 
   age_path: "{{vivek.name}}/demo/" – marked in yellow is the fix. 
 
How to use register -> Copy this code into a yml file say test.yml and run it  
--- 
#Tsting 
- hosts: tomcat-node 
   tasks: 
 
   - shell: /usr/bin/uptime 
      register: myvar 
      - name: Just debugging usage 
         debug: var = myvar

जब मैं कमांड कोड के माध्यम से इस कोड को चलाता हूं, तो मैं इसे दिखाने के लिए आउटपुट प्राप्त करता हूं।

यदि आप yaml देखते हैं, तो हमने कमांड के आउटपुट को एक चर में पंजीकृत किया है - myvar और सिर्फ आउटपुट प्रिंट किया।

पीले रंग के रूप में चिह्नित पाठ, हमें चर -myvar की संपत्ति के बारे में बताता है जिसका उपयोग आगे प्रवाह नियंत्रण के लिए किया जा सकता है। इस तरह हम उन गुणों के बारे में पता लगा सकते हैं जो एक विशेष चर के संपर्क में हैं। निम्नलिखित डिबग कमांड इसमें मदद करता है।

$ ansible-playbook -i hosts test.yml 

PLAY [tomcat-node] ***************************************************************
**************** ****************************************************************
*************** ****************************** 
 
TASK [Gathering Facts] *****************************************************************
************** *****************************************************************
************** ************************** 
Monday 05 February 2018  17:33:14 +0530 (0:00:00.051) 0:00:00.051 ******* 
ok: [server1] 
 
TASK [command] ******************************************************************
************* ******************************************************************
************* ********************************** 
Monday 05 February 2018  17:33:16 +0530 (0:00:01.697) 0:00:01.748 ******* 
changed: [server1] 
 
TASK [Just debugging usage] ******************************************************************
************* ******************************************************************
************* ********************* 
Monday 05 February 2018  17:33:16 +0530 (0:00:00.226) 0:00:01.974 ******* 
ok: [server1] => { 
   "myvar": { 
      "changed": true, 
      "cmd": "/usr/bin/uptime", 
      "delta": "0:00:00.011306", 
      "end": "2018-02-05 17:33:16.424647", 
      "rc": 0, 
      "start": "2018-02-05 17:33:16.413341", 
      "stderr": "", 
      "stderr_lines": [], 
      "stdout": " 17:33:16 up 7 days, 35 min,  1 user,  load average: 0.18, 0.15, 0.14", 
      "stdout_lines": [ 
         " 17:33:16 up 7 days, 35 min,  1 user,  load average: 0.18, 0.15, 0.14" 
      ] 
   } 
} 
 
PLAY RECAP ****************************************************************************
**********************************************************************************
 ************************************** 
server1 : ok = 3    changed = 1    unreachable = 0    failed = 0

आम Playbook मुद्दे

इस खंड में, हम कुछ सामान्य प्लेबुक मुद्दों के बारे में जानेंगे। मुद्दे हैं -

  • Quoting
  • Indentation

Playbook को yaml format में लिखा गया है और उपरोक्त दोनों yaml / playbook में सबसे आम मुद्दे हैं।

यमल टैब आधारित इंडेंटेशन का समर्थन नहीं करता है और अंतरिक्ष आधारित इंडेंटेशन का समर्थन करता है, इसलिए किसी को उसी के बारे में सावधान रहने की आवश्यकता है।

Note - एक बार जब आप yaml लिखने के साथ कर रहे हैं, तो इस साइट को खोलें (https://editor.swagger.io/) और यम को ठीक से संकलित करने के लिए अपने यम्ल को बायीं ओर पेस्ट करें। यह सिर्फ एक टिप है।

स्वैगर चेतावनी के साथ-साथ त्रुटि में भी योग्यता प्राप्त करता है।