一、动态调用插件解析

1、目录结构

1、base_module代码解析:

  1. def syntax_parser(self,section_name,mod_name,mod_data):
  2. print("-going to parser state data:",section_name,mod_name)
  3. for state_item in mod_data:
  4. print("\t",state_item)
  5. for key,val in state_item.items():
  6. if hasattr(self,key):
  7. state_func = getattr(self,key)
  8. state_func(val)
  9. else:
  10. exit("Error:module [%s] has no argument [%s]" %( mod_name,key ))

2、sate.py代码

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. # Author:luoahong
  4. from Arya.backends.base_module import BaseSaltModule
  5. import os
  6.  
  7. class State(BaseSaltModule):
  8.  
  9. def load_state_files(self,state_filename):
  10. from yaml import load, dump
  11. try:
  12. from yaml import CLoader as Loader, CDumper as Dumper
  13. except ImportError:
  14. from yaml import Loader, Dumper
  15. state_file_path = "%s/%s" %(self.settings.SALT_CONFIG_FILES_DIR,state_filename)
  16. if os.path.isfile(state_file_path):
  17. with open(state_file_path) as f:
  18. data = load(f.read(), Loader=Loader)
  19. return data
  20. else:
  21. exit("%s is not a valid yaml config file" % state_filename)
  22.  
  23. def apply(self):
  24. '''
  25. 1. load the configurations file
  26. 2. parse it
  27. 3. create a task and sent it to the MQ
  28. 4. collect the result with task-callback id
  29. :return:
  30. '''
  31.  
  32. if '-f' in self.sys_argvs:
  33. yaml_file_index = self.sys_argvs.index('-f') + 1
  34. try:
  35. yaml_filename = self.sys_argvs[yaml_file_index]
  36. state_data = self.load_state_files(yaml_filename)
  37. #print('state data:',state_data)
  38.  
  39. for os_type,os_type_data in self.config_data_dic.items(): #按照不同的操作系统单独生成一份配置文件
  40. for section_name,section_data in state_data.items():
  41. print('Section:',section_name)

3、运行截图

二、模块参数解析

1、目录结构

二、代码

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. # Author:luoahong
  4.  
  5. class BaseSaltModule(object):
  6. def __init__(self,sys_argvs,db_models,settings):
  7. self.db_models = db_models
  8. self.settings = settings
  9. self.sys_argvs = sys_argvs
  10.  
  11. def get_selected_os_types(self):
  12. data = {}
  13. for host in self.host_list:
  14. data[host.os_type] = []
  15. print('--->data',data)
  16. return data
  17. def process(self):
  18. self.fetch_hosts()
  19. self.config_data_dic = self.get_selected_os_types()
  20. def require(self,*args,**kwargs):
  21. pass
  22. def fetch_hosts(self):
  23. print('--fetching hosts---')
  24.  
  25. if '-h' in self.sys_argvs or '-g' in self.sys_argvs:
  26. host_list = []
  27. if '-h' in self.sys_argvs:
  28. host_str_index = self.sys_argvs.index('-h') +1
  29. if len(self.sys_argvs) <= host_str_index:
  30. exit("host argument must be provided after -h")
  31. else: #get the host str
  32. host_str = self.sys_argvs[host_str_index]
  33. host_str_list = host_str.split(',')
  34. host_list += self.db_models.Host.objects.filter(hostname__in=host_str_list)
  35. if '-g' in self.sys_argvs:
  36. group_str_index = self.sys_argvs.index('-g') +1
  37. if len(self.sys_argvs) <= group_str_index:
  38. exit("group argument must be provided after -g")
  39. else: #get the group str
  40. group_str = self.sys_argvs[group_str_index]
  41. group_str_list = group_str.split(',')
  42. group_list = self.db_models.HostGroup.objects.filter(name__in=group_str_list)
  43. for group in group_list:
  44. host_list += group.hosts.select_related()
  45. self.host_list = set(host_list)
  46. return True
  47. print('----host list:', host_list)
  48. else:
  49. exit("host [-h] or group[-g] argument must be provided")
  50.  
  51. def syntax_parser(self,section_name,mod_name,mod_data):
  52. print("-going to parser state data:",section_name,mod_name)
  53. for state_item in mod_data:
  54. print("\t",state_item)
  55. for key,val in state_item.items():
  56. if hasattr(self,key):
  57. state_func = getattr(self,key)
  58. state_func(val)
  59. else:
  60. exit("Error:module [%s] has no argument [%s]" %( mod_name,key ))

