• ansible自动化运维工具的安装与使用


    运行环境
    centOS6.6

    ansible

    ansible的功能还是比较多的,博主只用它在集群上进行批量部署软件和维护的功能,其他不多做研究,有需要的话这篇文章会慢慢补充。

    ansible特点

    • 轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
    • 批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
    • 使用python编写,维护更简单,ruby语法过于复杂;
    • 支持sudo。

    安装

    yum install ansible
    

    使用

    1. 配置ssh
      ansible是通过基于ssh实现的,我们先配置ssh无密码登录

      ssh-keygen
      ssh-copy-id -i ~/.ssh/id_rsa.pub user@dp0655
      ssh-copy-id -i ~/.ssh/id_rsa.pub user@dp0656
      ssh-copy-id -i ~/.ssh/id_rsa.pub user@dp0657
      
    2. 主机组定义
      这里定义了一个spark_test组

      vim /etc/ansible/hosts
      [spark_cluster]
      dp0655
      dp0656
      dp0657  
      
    3. 连通测试
      ansible all的意思是对/etc/ansible/hosts中的所有主机进行操作,我这只对spark_cluster组进行操作。

      #查看spark_cluster组中的主机
      ansible spark_cluster --list-hosts
      dp0655
      dp0656
      dp0657
      
      #测试是否连通
      ansible spark_cluster -m ping
      dp0657 | success >> {
      "changed": false, 
      "ping": "pong"
      }
      
      dp0656 | success >> {
      "changed": false, 
      "ping": "pong"
      }
      
      dp0655 | success >> {
      "changed": false, 
      "ping": "pong"
      }
      

    常用操作

    1. 用户和权限
      -u 指定运行的用户(默认为root)
      -s 使用sudo权限

      ansible spark_cluster -a "mkdir /usr/xx/xx" -s -u userName
      
    2. copy
      将本地文件/文件夹发送到远程主机,ansible的copy模块是围绕rsync的包装,所以它是增量而不是全量的拷贝。
      参数说明:
      src 本地文件/文件夹位置
      dest 发送到远程主机的位置
      owner(可选) 所属用户
      group(可选) 所属用户组
      mode(可选) 权限

    将本地文件/etc/ansible/ansible.cfg复制到远程服务器

    ansible spark_cluster -m copy -a "src=/etc/ansible/ansible.cfg dest=/tmp/ansible.cfg owner=admin group=admin mode=0644"
    1. 批量执行脚本
      在远程批量执行本地脚本

      ansible spark_cluster -m script -a "hello.sh"
      

    ansible的中文操作手册
    http://www.simlinux.com/books/Ansible-notes.pdf

  • 相关阅读:
    adb检测不到夜神模拟器
    夜神模拟器相关设置
    dos窗口下查看系统环境变量设置,输出dos命令结果到文件
    JavaScript DOM操作案例列表的高亮显示
    JavaScript DOM操作案例美女相册
    JavaScript DOM操作案例阻止超链接跳转
    JavaScript DOM操作案例点击按钮修改ul背景颜色
    Git 状态 untracked 和 not staged的区别
    GitPython模块简介
    解决error: failed to push some refs to 'xxxx'
  • 原文地址:https://www.cnblogs.com/xiaomaohai/p/6158058.html
Copyright © 2020-2023  润新知