热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

salt的api学习记录saltcp命令的执行过程

最近重新看了下salt-cp实现的过程,源代码逻辑相对简单,明白了salt-cp为什么只能针对文本文件、配置文件的拷贝。现在就来看看对应的代码吧源代码文件:saltclicp.py

最近重新看了下salt-cp实现的过程,源代码逻辑相对简单,明白了salt-cp为什么只能针对文本文件、配置文件的拷贝。现在就来看看对应的代码吧


源代码文件:

salt/cli/cp.py


class SaltCP(object):
    def __init__(self, opts):
        self.opts = opts
    
    # 读取文件内容,返回单元素字典:文件名-->文件内容
    def _file_dict(self, fn_):
        ‘‘‘ 
        Take a path and return the contents of the file as a string
        ‘‘‘
        if not os.path.isfile(fn_):
            err = ‘The referenced file, {0} is not available.‘.format(fn_)
            sys.stderr.write(err + ‘\n‘)
            sys.exit(42)
        with salt.utils.fopen(fn_, ‘r‘) as fp_:
            data = fp_.read()
        return {fn_: data}
        
     # 用来迭代文件的,产生一个字典:文件名-->文件内容
    def _load_files(self):
        ‘‘‘
        Parse the files indicated in opts[‘src‘] and load them into a python
        object for transport
        ‘‘‘
        files = {}
        for fn_ in self.opts[‘src‘]:
            if os.path.isfile(fn_):
                # 更新字典
                files.update(self._file_dict(fn_))
            elif os.path.isdir(fn_):
                print(fn_ + ‘ is a directory, only files are supported.‘)
                #files.update(self._recurse_dir(fn_))

        # files: {‘filename1‘:content,‘filename2‘:content}
        return files
       
       # 调用的是salt.client.LocalClient的方法cmd,调用cp.recv函数拷贝
      def run(self):
        ‘‘‘
        Make the salt client call
        ‘‘‘
        arg = [self._load_files(), self.opts[‘dest‘]]
        local = salt.client.LocalClient(self.opts[‘conf_file‘])
        args = [self.opts[‘tgt‘],
                ‘cp.recv‘,
                arg,
                self.opts[‘timeout‘],
                ]

        selected_target_option = self.opts.get(‘selected_target_option‘, None)
        if selected_target_option is not None:
            args.append(selected_target_option)

        ret = local.cmd(*args)

        pprint.pprint(ret)


从代码可以看出,拷贝文件前,需要读取文件的内容,并以{file:data}的形式返回。

然后调用salt.client.LocalClient的cmd方法并调用cp.recv函数拷贝。

cp.recv对应代码如下:

def recv(files, dest):
    ‘‘‘ 
    Used with salt-cp, pass the files dict, and the destination.

    This function receives small fast copy files from the master via salt-cp.
    It does not work via the CLI.
    ‘‘‘
    ret = {}
    for path, data in files.items():
        if os.path.basename(path) == os.path.basename(dest)                 and not os.path.isdir(dest):
            final = dest
        elif os.path.isdir(dest):
            final = os.path.join(dest, os.path.basename(path))
        elif os.path.isdir(os.path.dirname(dest)):
            final = dest
        else:
            return ‘Destination unavailable‘

        try:
            salt.utils.fopen(final, ‘w+‘).write(data)
            ret[final] = True
        except IOError:
            ret[final] = False

    return ret


我们可以直接以下面的形式调用这个api

opts = {
    ‘tgt‘: ‘192.168.110.132‘,  # target
    ‘src‘: [‘file1‘,‘file2‘,]  # 需要拷贝的文件路劲
    ‘conf_file‘: ‘/opt/app/salt/etc/master‘, # master的配置文件
    ‘dest‘: ‘/mnt‘,    # 目标目录
    ‘timeout‘: 5,      # 过期时间
}
cp = salt.cli.cp.SaltCP(opts)
cp.run()

# 最终调用是这样的形式
local.cmd(‘192.168.110.132‘,‘cp.recv‘,[{‘/root/data‘:content},‘/mnt‘],5)


看完之后,才知道salt-cp的实现原理这么简单,简单的只能拷贝配置文件、文本文件、小文件。对于大文件的拷贝,后面会有方法。



本文出自 “fly天地” 博客,请务必保留此出处http://liuping0906.blog.51cto.com/2516248/1553252

salt的api学习记录---salt-cp命令的执行过程


推荐阅读
  • Python自动化测试入门:Selenium环境搭建
    本文详细介绍如何在Python环境中安装和配置Selenium,包括开发工具PyCharm的安装、Python环境的设置以及Selenium包的安装方法。此外,还提供了编写和运行第一个自动化测试脚本的步骤。 ... [详细]
  • 探索新一代API文档工具,告别Swagger的繁琐
    对于后端开发者而言,编写和维护API文档既繁琐又不可或缺。本文将介绍一款全新的API文档工具,帮助团队更高效地协作,简化API文档生成流程。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • 通常情况下,修改my.cnf配置文件后需要重启MySQL服务才能使新参数生效。然而,通过特定命令可以在不重启服务的情况下实现配置的即时更新。本文将详细介绍如何在线调整MySQL配置,并验证其有效性。 ... [详细]
  • 本文探讨了在构建应用程序时,如何对不同类型的数据进行结构化设计。主要分为三类:全局配置、用户个人设置和用户关系链。每种类型的数据都有其独特的用途和应用场景,合理规划这些数据结构有助于提升用户体验和系统的可维护性。 ... [详细]
  • Linux中的yum安装软件
    yum俗称大黄狗作用:解决安装软件包的依赖关系当安装依赖关系的软件包时,会将依赖的软件包一起安装。本地yum:需要yum源,光驱挂载。yum源:(刚开始查看yum源中的内容就是上图 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • 本文详细介绍了钩子(hook)的概念、原理及其在编程中的实际应用。通过对比回调函数和注册函数,解释了钩子的工作机制,并提供了具体的Python示例代码,帮助读者更好地理解和掌握这一重要编程工具。 ... [详细]
  • CentOS 系统管理基础
    本文介绍了如何在 CentOS 中查询系统版本、内核版本、位数以及磁盘分区的相关知识。通过这些命令,用户可以快速了解系统的配置和磁盘结构。 ... [详细]
  • 本文详细探讨了 PHP 中 method_exists() 和 is_callable() 函数的区别,帮助开发者更好地理解和使用这两个函数。文章不仅解释了它们的功能差异,还提供了代码示例和应用场景的分析。 ... [详细]
author-avatar
大眼妹PS珺珺
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有