1. 安装

//salt-master安装(环境:OS-debian,IP-120.25.255.213)
# apt-get install -t jessie-backports salt-master
//salt-minion安装(环境:OS-debian,IP-192.168.36.44)
# apt-get install -t jessie-backports salt-minion

2. 接入

2.1 minion操作


# vi /etc/salt/minion             -- 编辑minion配置文件
    master: 120.25.255.213        -- 指定master地址
    id: test-36.44                -- minion ID标识
# service salt-minion restart     -- 重启服务

2.2 master操作

# salt-key -a test-36.44       -- accept minion
# salt '*' test.ping           -- 测试所有的minion是否正常接入
test-36.44:
    True                       -- test-36.44 接入成功

3. 操作

3.1 下推文件

# salt test-36.44 cp.get_file salt://agent.log /root/agent.log
PS:
  1). salt默认 file_roots 的目录是 /srv/salt,因此将 agent.log (准备下推的文件)放到 /srv/salt 目录下(支持文件夹)
  2). 若文件目录的格式不是 salt://,则 minion 端会报错(如下)
    specified file /var/log/agent.log is not present to generate hash: Unsupported path: /var/log/agent.log

4. 问题

4.1 由于证书导致的’No response’

master 端执行 salt ‘*’ test.ping,返回结果是 No response

查看 minion 端日志(/var/log/salt/minion),如下:

The Salt Master has cached the public key for this node, this salt minion will wait for 10 seconds before attempting to re-authenticate

出现这个问题的原因是,minion 之前接入到其他的 master,旧的证书被缓存

解决方法:

rm -rf /etc/salt/pki/minion/minion_master.pub  -- 删除证书
service salt-minion restart                    -- 重启minion

总结:换 master 时,不仅仅改 master 的地址,还要删除旧的证书

  • ipset

    ipset 安装参考文档(待整理)ipset 官方文档ipset 7.1版本链接使用参考文档 简单的流程可以用这几条命令概括使用 ipset 和 iptables 进行 IP 封禁的流程 ipset create blacklist ...

    ipset
  • 删除非目录文件

    linux 下删除一个目录下所有的隐藏文件和非目录文件 前言在 alpine 基础上编译 OpenWAF,想要达到最简,删除无用文件。 亮点rm -rf `ls -Fa | grep '^\.\w'` -- 删除隐...

    删除非目录文件
  • 在 alpine 上编译 openssl 遇到的问题

    alpine 上编译 openssl (v1.1.1) 遇到 ucontext 报错 前言今天在 alpine 基础上编译 openwaf,编到 openssl 时,报 ucontext 相关错误。 ucontext 报错编译 ope...

    在 alpine 上编译 openssl 遇到的问题
  • 批量修改或添加文件后缀名

    前言常见的是对不同文件名进行文件后缀名修改。但今天遇到同一文件名的情况。 常见windows 或 Linux 命令: ren *.jpg *.bmp # 将 jpg 后缀改为 bmp 如:1.jpg 2.txt 改后为:1.bm...

    批量修改或添加文件后缀名
  • hyperscan 安装

    1. 前言本文在 Debian8 中安装 hyperscan 5.0.0内存至少 2 G,不然编译慢而且失败 2. 依赖2.1 C/C++编译器hyperscan使用C++开发,且需要C99和C++11支持,目前支持的编译器有 GC...

    hyperscan 安装
  • linux 查看系统开机时间

    有时候需要查看Linux系统运行了多久时间,此时需要知道上次开机启动时间;有时候由于断电或供电故障突然停机,需要查看Linux开机时间/重启时间;下面总结一些查看Linux开机关机时间的方法(非常全面) 1. who 命令查看who ...

    linux 查看系统开机时间
  • GDB 多线程 (non-stop)

    1. 背景这几天在扩展 ngx_lua 模块,但 gdb 定位时,提示:Thread debugging using libthread_db enabled。 2. GDB non-stop 配置把以下3行添加到 ~/.gdbini...

    GDB 多线程 (non-stop)
  • suricata 从 0 开始

    背景OpenWAF 是在 openresty 基础上发布的,但安全不仅仅是针对 HTTP 协议的防护,而是全方位立体化的防护。因此,为了防护更多的协议,开始接触 suricata,用熟后,争取将 OpenWAF 集成到 suricat...

    suricata 从 0 开始
  • clear: command not found 命令无法找到

    1. 安装 ncurses-binsudo apt-get install ncurses-bin 此时尝试执行 ‘clear’ 命令,若失败,执行第二步(重新安装 ncurses-bin) 2. 重新安装 ncurses-binsu...

    clear: command not found 命令无法找到
  • svn 游记

    前言公司之前用 svn 管理项目代码,我一直用的 windows 版本 近期想要搭建知识库云平台,需要在 linux 上使用 svn 管理代码,因此做些笔记 直接使用公司搭建好的 svn服务器 1. 客户端安装yum install ...

    svn 游记