sates.py

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. # Author:luoahong
  4. from Arya.backends.base_module import BaseSaltModule
  5. import os
  6.  
  7. class State(BaseSaltModule):
  8.  
  9. def load_state_files(self,state_filename):
  10. from yaml import load, dump
  11. try:
  12. from yaml import CLoader as Loader, CDumper as Dumper
  13. except ImportError:
  14. from yaml import Loader, Dumper
  15. state_file_path = "%s/%s" %(self.settings.SALT_CONFIG_FILES_DIR,state_filename)
  16. if os.path.isfile(state_file_path):
  17. with open(state_file_path) as f:
  18. data = load(f.read(), Loader=Loader)
  19. return data
  20. else:
  21. exit("%s is not a valid yaml config file" % state_filename)
  22.  
  23. def apply(self):
  24. '''
  25. 1. load the configurations file
  26. 2. parse it
  27. 3. create a task and sent it to the MQ
  28. 4. collect the result with task-callback id
  29. :return:
  30. '''
  31.  
  32. if '-f' in self.sys_argvs:
  33. yaml_file_index = self.sys_argvs.index('-f') + 1
  34. try:
  35. yaml_filename = self.sys_argvs[yaml_file_index]
  36. state_data = self.load_state_files(yaml_filename)
  37. #print('state data:',state_data)
  38.  
  39. for os_type,os_type_data in self.config_data_dic.items(): #按照不同的操作系统单独生成一份配置文件
  40. for section_name,section_data in state_data.items():
  41. print('Section:',section_name)
  42.  
  43. for mod_name,mod_data in section_data.items():
  44. base_mod_name = mod_name.split(".")[0]
  45. plugin_file_path = "%s/%s.py" % (self.settings.SALT_PLUGINS_DIR,base_mod_name)
  46. if os.path.isfile(plugin_file_path):
  47. #导入 模块
  48.  
  49. module_plugin = __import__('plugins.%s' %base_mod_name)
  50. special_os_module_name = "%s%s" %(os_type.capitalize(),base_mod_name.capitalize())
  51. #print('dir module plugin:',module_plugin,base_mod_name)
  52. #getattr(module_plugin,base_mod_name)
  53. module_file= getattr(module_plugin, base_mod_name) # 这里才是真正导入模块
  54. if hasattr(module_file, special_os_module_name): #判断有没有根据操作系统的类型进行特殊解析 的类,在这个文件里
  55. module_instance = getattr(module_file, special_os_module_name)
  56. else:
  57. module_instance = getattr(module_file, base_mod_name.capitalize())
  58.  
  59. #开始调用 此module 进行配置解析
  60. module_obj = module_instance(self.sys_argvs,self.db_models,self.settings)
  61. module_obj.syntax_parser(section_name,mod_name,mod_data )
  62. else:
  63. exit("module [%s] is not exist" % base_mod_name)
  64. #print(" ",mod_name)
  65. #for state_item in mod_data:
  66. # print("\t",state_item)
  67.  
  68. except IndexError as e:
  69. exit("state file must be provided after -f")
  70.  
  71. else:
  72. exit("statefile must be specified.")

