उत्तर देने योग्य - समस्या निवारण
डिसएबल प्लेबुक की डिबगिंग के लिए सबसे आम रणनीतियाँ नीचे दिए गए मॉड्यूल का उपयोग कर रही हैं -
डिबग और रजिस्टर
ये दोनों अंसिबल में उपलब्ध मॉड्यूल हैं। डिबगिंग उद्देश्य के लिए, हमें दो मॉड्यूल का विवेकपूर्ण उपयोग करने की आवश्यकता है। उदाहरण नीचे प्रदर्शित किए गए हैं।
वर्बोसिटी का उपयोग करें
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/) और यम को ठीक से संकलित करने के लिए अपने यम्ल को बायीं ओर पेस्ट करें। यह सिर्फ एक टिप है।
स्वैगर चेतावनी के साथ-साथ त्रुटि में भी योग्यता प्राप्त करता है।