pangxia75 发表于 2018-7-31 08:57:30

用saltstack cp模块实现文件管理

1.先看配置,2.配置,看日志3,日志不行,只能源代码了  

  

  
基础篇
  

  
官网 http://salt.readthedocs.io/en/stable/topics/tutorials/minionfs.html#tutorial-minionfs
  

  
第一看卡壳 Saltstack的配置Salt master配置文件
  
http://blog.csdn.net/zhs2014150551/article/details/48951581
  

  
fileserver_backend:
  
    – roots
  

  
salt支持模块化的后端文件系统服务器,它允许salt通过第三方的系统来管理收集文件并提供给minions使用,可以配置多个后端文件系统,这里支持gitfs、hgfs、roots、s3fs文件调用的搜索顺序按照后台文件系统的配置顺序来搜索,默认的设置只开启了标准的后端服务器roots,具体的根选项配置通过file_roots参数设置
  

  
分发到minion
  
salt '*' cp.get_filesalt://test.sls /root/test.sls --log-level=all
  

  
上传到master
  
salt '*' cp.push/root/install.log --log-level=all
  
上传的文件存放在master端的 /var/cache/salt/master/minions/<minion_id>/files/ 目录下
  

  

  

  

  
源代码解析
  
http://liuping0906.blog.51cto.com/2516248/1553252
  

  
def push(path):
  
    '''
  
    Push a file from the minion up to the master, the file will be saved to
  
    the salt master in the master's minion files cachedir
  
    (defaults to /var/cache/salt/master/minions/files)
  
    Since this feature allows a minion to push a file up to the master server
  
    it is disabled by default for security purposes. To enable add the option:
  
    file_recv: True
  
    to the master configuration and restart the master
  
    CLI Example::
  
      salt '*' cp.push /etc/fstab
  
    '''
  
    path=os.path.basename(path)
  
    if '../' in path or not os.path.isabs(path):
  
      return False
  
    if not os.path.isfile(path):
  
      return False
  
    auth = _auth()
  
    load = {'cmd': '_file_recv',
  
            'id': __opts__['id'],
  
            'path': path.lstrip(os.sep)}
  
    sreq = salt.payload.SREQ(__opts__['master_uri'])
  
    with salt.utils.fopen(path) as fp_:
  
      while True:
  
            load['loc'] = fp_.tell()
  
            load['data'] = fp_.read(__opts__['file_buffer_size'])
  
            if not load['data']:
  
                return True
  
            ret = sreq.send('aes', auth.crypticle.dumps(load))
  
            if not ret:
  
                return ret
  

  
进阶
  
http://rfyiamcool.blog.51cto.com/1030776/1360468/
  
用saltstack cp模块实现文件管理、拉取和回滚下发
  

  
要实现的效果:
  
通过mongodb记录数据,然后web api接口渲染配置文件来的更方便。
  

  
web-api http://salt-api.readthedocs.io/en/latest/ref/netapis/all/saltapi.netapi.rest_cherrypy.html#a-rest-api-for-salt
页: [1]
查看完整版本: 用saltstack cp模块实现文件管理