- 前言
- Ansible 是什么?
- 怎么部署 Ansible 环境?
- 怎么用 Vagrant 练习 Ansible?
- 怎么用 Docker 练习 Ansible?
- 怎么操作 Ansible?
- 怎么用 Jupyter 操控 Ansible?(localhost)
- 怎么用 Jupyter 操控 Ansible?(Managed node)
- 怎么用 Docker Compose 练习 Ansible?
- Ansible 的开发工具有哪些?
- 怎么看 Ansible Modules 文件?
- 常用的 Ansible Module 有哪些?
- 怎么使用 setup 取得 Managed node 的 facts?
- 怎么使用 Ansible 的 Template 系统?
- 怎么在 Playbooks 里使用 Handlers?
- Ansible 如何发送 notification 到 Slack?
- Ansible 如何发送 notification 到 HipChat?
- 如何在 Playbooks 使用 loops?
- 如何维护大型的 Playbooks?
- Roles 是什么?
- 怎么使用 Roles?
- 怎么用 Roles 部署 LNMP 网页应用程式?(上)
- 怎么用 Roles 部署 LNMP 网页应用程式?(下)
- 怎么用 Roles 部署 TestLink?
- 怎么在 Ansible Galaxy 分享 Roles?(上)
- 怎么在 Ansible Galaxy 分享 Roles?(下)
- 怎么用 Travis CI 测试 Roles?
- 怎么混用 Ansible 建置 Docker image?
- 怎么在 Docker Hub 混用 Ansible 自动建置 Docker image?
- 怎么用 Vault 管理敏感资料?
- 总结
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
怎么在 Ansible Galaxy 分享 Roles?(下)
現代 IT 人一定要知道的 Ansible 自動化組態技巧
26. 怎麼在 Ansible Galaxy 分享 Roles?(下)
上一章「25. 怎麼在 Ansible Galaxy 分享 Roles?(上)」,我們幫 Role 補充了 Galaxy 網站所需的資訊,接下來就是把它分享到 Galaxy 上了!
怎麼上傳 Roles 到 GitHub?
先前在「21. 怎麼使用 Roles?」一章曾提過,Galaxy 裡的 Roles 其實是存在 GitHub 上的。
- 在 GitHub 建立一個 Repository (儲存庫) 1,官方建議使用
ansible-role-acme
的格式進行命名。 把寫好的 Roles 加入 Git 版本控制裡。
$ git commit -a $ git push
藉由 Git 從本地 (Local) 把 Roles 上傳至 GitHub。
- 若對 Git 和 GitHub 不熟,可參考凍仁先前寫的 Git and Github basic with SourceTree 簡報。
怎麼在 Galaxy 匯入 Roles?
進入 Galaxy 網站,並點擊右上角的 SIGN IN。
使用 GitHub OAuth 登入 Galaxy 網站。
進入 My Roles 頁面,並點選左方按鈕啟用 Roles,完成後將顯示 ✔。
當 Roles 太多時,可藉由右方的搜尋框進行過濾。
啟用 Role 後,點擊右方的 Import Role 圖示進行匯入。
匯入成功後將顯示 Succeeded,點擊 Succeeded 即可觀看這次匯入的相關資訊。
我們可藉由此頁面檢查 Meta Data (
meta/main.yml
) 的設定是否有誤。若想自訂 Role name,可透過 Role Settings 進行更改。
以上,現在我們可以在 https://galaxy.ansible.com/chusiang/testlink/ 看到剛匯入的 Role,其中 chusiang
為 username,testlink
為 role name,而完整名稱則是 chusiang.testlink
。
後語
寫完複雜 Playbooks,我們只需再費點工夫就可以在 Galaxy 上與全世界分享了!
相關連結
1. 若不會在 GitHub 上建立 Repository,可參考 Create A Repo | GitHub 一文。 ↩
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论