demo 环境

安装 virtualBox和vagrant

  1. 安装工具包:virtualBox, vagrant
  2. 下载 https://github.com/UtahDave/salt-vagrant-demo,download zip或者clone项目。

    进入目标文件夹,启动
  1. cd %homepath%\Downloads\salt-vagrant-demo-master
  2. cd ~\Downloads\salt-vagrant-demo-master
  3. vagrant up

vagrant的使用

  1. 中止vagrant
  2. vagrant halt
  3. vagrant destroy # 关闭
  4. vagrant up # 启动

安装SaltStack

  • 可以使用pip,source code,或者bootstrap 脚本来安装
  • salt 也提供了用于创建机器,在共有或者私有云上安装salt的工具。salt在物理上,云和虚拟环境上的使用都是一样的。

如果用的是salt,vagrant,按照上面的操作步骤,就已经安装好了;如果不是上述环境,bootstrap脚本是最简单的安装方式。

接收连接

salt master和salt minion之间的连接使用秘钥。

cd 到 vagrant-demo-master目录下,执行如下命令,进入到salt master

  1. vagrant ssh master
  2. sudo su # 切到root用户
  3. #登录之后,可以看到salt minion机器的连接情况
  4. salt-key --list-all
  5. # 接受一个key
  6. salt-key --accept=<key>
  7. # 接受所有的key
  8. salt-key --accept-all
  9. # 发送命令
  10. 确认salt minion是否在监听命令
  11. salt '*' test.ping

执行命令

运行shell命令

  1. salt '*' cmd.run 'ls -l /etc'

命令语法

  1. salt '*' pgk.install cowsay
  2. # '*'是target minion, pgk.install 是 module.function ; cowsay是arguments;'*' 将匹配所有的minion机器
  3. # 使用目标机器过滤
  4. salt '*' sys.doc
  5. salt '*' sys.doc pkg
  6. salt '*' sys.doc pkg.install
  7. salt '*' disk.usage # 查看磁盘使用情况
  8. salt '*' network.interfaces # list network interfaces

Targeting 指定执行命令的salt minion机器

  • 直接指定某个,或某几个minion机器,支持正则
  1. salt -E 'minion[0-9]' test.ping
  • 使用grains系统
  1. salt -G 'os:Ubuntu' test.ping

grains用于收集操作系统数据,如域名,ip, kernal, os 类型,以及其它属性

可以自定义grain,放在salt master的/etc/salt/grains下,或者放在salt minion的配置文件的grains 文件夹下。

grains.ls 用于列出minion上所有的grains机器。

grains的名字都是小写

  • minion list,使用逗号隔开
  1. salt -L 'minion1,minion2' test.pinghttps://docs.saltstack.com/en/getstarted/fundamentals/states.html
  • 以上几种方式结合使用
  1. salt -C 'G@os:Ubuntu and minion* or S@192.168.50.*' test.ping

Create Salt State

  • sate 是可复用的配置模板

    一个任务可能是由多个命令组合成的,这些命令要在不同的salt minion上执行,而对于不同的minon机器而言,每个命令都有细微的差别,错误也不一样。为了解决这样的问题,salt的配置管理提供了可服用的模板,一个模板成为一个state,可以把系统组件或者应用放入一个配置中。

  • state 是用yaml来描述的

    /srv/salt maps 本地目录:salt-vagrant-demo-master/saltstack/salt

    可以使用本地编辑器,然后保存在本地文件系统中,vagrant呈现出来的就是感觉像是在salt master上操作一样

  • 编辑如下文件

  1. install_network_packages:
  2. pkg.installed:
  3. - pkgs:
  4. - rsync
  5. - lftp
  6. - curl
  • 保存至demo-master/saltstack/salt/nettools.sls
  • salt master 上应用这个文件,执行命令
  1. salt 'minion2' state.apply nettools
  2. # state.apply 添加于2015.5, 之前的版本调用 state.sls
  • salt minion上发布:
  1. salt minion2 state.sls nettools