saltstack主机管理项目:动态调用插件解析-模块解析(五)的更多相关文章

  1. saltstack主机管理项目:编写插件基类-获取主机列表-提取yaml配置文件(四)

    一.编写插件基类 1.目录结构 1.我是如何获知我有多少种系统? 当客户端第一连接过来的时候,我就已经把这些文件存下来了 ,存在到哪里了?存到数据库了 每次对主机发送命令的动作时,我从库里把数据取出来 ...

  2. saltstack主机管理项目:主机管理项目架构设计(二)

    1.salt架构图 https://docs.saltstack.com/en/getstarted/system/plugins.html plug-ins(左边):场景可插拔 subsystem- ...

  3. saltstack主机管理项目【day23】:主机管理项目需求分析-设计

    本节内容 一. 主机管理项目需求分析 二 .主机管理项目架构设计 三.主机管理项目初始构建 四. 主机管理项目编主机分发器 一. 主机管理项目需求分析 场景:我现在又一台裸机要实现一下人物 配置管理: ...

  4. saltstack主机管理项目【day39】:主机管理项目开发

    项目目标 salt state.apply -h "ubuntu,centos" -g "ubuntu,centos" -f "ubuntu,cent ...

  5. saltstack主机管理项目:今日总结(六)

    一.总目录 二.具体代码 salt #!/usr/bin/env python # -*- coding:utf-8 -*- # Author:luoahong import os,sys if __ ...

  6. saltstack主机管理项目:主机管理项目需求分析(一)

    1.场景: 我现在又一台裸机要实现一下任务 2.配置管理: 1.装上nginx,mysql 2.nginx用我指定的配置文件 3.mysql用户 4.设置一个默认的数据库访问权限 5.启动mysql ...

  7. saltstack主机管理项目:计主机管理项目命令分发器(三)

    一.开发目标命令格式如下: 二.目录结构 三.代码注解 01.salt.py 只是一个入口,没干什么事情 #!/usr/bin/env python # -*- coding:utf-8 -*- # ...

  8. 动态链接库(dll)文件的动态调用(使用动态链接库,解析Wis文件--测井数据文件的一种)

    在画出井眼轨迹后,老师又给了三口井的数据,不过这次给的数据是WIS格式的,可以使用一个动态链接库进行解析,解析结束后会生成一个固定格式的txt文件,然后再读取txt文件,画井眼轨迹. 学长给了一个可以 ...

  9. 【主机管理项目】-(models.py(一对多、多对多数据库创建代码))

    # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models class U ...

随机推荐

  1. 拉勾网爬取全国python职位并数据分析薪资,工作经验,学历等信息

    首先前往拉勾网“爬虫”职位相关页面 确定网页的加载方式是JavaScript加载 通过谷歌浏览器开发者工具分析和寻找网页的真实请求,确定真实数据在position.Ajax开头的链接里,请求方式是PO ...

  2. mysql面试题

    01. 列举常见的关系型数据库和非关系型都有那些? 1.关系型数据库通过外键关联来建立表与表之间的关系,---------常见的有:SQLite.Oracle.mysql 2.非关系型数据库通常指数据 ...

  3. linux 本机内核模块

    make -C /lib/modules/4.13.0-36-generic/build M=/$(pwd) modules 内核里只需要写obj-m:=hello.o

  4. Linux-基础学习(六)-Redis的进阶学习

    1. redis的进阶操作 1.1 redis的订阅操作 发布订阅的命令 PUBLISH channel msg 将信息 message 发送到指定的频道 channel SUBSCRIBE chan ...

  5. Linux进程管理专题

    Linux进程管理 (1)进程的诞生介绍了如何表示进程?进程的生命周期.进程的创建等等? Linux支持多种调度器(deadline/realtime/cfs/idle),其中CFS调度器最常见.Li ...

  6. Kaggle教程——大神教你上分

    本文记录笔者在观看Coursera上国立经济大学HLE的课程 How to win a data science competetion中的收获,和大家分享.课程的这门课的讲授人是Kaggle的大牛, ...

  7. 好的LCT板子和一句话

    typedef long long ll; const int maxn = 400050; struct lct { int ch[maxn][2], fa[maxn], w[maxn]; bool ...

  8. 关于JAVA中string直接初始化赋值和new的区别,是否可以联系到int[]的情况

    String str1 = "ABC"; String str2 = new String("ABC"); String str1 = “ABC”;可能创建一个 ...

  9. tomcat发请求,查看各个环节的耗时时间

    从一台机器给另一台机器tomcat发请求,查看各个环节的耗时时间 - 业精于勤,荒于嬉:行成于思,毁于随. - CSDN博客https://blog.csdn.net/YAOQINGGG/articl ...

  10. vue.js实战——$event

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...