运维自动化工具 - SaltStack

一、概述

1.1 关于Salt

Salt 是:

1.2 Salt架构

Salt采用Client/Server架构。

1.3 Salt安装

Salt的安装比较简单,通过yum就可以直接安装。

1.3.1 CentOS7机器

Hostname IP 说明
peng-master-1 172.16.196.200 安装salt-master,salt-minion
peng-node-1 172.16.196.201 安装salt-minion
peng-node-2 172.16.196.202 安装salt-minion

1.3.2 安装epel源

[root@peng-master-1 ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
[root@peng-master-1 ~]# wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
[root@peng-master-1 ~]# yum clean all
[root@peng-master-1 ~]# yum makecache

1.3.3 Master节点安装

[root@peng-master-1 ~]# yum install -y salt-master

# 启动Master并设置开机启动(CentOS7)
[root@peng-master-1 ~]# systemctl start salt-master
[root@peng-master-1 ~]# systemctl enable salt-master

配置文件在/etc/salt/master

1.3.4 Node节点安装

[root@peng-node-1 ~]# yum install -y salt-minion

# 启动Minion并设置开机启动(CentOS7)
[root@peng-node-1 ~]# systemctl start salt-minion
[root@peng-node-1 ~]# systemctl enable salt-minion

配置文件在/etc/salt/minion

如果配置了阿里源还是找不到,可以按照官网的配置方式(CentOS7):https://repo.saltstack.com/#rhel

  1. Run the following commands to install the SaltStack repository and key:
   sudo yum install https://repo.saltstack.com/py3/redhat/salt-py3-repo-3002.el7.noarch.rpm 
  1. Run sudo yum clean expire-cache
  2. Install the salt-minion, salt-master, or other Salt components:

    • sudo yum install salt-master
    • sudo yum install salt-minion
    • sudo yum install salt-ssh
    • sudo yum install salt-syndic
    • sudo yum install salt-cloud
    • sudo yum install salt-api
  3. *(Upgrade only) Restart all upgraded services, for example:*

   sudo systemctl restart salt-minion

二、Salt配置

2.1 Master配置

grep -v ^# /etc/salt/master|grep -v ^$

2.2 Node配置

调整配置文件/etc/salt/minion,在Node节点中指定Master地址。

[root@peng-node-1 ~]# vi /etc/salt/minion

# Set the location of the salt master server. If the master server cannot be
# resolved, then the minion will fail to start.
#master: salt
master: 172.16.196.200

[root@peng-node-1 ~]# systemctl restart salt-minion

2.3 配置认证

Node节点配置master地址之后重启服务,在master通过salt-key就可以看到列表。

[root@peng-master-1 ~]# salt-key -L
Accepted Keys:
Denied Keys:
Unaccepted Keys:
peng-node-1
peng-node-2
Rejected Keys:

需要接受对应的KEY, 通过salt-key -h可以看到接受与拒绝,这里接受所有的KEY

[root@peng-master-1 ~]# salt-key -A
The following keys are going to be accepted:
Unaccepted Keys:
peng-node-1
peng-node-2
Proceed? [n/Y] Y
Key for minion peng-node-1 accepted.
Key for minion peng-node-2 accepted.

2.4 Salt测试

执行ping操作

[root@peng-master-1 ~]# salt '*' test.ping
peng-node-1:
    True
peng-node-2:
    True

远程执行命令

[root@peng-master-1 ~]# salt '*' cmd.run 'free -m'
peng-node-2:
                  total        used        free      shared  buff/cache   available
    Mem:            972         434          62           8         475         383
    Swap:             0           0           0
peng-node-1:
                  total        used        free      shared  buff/cache   available
    Mem:            972         415          89           8         467         402
    Swap:             0           0           0

三、 常用命令

3.1 基础命令

指定所有机器

# salt '*' cmd.run 'cp /etc/hosts /etc/hosts-$(date +%F)'

指定多个IP机器

# salt -L "127.0.0.1,128.0.0.1" cmd.run 'cat /etc/hosts | grep -E "127.0.0.1|128.0.0.1"'

指定设置好的组

# salt -N test cmd.run 'netstat -tlnp'

3.2 统计CPU

统计CPU核数

# salt '*' cmd.run 'cat /proc/cpuinfo| grep "processor"| wc -l'

统计peng分组下CPU空闲率

# 各台机器CPU空闲率,统计10次的平均CPU
$ salt -N peng cmd.run 'top -n 10 -b | grep "Cpu(s):" | awk -F "," "{print \$4}" | awk -F "%" "{a+=\$1}END{print a/10}"'

# 所有机器平均空闲率
$ salt -N peng cmd.run 'top -n 10 -b | grep "Cpu(s):" | awk -F "," "{print \$4}" | awk -F "%" "{a+=\$1}END{print a/10}"' | grep -v ":" | awk '{sum+=$1}END {print sum/NR}'

3.3 统计内存

统计内存大小

# salt '*' cmd.run 'cat /proc/meminfo | head -n 1'

统计peng分组下内存使用

# 各台机器的内存使用率
$ salt -N peng cmd.run 'free |head -n 2| tail -n 1' | grep Mem | awk '{print ($4+$6+$7)*100/$2}'

# 所有机器的内存使用率
$ salt -N peng cmd.run 'free |head -n 2| tail -n 1' | grep Mem | awk '{a+=$4;b+=$6;c+=$7;d+=$2}END{print (a+b+c)*100/d}'

3.4 Host替换

修改127.0.0.1 test.salt.com128.0.0.1 test.salt.com

# salt -N test cmd.run 'sed -i "s/127.0.0.1 test.salt.com/128.0.0.1 test.salt.com/" /etc/hosts'

3.5 Host追加

127.0.0.1 test.local后增加一行128.0.0.1 test.salt.com

# salt -N test cmd.run 'sed -i "/127.0.0.1 test.local/a\128.0.0.1 test.salt.com" /etc/hosts'

3.6 删除Host

删除127.0.0.1 test.local配置

# salt -N test cmd.run 'sed -i "/127.0.0.1 test.local/d" /etc/hosts'

-- EOF --
最后更新于: 2024-08-17 14:44
发表于: 2019-07-26 23:50
标签: 运维