发布过之后,在没有更新的情况下再次发布,会提示没有任何更新,保持了幂等性。

更新之后,state会重启服务,copy所有的路径,直接让其他states先使用变量,先运行。

专业术语

  • formula

    salt state 和salt pillar文件的集合,用于配置一个应用或者系统组件。大多数fomulas是由若干个设计多个salt sate 文件的salt state构成

  • state

    可复用的声明,配置系统的某个部分。每个sate的定义都会使用sate 声明

  • sate 声明

    state file的高级部分,列出了构成state的 函数调用和参数。每个声明都用一个唯一ID开头

  • state 函数

    用于调用执行系统配置任务的命令

  • state file

    sls文件,包括一个或多个声明

  • pillar file

    sls文件,用于定义系统中的用户的变量和数据的

  • state 函数

    salt.state.* 开头的函数

    https://docs.saltstack.com/en/latest/salt-modindex.html#cap-s salt state函数文件

  • yaml 自己的标记语言

    salt使用yaml描述配置

    使用固定的缩进模式,来呈现数据层级之间的关系。salt要求每层开头有两个空行,不是tab。

    破折号代表list中的一个item

    键值对的表示形式key:value

  • 执行顺序

    命令的执行顺序是从上到下。salt提供了可以设置执行顺序的方法,后面介绍。

Apply and Target State

  • github formulas仓库
  • 批量更新,限制每次更新的salt minon的数量 salt --batch-size 10 '*' state.apply
  • salt state中不包括应该接收配置的salt minion的信息, salt state只定义salt minion如何接收配置。
  • top file,定义在哪儿应用states
  • states和top file一起创建saltstack的核心配置。

关于top file

  • highstate,会引发所有的目标 minion机器下载 /srv/salt/top.sls文件,找到匹配的目录。如果找到了 匹配的,minon会应用目录下列出的所有的state 文件。很多用户会规律地执行highstate,保证系统正常
  • top file 用于在highstate期间,使得salt minion应用多个state文件。minion使用哪个sate file,sate file的路径会在top file中列出来。
  • top file示例:
  1. All:
  2. - vim
  3. - script dir
  4. - Admin assts
  5. Web servers:
  6. - apache
  7. - python
  8. - django
  9. db server:
  10. - mysql
  11. 转换为top.sls
  12. base:
  13. '*'
  14. - vim
  15. - script dir
  16. - Admin assts
  17. '*web*':
  18. - apache
  19. - python
  20. - jango
  21. '*db*':
  22. - mysql
  23. base:
  24. '*':
  25. - common
  26. 'minion1':
  27. - nettools
  28. 将这个部署
  29. salt '*' state.apply
  30. #calling state.apply with no arguments starts a highstate.
  31. 结果就是,minion1上安装ntetools

