zoukankan      html  css  js  c++  java
  • saltstack执行结果存储到MySQL

    saltstack执行结果保存到MySQL中,以便进行命令安全审
    必须是python2.7以上的环境
    安装相关模块
    ubuntu系统安装

    apt-get install -y python-mysqldb

    centos系统安装

    yum install -y MySQL-python
    

    数据库、相关表创建以及账户创建授权
    官网:https://docs.saltstack.com/en/latest/ref/returners/all/salt.returners.mysql.html#module-salt.returners.mysql

    CREATE DATABASE  `salt`
    DEFAULT CHARACTER SET utf8
    DEFAULT COLLATE utf8_general_ci;
    
    USE `salt`;
    CREATE TABLE `jids` (
      `jid` varchar(255) NOT NULL,
      `load` mediumtext NOT NULL,
      UNIQUE KEY `jid` (`jid`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    CREATE INDEX jid ON jids(jid) USING BTREE;
    
    CREATE TABLE `salt_returns` (
      `fun` varchar(50) NOT NULL,
      `jid` varchar(255) NOT NULL,
      `return` mediumtext NOT NULL,
      `id` varchar(255) NOT NULL,
      `success` varchar(10) NOT NULL,
      `full_ret` mediumtext NOT NULL,
      `alter_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
      KEY `id` (`id`),
      KEY `jid` (`jid`),
      KEY `fun` (`fun`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    CREATE TABLE `salt_events` (
    `id` BIGINT NOT NULL AUTO_INCREMENT,
    `tag` varchar(255) NOT NULL,
    `data` mediumtext NOT NULL,
    `alter_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    `master_id` varchar(255) NOT NULL,
    PRIMARY KEY (`id`),
    KEY `tag` (`tag`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    创建数据库账户以及授权

    grant all privileges on salt.* to salt@'localhost' identified by "xxxxxxxx";
    

    salt-master salt-minion端相关配置
    方法一
    在所有minion端配置添加数据库相关信息
    找到minion文件中的#return: mysql后面添加数据库相关信息
    #return: mysql
    mysql.host: '192.168.217.20'
    mysql.user: 'salt'
    mysql.pass: 'xxxxx'
    mysql.db: 'salt'
    mysql.port: 3306
    重启所以客户端

    方法二
    开启master端的master_job_cache,该方法就不需要再minion端配置数据库相关信息了,如果也配置了minion端数据库相关信息,那么执行结果将会在数据库中保存两份
    配置如下:

    #return: mysql
    master_job_cache: mysql
    mysql.host: '192.168.217.20'
    mysql.user: 'salt'
    mysql.pass: 'Wclwcw1101!'
    mysql.db: 'salt'
    mysql.port: 3306

    重启salt-master

  • 相关阅读:
    kill -3 导出 thread dump
    JVM中锁优化,偏向锁、自旋锁、锁消除、锁膨胀
    Hibernate validator验证
    java子类实例初始化过程
    spring- properties 读取的五种方式
    Spring连接数据库的几种常用的方式
    缓存使用中的注意事项
    java动态代理原理
    classpath目录
    springmvc常用注解标签详解
  • 原文地址:https://www.cnblogs.com/wclwcw/p/8427629.html
Copyright © 2011-2022 走看看