Ansible 小手冊系列 三(命令介紹)

Ansible 版本:2.1.2.0

ansible


ansible是指令核心部分,其主要用于執(zhí)行ad-hoc命令,即單條命令。默認后面需要跟主機和選項部分,默認不指定模塊時,使用的是command模塊。

Usage: ansible <host-pattern> [options]

選項:

參數(shù) 說明
-a MODULE_ARGS, --args=MODULE_ARGS 模塊的參數(shù)。
--ask-vault-pass vault 密碼。
-B SECONDS, --background=SECONDS 異步運行時,多長時間超時。
-C, --check 只是測試一下會改變什么內(nèi)容,不會真正去執(zhí)行;相反,試圖預測一些可能發(fā)生的變化。
-D, --diff 當更改文件和模板時,顯示這些文件得差異,比--check效果好。
-e EXTRA_VARS, --extra-vars=EXTRA_VARS 添加附加變量,比如key=value,yaml,json格式。
-f FORKS, --forks=FORKS 指定定要使用的并行進程數(shù),默認為5個。
-h, --help 顯示此幫助信息。
-i INVENTORY, --inventory-file=INVENTORY 指定主機清單文件或逗號分隔的主機,默認為/etc/ansible/hosts。
-l SUBSET, --limit=SUBSET 進一步限制所選主機/組模式,只執(zhí)行-l 后的主機和組。
--list-hosts 輸出匹配主機的列表。
-m MODULE_NAME, --module-name=MODULE_NAME 要執(zhí)行的模塊,默認為command。
-M MODULE_PATH, --module-path=MODULE_PATH 要執(zhí)行的模塊的路徑。
--new-vault-password-file=NEW_VAULT_PASSWORD_FILE 新vault密鑰文件。
-o, --one-line 壓縮輸出,摘要輸出.嘗試一切都在一行上輸出。
--output=OUTPUT_FILE 加密或解密輸出文件名 用于標準輸出。
-P POLL_INTERVAL, --poll=POLL_INTERVAL 如果使用-B,則設置輪詢間隔。
--syntax-check 對playbook進行語法檢查,且不執(zhí)行playbook。
-t TREE, --tree=TREE 將日志內(nèi)容保存在該目錄中,文件名以執(zhí)行主機名命名。
--vault-password-file=VAULT_PASSWORD_FILE vault密碼文件
-v, --verbose 輸出執(zhí)行的詳細信息,使用-vvv獲得更多,-vvvv 啟用連接調(diào)試
--version 顯示程序版本號

連接選項:

參數(shù) 說明
-k, --ask-pass 要求用戶輸入請求連接密碼
--private-key=PRIVATE_KEY_FILE, --key-file=PRIVATE_KEY_FILE 私鑰路徑,使用這個文件來驗證連接
-u REMOTE_USER, --user=REMOTE_USER 連接用戶
-c CONNECTION, --connection=CONNECTION 連接類型,默認smart
-T TIMEOUT, --timeout=TIMEOUT 指定默認超時時間,默認是10S
--ssh-common-args=SSH_COMMON_ARGS 指定要傳遞給sftp / scp / ssh的常見參數(shù) (例如 ProxyCommand)
--sftp-extra-args=SFTP_EXTRA_ARGS 指定要傳遞給sftp,例如-f -l
--scp-extra-args=SCP_EXTRA_ARGS 指定要傳遞給scp,例如 -l
--ssh-extra-args=SSH_EXTRA_ARGS 指定要傳遞給ssh,例如 -R

特權(quán)升級選項:

參數(shù) 說明
-s, --sudo 使用sudo (nopasswd)運行操作 , 不推薦使用
-U SUDO_USER, --sudo-user=SUDO_USER sudo 用戶,默認為root, 不推薦使用
-S, --su 使用su運行操作, 不推薦使用
-R SU_USER, --su-user=SU_USER su 用戶,默認為root,不推薦使用
-b, --become 運行操作
--become-method=BECOME_METHOD 權(quán)限升級方法使用 ,默認為sudo,有效選擇:sudo,su,pbrun,pfexec,runas,doas,dzdo
--become-user=BECOME_USER 使用哪個用戶運行,默認為root
--ask-sudo-pass sudo密碼,不推薦使用
--ask-su-pass su密碼,不推薦使用
-K, --ask-become-pass 權(quán)限提升密碼

示例:

ansible all -m ping
ansible 192.168.77.* -m ping
ansible all -m command -a ifconfig
ansible all -m shell -a "ifconfig eth0 |grep 'inet addr' "
ansible -i "192.168.77.129,192.168.77.130" 192.168.77.129  -m ping
ansible -i hosts  all --list-host
ansible -i hosts -l 192.168.77.130 all -m ping -t /tmp -vvvv
ansible web -l @retry_hosts.txt --list-hosts

