设为首页 收藏本站
查看: 1985|回复: 0

[经验分享] linux自学笔记--ansible

[复制链接]

尚未签到

发表于 2018-7-29 09:41:30 | 显示全部楼层 |阅读模式
  1.密钥认证
  ssh-keygen -t rsa -C "xxx@xxx.com"
  ssh-copy-id -i .ssh/id_rsa.pub root@x.x.x.x
  2.并入管理组
  /etc/ansible/hosts
  [webserver]
  x.x.x.x
  [dbserber]
  x.x.x.x
  3.常用模块
  (1)ping: 主机探测,返回pong
  ansible all -m ping
  (2)command: 执行命令,不支持管道
  ansible all -m command -a "touch ./test"
  (3)shell: 执行命令,支持管道
  ansible all -m shell -a "cat /etc/passwd | grep root"
  (4)cron: 同时发布任务
  ansbile all -m cron -a  "minute|day|month|weekday|hour=*/5 job='/sbin/ntpdate    x.x.x.x &> /dev/null' name=time"
  (5)yum: 安装和卸载
  ansible all -m yum -a "name=pkname "
  ansbile all -m yum -a "name=pkname state=absent"
  (6)service: 启动和停止服务
  ansible all -m service -a "name=pkname            state=started|stopped"
  (7)copy: 赋值文件
  ansible all -m copy -a "src=/path/file dest=/path/file"
  ansible all -m copy -a "content='123' dest=/path/file"
  (8)user:
  ansible all -m user -a "name=user1 state=present|absent system=yes|no "
  4.playbook
  (1)创建xxx.yaml文件
  (2)编辑xxx.yaml
  - hosts: webserber
  remote_user: root
  tasks:
  - name: add user
  user: name=` item`.`name ` group=` item`.`group `
  with_items:
  - { name: "`name1`" group: "`group1`" }
  when: ansible_distribution_major_version=="7"
  - name: copy conf
  copy: src=/path/file dest=/path/file
  notify: copy conf
  tags: copy conf
  handlers:
  - name: copy conf
  service: name=httpd state=stopped
  (3)运行 ansible-play -t "copy conf" xxx.yaml
  5.传递参数
  (1)内置变量 ansible all -m step
  (2)写在hosts中
  [webserver]
  x.x.x.x 80
  x.x.x.x 8080
  (3)写在vars中
  vars:
  - username: "user1"
  - groupname: "group1"
  (4)调用roules时
  roles:
  - {role:test,name=magedu }
  (5)运行命令时传递
  ansible-plya -e "name=magedu age=99" xxx.yaml
  6.roles
  (1)创建/etc/ansible/roles/test
  (2)目录结构
  file: 存放copy文件
  template: 存在模板
  tasks: 必须有一个main.yml,其余可include进来
  handlers: 存放触发器,必须有一个mail.yml
  vars: 存放参数,不用加-,直接name=value
  meta: 特殊设定及其依赖关系
  default: 设定默认变量
  (3)写playbook,调用角色
  - hosts: all
  remote_user: root
  roles:
  - test

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-542858-1-1.html 上篇帖子: Ansible之Playbooks 下篇帖子: ansible(续一)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表