Func常用模块及API
Func常用模块及API
- Func提供了非常丰富的功能模块,包括:
CommandModule(执行命令)
CopyFileModule(拷贝文件)
CpuModule(CPU信息)
DiskModule(磁盘信息)
FileTrackerModule(文件跟踪)
IPtablesModule(iptables管理)
MountModule(Mount挂载)
NagiosServerModule(Nagios管理)
NetWorkTest(网络测试)
ProcessModule(进程管理)
SysctlModule(sysctl管理)
SNMPModule(SNMP信息管理)等等:
更多模块见:https://fedoraproject.org/wiki/Infrastructure/Fedorahosted-retirement
命令行调用模块格式:
Func<目标主机>call<Module_name(模块名)><method_name(方法名)><module_args(模块参数)>
例如运行“df –m”查看被控端内存,如:
[root@controller ~]# func compute call command run "df -m"
('compute',
[0,
'Filesystem 1M-blocks Used Available Use% Mounted on\n/dev/mapper/centos-root 459828 2131 457697 1% /\ndevtmpfs 3861 0 3861 0% /dev\ntmpfs 3871 0 3871 0% /dev/shm\ntmpfs 3871 57 3815 2% /run\ntmpfs 3871 0 3871 0% /sys/fs/cgroup\n/dev/sda1 494 184 311 38% /boot\ntmpfs 775 0 775 0% /run/user/0\n',
''])
注: [root@controller ~]# func "*" call command run "df -m" 单独“*”为所有被控制端
[root@controller ~]# func "com*ute?" call command run "df -m" 这里“*”代表任意多个字符。“?”代表单个任意字符
func "compute1;compute2" call command run "df -m" 多个目标主机使用分号分隔
- 常用模块详解
1、 执行命令模块
(1) 功能
CommandModule实现linux远程命令调用执行
(2) 命令行模式
[root@controller ~]# func "*" call command run "uname -a"
(3) API模式
[root@controller ~]# cat funcommand.py
#!/usr/bin/python
import func.overlord.client as func
client = func.Client("*")
print client.command.run("free -m")
[root@controller ~]# python funcommand.py
{'compute': [0, ' total used free shared buff/cache available\nMem: 7741 700 6356 56 684 6669\nSwap: 16383 0 16383\n', '']}
2、 文件拷贝模块
a) 功能
CopyFileModule实现主控端向目标主机拷贝文件,类似scp的功能
b) 命令行模式
[root@controller ~]# func "*" copyfile -f /root/start.sh --remotepath /root/start.sh
c) API模式
[root@controller ~]# cat funccopyfile.py
#!/usr/bin/python
import func.overlord.client as func
client = func.Client("*")
client.local.copyfile.send("/root/start.sh","/tmp/start.sh")
- CPU信息模块
1、 功能
Cpumodule获取远程主机cpu信息,支持按时间(秒)采样平均值,如下面示例的参数‘10’
2、 命令模式
[root@controller ~]# func "*" call cpu usage 10
3、 API模式
print client.cpu.usage(10)
- 磁盘信息模块
1、 功能
DiskModule实现获取远程主机的磁盘分区信息,参数为分区标签,如/data分区。
2、 命令模式
[root@controller ~]# func "*" call cpu usage 10
3、 API模式
print client.cpu.usage(10)
- 拷贝远程文件模块
1、 功能
GetFileModul实现拉取远程Linux主机指定文件到主控端目录,不支持命令行模式。
2、 API模式
client.local.getfile.get("/root/a.txt","/tmp/")
- Iptables管理模块
1、 功能
IPtables实现远程主机iptables配置。
2、 命令行模式
[root@controller ~]# func "*" call iptables.port drop_to 53 192.168.128.0/24 udp src
3、 API模式
client.iptables.port.drop_to(8080,"192.168.128.55","tcp","dst")
- 系统硬件信息模块
1、 功能
HardwareModule返回远程主机系统硬件信息。
2、 命令行模式
[root@controller ~]# func "*" call iptables.port drop_to 53 192.168.128.0/24 udp src
3、 API模式
print client.hardware.info(with_devices=True)
print client.hardware.hal_info()
- 系统Mount管理模块
1、 功能
MountModule实现远程主机Linux系统挂载、卸载分区管理。
2、 命令行模式
[root@controller ~]# func "*" call mount list
3、 API模式
print client.mount.list()
- 系统进程管理模块
1、 功能
ProcessModule实现远程主机Linux进程管理。
2、 命令行模式
[root@controller ~]# func "*" call process info "aux"
3、 API模式
print client.process.info("aux")
- 系统服务管理模块
4、 功能
servicesModule实现远程主机Linux系统服务管理。
5、 命令行模式
[root@controller ~]# func "*" call service start snmpd
6、 API模式
print client.service.start("nginx")
Func常用模块及API的更多相关文章
- Func系列2:常用模块及API
简介 Func提供了非常丰富的功能模块,包括CommandModule(执行命令).CopyFileModule(拷贝文件).CPUModule(CPU信息).DiskModule(磁盘信息).Fil ...
- Saltstack常用模块及API
Saltstack提供了非常丰富的功能模块,涉及操作系统的基础功能.常用工具支持等,更多模块信息可以查看官网模块介绍.也可以通过sys模块列出当前版本支持的模块. salt '*' sys.list_ ...
- Saltstack系列3:Saltstack常用模块及API
说明 salt '*' sys.list_modules #列出当前版本支持的模块 API原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmd()方法来实现 ...
- Ansible常用模块及API
Ansible安装 安装EPEL作为安装Ansible的yum源(CentOS6.4): rpm -Uvh http://ftp.linux.ncsu.edu/pub/epel/6/i386/epel ...
- salt常用模块及API
saltstack提供了非常丰富的功能模块,涉及操作系统的基础功能,常用工具支持等,更多模块信息见官网模块介绍:https://docs.saltstack.com/en/latest/ref/mod ...
- Saltstack 常用的模块及API
Saltstack提供了非常丰富的功能模块,设计操作系统的基础功能,常用工具支持等, 官网模块介绍 http://docs.saltstack.com/ref/modules/all/index.ht ...
- ansible api常用模块与参数
###ansibleAPI 常用模块 用于读取yaml,json格式的文件 from ansible.parsing.dataloader import DataLoader #用于管理变量的类,包括 ...
- ansible API 常用模块
常用模块 用于读取yaml,json格式的文件 from ansible.parsing.dataloader import DataLoader #用于管理变量的类,包括主机,组,扩展等变量 fro ...
- Python学习笔记-常用模块
1.python模块 如果你退出 Python 解释器并重新进入,你做的任何定义(变量和方法)都会丢失.因此,如果你想要编写一些更大的程序,为准备解释器输入使用一个文本编辑器会更好,并以那个文件替代作 ...
随机推荐
- deeplearning.ai 人工智能行业大师访谈 Pieter Abbeel 听课笔记
1. Pieter Abbeel小时候想做一个篮球运动员 - -!上学的时候喜欢数学和物理,上大学之后很自然的学工程.Pieter定义工程问题是"解决实际中应用物理和数学的问题". ...
- 2016广东工业大学新生杯决赛网络同步赛暨全国新生邀请赛 题解&源码
Problem A: pigofzhou的巧克力棒 Description 众所周知,pigofzhou有许多妹子.有一天,pigofzhou得到了一根巧克力棒,他想把这根巧克力棒分给他的妹子们.具体 ...
- HDU 1012 u Calculate e【暴力打表,水】
u Calculate e Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- poj1258prim算法
/*poj 1258 *题意:有若干个农场,现需要将各个农场用光纤连接起来,各个农场之间连接的光纤长度也许不同, *要求求出使得将所有农场连接起来的最短光线长度 *算法分析:使用矩阵将各个农场之间的光 ...
- 《TensorFlow深度学习应用实践》
http://product.dangdang.com/25207334.html 内容 简 介 本书总的指导思想是在掌握深度学习的基本知识和特性的基础上,培养使用TensorFlow进行实际编程以解 ...
- 【django基础补充之URL,视图,模版】
一.url路由配置 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于这个URL调用这段代 ...
- IDEA安装vue开发插件
前言: 开发免不了要用到开发工具,什么sublime,webstorm,idea的,现在我就说下idea开发神器下安装vue插件进行vue项目的开发吧. idea下载地址:http://www.jet ...
- UserView--第一种方式set去重,基于Spark算子的java代码实现
UserView--第一种方式set去重,基于Spark算子的java代码实现 测试数据 java代码 package com.hzf.spark.study; import java.util.Ha ...
- SSM手把手整合教程&测试事务
自打来了博客园就一直在看帖,学到了很多知识,打算开始记录的学习到的知识点 今天我来写个整合SpringMVC4 spring4 mybatis3&测试spring事务的教程,如果有误之处,还请 ...
- 安装Wamp后 Apache无法启动的解决方法
安装Wamp后 Apache无法启动的解决方法,网上的解决方案可以说是五花八门,有些说了一大推,一点作用都起不到. 其实解决方法只需两步: 1.安装路径不能包含有中文,这个我不知道为什么,总之如果安装 ...