ansible-console


交互式命令執(zhí)行界面

Usage: ansible-console <host-pattern> [options]

選項與ansible一致

ansible-doc


該指令用于查看模塊信息,常用參數(shù)有兩個-l-s

Usage: ansible <host-pattern> [options]

選項

參數(shù) 說明
-h, --help 顯示此幫助信息
-l, --list 列出可用的模塊
-M MODULE_PATH, --module-path=MODULE_PATH 指定到模塊庫的路徑
-s, --snippet 顯示playbook制定模塊的用法
-v, --verbose 詳細模式(-vvv表示更多,-vvvv表示啟用連接調(diào)試)
--version 顯示程序版本號

示例:

ansible-doc -l
ansible-doc yum
ansible-doc yum -s

ansible-galaxy


ansible-galaxy 指令用于方便的從 https://galaxy.ansible.com/ 站點下載第三方擴展模塊,我們可以形象的理解其類似于centos下的yum、python下的pip或easy_install

Usage: ansible-galaxy [delete|import|info|init|install|list|login|remove|search|setup] [--help] [options] …

示例:

ansible-galaxy install aeriscloud.docker  # 下載
ansible-galaxy  init abc   # 創(chuàng)建角色模板

ansible-playbook


對于需反復執(zhí)行的、較為復雜的任務,我們可以通過定義 Playbook 來搞定。Playbook 是 Ansible 真正強大的地方,它允許使用變量、條件、循環(huán)、以及模板,也能通過角色 及包含指令來重用既有內(nèi)容。

Usage: ansible-playbook playbook.yml

相對于ansible,增加了下列選項:

參數(shù) 說明
--flush-cache 清除fact緩存
--force-handlers 如果任務失敗,也要運行handlers
--list-tags 列出所有可用的標簽
--list-tasks 列出將要執(zhí)行的所有任務
--skip-tags=SKIP_TAGS 跳過運行標記此標簽的任務
--start-at-task=START_AT_TASK 在此任務處開始運行
--step 一步一步:在運行之前確認每個任務
-t TAGS, --tags=TAGS 只運行標記此標簽的任務

示例:

ansible-playbook -i hosts ssh-addkey.yml    # 指定主機清單文件
ansible-playbook -i hosts ssh-addkey.yml  --list-tags   # 列出tags
ansible-playbook -i hosts ssh-addkey.yml  -T install  # 執(zhí)行install標簽的任務

ansible-pull


pull模式在被配置的機器上運行,速度很快。在這種模式下,你需要提供一個git倉庫來供Ansible下載來配置你的機器。

Usage: ansible-pull -U <repository> [options]

ansible-vault


ansible-vault主要應用于配置文件中含有敏感信息,又不希望他能被人看到,vault可以幫你加密/解密這個配置文件。這種playbook文件在執(zhí)行時,需要加上 –ask-vault-pass參數(shù),同樣需要輸入密碼后才能正常執(zhí)行。

Usage: ansible-vault [create|decrypt|edit|encrypt|rekey|view] [--help] [options] vaultfile.yml

示例:

ansible-vault create /tmp/123 # 創(chuàng)建加密文件
ansible-vault view  /tmp/123 # 查看加密文件
ansible-vault encrypt  /tmp/abc # 加密文件
ansible-vault decrypt  /tmp/abc # 解密文件

更多文章請看 Ansible 專題文章總覽

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,117評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,860評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,128評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,291評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,025評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,421評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,477評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,642評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,177評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,970評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,157評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,717評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,410評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,821評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,053評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,896評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,157評論 2 375

推薦閱讀更多精彩內(nèi)容

  • ansible 系統(tǒng)架構(gòu) ansible簡介ansible是新出現(xiàn)的自動化運維工具,ansible是一個配置管理和...
    運維阿文閱讀 9,659評論 1 52
  • 1. Ansible程序目錄功能介紹 rpm -ql ansible 通過如上命令可獲取ansible所有文件存放...
    stanleylst閱讀 2,669評論 3 16
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,806評論 18 139
  • 簡介 ansible是一個簡單的it自動化工具,可以實現(xiàn)批量進行系統(tǒng)配置,軟件部署和運行命令等功能。基于pytho...
    clickdiff閱讀 738評論 0 1
  • 我種的花慢慢的發(fā)芽, 我默許的話全給了它。 我給他講, 你是太陽的孩子, 你來自遙遠的南美, 沐浴著珠峰的凈水, ...
    田靜海閱讀 748評論 2 8