Func常用模块及API

  1. 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、  执行命令模块

(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")

  1. CPU信息模块

1、  功能

Cpumodule获取远程主机cpu信息,支持按时间(秒)采样平均值,如下面示例的参数‘10’

2、  命令模式

[root@controller ~]# func "*" call cpu usage 10

3、  API模式

print client.cpu.usage(10)

  1. 磁盘信息模块

1、  功能

DiskModule实现获取远程主机的磁盘分区信息,参数为分区标签,如/data分区。

2、  命令模式

[root@controller ~]# func "*" call cpu usage 10

3、  API模式

print client.cpu.usage(10)

  1. 拷贝远程文件模块

1、  功能

GetFileModul实现拉取远程Linux主机指定文件到主控端目录,不支持命令行模式。

2、  API模式

client.local.getfile.get("/root/a.txt","/tmp/")

  1. 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. 系统硬件信息模块

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()

  1. 系统Mount管理模块

1、  功能

MountModule实现远程主机Linux系统挂载、卸载分区管理。

2、  命令行模式

[root@controller ~]# func "*" call mount list

3、  API模式

print client.mount.list()

  1. 系统进程管理模块

1、  功能

ProcessModule实现远程主机Linux进程管理。

2、  命令行模式

[root@controller ~]# func "*" call process info "aux"

3、  API模式

print client.process.info("aux")

  1. 系统服务管理模块

4、  功能

servicesModule实现远程主机Linux系统服务管理。

5、  命令行模式

[root@controller ~]# func "*" call service start snmpd

6、  API模式

print client.service.start("nginx")

Func常用模块及API的更多相关文章

  1. Func系列2:常用模块及API

    简介 Func提供了非常丰富的功能模块,包括CommandModule(执行命令).CopyFileModule(拷贝文件).CPUModule(CPU信息).DiskModule(磁盘信息).Fil ...

  2. Saltstack常用模块及API

    Saltstack提供了非常丰富的功能模块,涉及操作系统的基础功能.常用工具支持等,更多模块信息可以查看官网模块介绍.也可以通过sys模块列出当前版本支持的模块. salt '*' sys.list_ ...

  3. Saltstack系列3:Saltstack常用模块及API

    说明 salt '*' sys.list_modules #列出当前版本支持的模块 API原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmd()方法来实现 ...

  4. Ansible常用模块及API

    Ansible安装 安装EPEL作为安装Ansible的yum源(CentOS6.4): rpm -Uvh http://ftp.linux.ncsu.edu/pub/epel/6/i386/epel ...

  5. salt常用模块及API

    saltstack提供了非常丰富的功能模块,涉及操作系统的基础功能,常用工具支持等,更多模块信息见官网模块介绍:https://docs.saltstack.com/en/latest/ref/mod ...

  6. Saltstack 常用的模块及API

    Saltstack提供了非常丰富的功能模块,设计操作系统的基础功能,常用工具支持等, 官网模块介绍 http://docs.saltstack.com/ref/modules/all/index.ht ...

  7. ansible api常用模块与参数

    ###ansibleAPI 常用模块 用于读取yaml,json格式的文件 from ansible.parsing.dataloader import DataLoader #用于管理变量的类,包括 ...

  8. ansible API 常用模块

    常用模块 用于读取yaml,json格式的文件 from ansible.parsing.dataloader import DataLoader #用于管理变量的类,包括主机,组,扩展等变量 fro ...

  9. Python学习笔记-常用模块

    1.python模块 如果你退出 Python 解释器并重新进入,你做的任何定义(变量和方法)都会丢失.因此,如果你想要编写一些更大的程序,为准备解释器输入使用一个文本编辑器会更好,并以那个文件替代作 ...

随机推荐

  1. EMMC与nand flash的区别【转】

    1.NAND Flash 是一种存储介质,要在上面读写数据,外部要加主控和电路设计. 2.eMMC是NAND flash+主控IC ,对外的接口协议与SD.TF卡类似:对厂家而言简化了电路设计,降低了 ...

  2. 跟我一起读postgresql源码(十一)——Executor(查询执行模块之——Materialization节点(上))

    物化节点 顾名思义,物化节点是一类可缓存元组的节点.在执行过程中,很多扩展的物理操作符需要首先获取所有的元组后才能进行操作(例如聚集函数操作.没有索引辅助的排序等),这时要用物化节点将元组缓存起来.下 ...

  3. webpack编译流程漫谈

    前言 weback在web构建工具的激烈竞争中逐渐脱引而出. 无论是编译速度.报错提示.可扩展性等都给前端开发者耳目一新的感觉.本篇文章是个人对webpack的一点小研究总结. webpack在开发者 ...

  4. bzoj:2018 [Usaco2009 Nov]农场技艺大赛

    Description Input 第1行:10个空格分开的整数: N, a, b, c, d, e, f, g, h, M Output 第1行:满足总重量最轻,且用度之和最大的N头奶牛的总体重模M ...

  5. 一步一步从原理跟我学邮件收取及发送 3.telnet命令行发一封信

    首先要感谢博客园管理员的及时回复,本系列的第二篇文章得以恢复到首页,这是对作者的莫大鼓励.说实在的本来我真的挺受打击的.好在管理员说只是排版上有些问题,要用代码块修饰下相关的信息.说来惭愧因为常年编码 ...

  6. c语言变量类型联想

    int float char *(指针) 已经定义:单个变量 单个相同类型在内存中顺序存放:数组 不同单个类型在内存中顺序存放:结构体 不同类型在内存中自由存放:链表 其中结构体与链表类型需运用时提前 ...

  7. c语言_FILE结构体解释及相关操作

    1. 文件和流的关系 C将每个文件简单地作为顺序字节流(如下图).每个文件用文件结束符结束,或者在特定字节数的地方结束,这个特定的字节数可以存储在系统维护的管理数据结构中.当打开文件时,就建立了和文件 ...

  8. js第一课总结

    一. 当引用了一个src="demo.js"后,scrpit中间不能有js类的任何方法,都不会被执行. <!DOCTYPE html PUBLIC "-//W3C/ ...

  9. spring自带定时器

    http://www.cnblogs.com/pengmengnan/p/6714203.html 注解模式的spring定时器1 , 首先要配置我们的spring.xmlxmlns 多加下面的内容. ...

  10. JS使用循环按指定倍数分割数组组成新的数组的方法

    今天一个新人同事问了我一个问题,就是有一个像下边这种不知道具体长度的数组,想以每4个为一组,重新组合为一个二维数组,很简单的需求只需要用到一个循环再去取余数就可以了,写了一个小demo在这里把代码包括 ...