opensuse/salt-mastersalt-master镜像是包含SaltStack主节点组件的Docker镜像。salt-master是SaltStack自动化平台的核心控制节点,负责与minion节点建立通信,集中管理配置分发、远程命令执行、状态管理和事件监控等任务,是实现服务器集群自动化运维的关键组件。
salt命令向指定minion节点或节点组发送并执行命令cp.get_file等模块向minion节点分发配置文件、脚本等资源bashdocker run -d \ --name salt-master \ -p 4505:4505 \ # ZeroMQ发布端口(minion订阅) -p 4506:4506 \ # ZeroMQ请求端口(minion请求) -v /path/to/salt/config:/etc/salt \ # 挂载配置目录 -v /path/to/salt/pki:/etc/salt/pki \ # 挂载PKI证书目录(持久化认证信息) salt-master
核心配置文件路径:/etc/salt/master(容器内路径),建议通过数据卷挂载自定义配置。常用配置项:
interface:绑定的网络接口(默认0.0.0.0)publish_port:发布端口(默认4505)ret_port:请求端口(默认4506)timeout:与minion通信超时时间(默认5秒)fileserver_backend:文件服务器后端(如roots、git等)| 宿主机路径 | 容器内路径 | 用途说明 |
|---|---|---|
/path/to/salt/config | /etc/salt | 存储自定义配置文件(master配置、State文件等) |
/path/to/salt/pki | /etc/salt/pki | 存储master与minion的证书和密钥(必须持久化) |
/path/to/salt/cache | /var/cache/salt | 缓存目录(可选,提升性能) |
yamlversion: '3' services: salt-master: image: salt-master container_name: salt-master ports: - "4505:4505" - "4506:4506" volumes: - ./salt/config:/etc/salt - ./salt/pki:/etc/salt/pki - ./salt/cache:/var/cache/salt restart: unless-stopped networks: - salt-network networks: salt-network: driver: bridge
查看运行状态:
bashdocker logs salt-master # 查看日志 docker exec -it salt-master salt-key -L # 列出已认证/未认证的minion
认证minion节点:
bashdocker exec -it salt-master salt-key -a minion-id # 接受指定minion docker exec -it salt-master salt-key -A # 接受所有未认证minion
执行远程命令:
bashdocker exec -it salt-master salt 'minion-id' test.ping # 测试minion连通性 docker exec -it salt-master salt '*' cmd.run 'uptime' # 向所有minion执行uptime命令
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务