salt demo 环境的更多相关文章

  1. Marketing Cloud demo环境和API使用方法说明

    version 1.0 作者:Wang Jerry 更多问题请联系我 demo 系统url:https:/jerry.hybris.com/sap/bc/ui5_ui5/ui2/ushell/shel ...

  2. [整]Android SlidingMenu Demo 环境搭建

    1. 下载ActionBarSherlock https://github.com/JakeWharton/ActionBarSherlock 2. 下载SlidingMenu https://git ...

  3. 第7篇 ORACLE EBS DEMO虚拟机环境的安装

    ERP信息系统的实施不仅要求懂得道理方面的知识,更要侧重于应用实践.为了有一个稳定的测试环境.初学者可以自己搭建一个EBS DEMO环境.本节介绍EBS DEMO环境虚拟机的安装.一. 安装前的准备( ...

  4. 打造高效前端工作环境-tmuxinator

    前言  虽然tmux能让我们方便组织工作环境,但每次重新打开会话时都需要手动重新创建窗口.窗格和执行各种程序,能不能像VS那样以工程为单位保存窗口.窗格和各种所需执行的程序的信息呢?tmuxinato ...

  5. Microsoft Dynamics AX 7 新特性探索 - Demo 部署(Part 1)

    Dynamics AX 7已经发布了一段时间了,我们知道这次微软为我们带来了许多令人激动的新特性.在这个系列里,Reinhard将揭开New Dynamics AX的神秘面纱,和大家一起探索这些新的特 ...

  6. grunt使用小记之uglify:最全的uglify使用DEMO

    grunt-contrib-uglify uglify是一个文件压缩插件,项目地址:https://github.com/gruntjs/grunt-contrib-uglify 本文将以一个DEMO ...

  7. Dll学习二_Dll 窗体中动态创建数据并使用Demo

    沿用上一篇Demo 环境:DelphiXE,XP,SQL2005 贴出改动过的单元代码: dbGrid控件版: unit SubMain_Unit; interface uses Windows, M ...

  8. 在xcode上搭建OpenGL3.x运行环境

    最近开始学习OpenGL,网上的教程太散乱,于是打算照着红宝书<OpenGL编程指南(第七版)>来学习. 于是在Mac上搭建一下Demo环境.比较方便的是,OS X上已经装了OpenGL ...

  9. 安装Rocky版OpenStack 1控制节点+1计算节点环境部署脚本

    在上一篇文章中叙述了具体的安装部署过程,在这里把相应的部署脚本写出来,供大家参考: 一.执行部署的setup.sh脚本: #!/bin/bash ########################### ...

随机推荐

  1. Xposed截获 Android手机QQ密码

    0x00 前言 Xposed框架是一款修改系统框架服务的软件,通过它许多功能强大的模块得以实现,且不冲突地同时运作,自从Xposed框架发布以来,安卓手机的可玩性日益激增,最近很闲很蛋疼,研究下截获A ...

  2. Python基础学习之序列(1)

    序列 序列类型有着相同的访问模式:它的每一个元素可以通过指定一个偏移量的方式得到.而多个元素可以通过切片操作的方式一次得到,下标偏移量是从0开始到总元素-1结束,之所以要减1是因为我们是从0开始计数的 ...

  3. Js arguments.callee();函数自己调用自己

    1.阶乘的时候,函数一般要用到递归算法,所以函数内部一定会调用自身 //递归,阶乘 function sum(num){ ) { ; } else{ ); //自己调用自己,递归 } } alert( ...

  4. phpStudy-FTP_Server插件安装使用教程

    FileZilla Server使用教程 ftp server安装教程 除了phpStudy for IIS外其他版本phpStudy不再集成ftp server外. phpStudy for IIS ...

  5. EF写INNER JOIN 链接

    面对多表的查询,一般都是多表连接后下面再写条件,但是有一种写法可以提升一下EF生成的语句的效率 首先先去查询每一个表,把每一个表对应的条件附加上去,注意:过滤数据最多的条件放在首先位置 var lt ...

  6. redis 有序集合类型

  7. getnumdevices.c && setgetdevicetype例程

    getnumdevices.c代码 /* 文件名: getnumdevices.c * 功能 : 测试函数acc_get_num_devices(.) */ #include<stdio.h&g ...

  8. Windows核心编程-作业

    原文链接:http://zhujiangtao.com/?p=983 作业 作业 一个简单例程 CreateJobObject 创建作业 作业限制和 SetInformationJobObject A ...

  9. 【JS-Java-EL】JavaScript和Java(EL表达式)引发的 Uncaught SyntaxError: Unexpected token ILLEGAL

    2018.10.14 BUG原因: 在较早期的代码中,容易出现 JS 拼接 HTML 代码字符串的情况.如 // 页面 test.jsp 内部的 JS 代码 // ${} JSP中EL语法,内部为Ja ...

  10. OpenFire通过User Service管理用户

    安装OpenFire服务器略去 1.安装User Service插件: 在管理控制平台找到选项卡“插件”,里边有我们需要安装的一个User Service插件,如果安装过了会显示已经安装的哪些插件,没 ...