Func系列2:常用模块及API

简介

Func提供了非常丰富的功能模块,包括CommandModule(执行命令)、CopyFileModule(拷贝文件)、CPUModule(CPU信息)、DiskModule(磁盘信息)、FileTrackerModule(文件跟踪)、IPtablesModule(iptables管理)、MountModule(Mount挂载)、NagiosServerModule(Nagios管理)、NetworkTest(网络测试)、ProcessModule(进程管理)、SysctlModule(sysctl管理)、SNMPModule(SNMP信息)等等。

命令调用格式:

func <目标主机> call <module_name(模块名)> <method_name(方法名)> <module_args(模块参数)>

例:

func ‘test‘ call command run ‘df -h‘    #获取test主机磁盘信息

结果:

(‘wx‘,
[0,
‘Filesystem Size Used Avail Use% Mounted on\n/dev/mapper/vg_wx-lv_root\n 14G 8.2G 4.7G 64% /\ntmpfs
939M 16K 939M 1% /dev/shm\n/dev/sda1 477M 103M 349M 23% /boot\n‘,
‘‘])

注:模块命令执行结果以Python元组字符串形式返回,API调用以字典形式返回

API:

#! /usr/bin/env python
# -*-coding:utf-8-*-

import func.overlord.client as func

client = func.Client(‘test‘) #test为目标主机,要对所有目标主机进行操作,使用‘*‘
result = client.command.run(‘free -m‘) #所有模块调用只需要在这里添加即可

print result

选择目标主机

Func选择目标主机操作对象支持‘*’与‘?’方式匹配,其中*代表任意多个字符,?代表单个任意字符。多个目标主机用分号(;)隔开

例:

func ‘SN2013-*-02?‘ call command run ‘uptime‘         #SN2013-*-02? 可以匹配SN2013-08-021、SN2013-09-022等

常用模块详解

func命令功能参数举例

查看所有主机uptime,开启5个线程异步运行,超时时间为3秒

func -t 3 ‘*‘ call --forks=‘5‘ --async command run ‘uptime‘

格式化输出结果,默认格式为Python的元组,给别添加--json或--xml来输出JSON及XML格式

func -t 3 ‘*‘ call --forks=‘5‘ --json --async command run ‘uptime‘

执行命令模块

功能:

CommandModule实现Linux远程命令调用执行

命令:

func ‘*‘ call command run ‘ulimit -a‘
func ‘test‘ call command run ‘free -m‘

API:

client.command.run(‘free -m‘)

文件拷贝功能

功能:

CopyFileModule实现主控端向目标主机拷贝文件,类似于scp功能

命令:

#格式:
func ‘*‘ copyfile -f 本地文件 --remotepath 远程文件路径

#例:
func ‘*‘ copyfile -f /etc/sysctl.conf --remotepath /tmp/sysctl.conf

API:

client.local.copyfile.send(‘/etc/sysctl.conf‘,‘/tmp/sysctl.conf‘)

CPU信息模块

功能:

CPUModule获取远程主机CPU信息,支持按时间(秒)采样取平均值。

命令:

func ‘*‘ call cpu usage
func ‘*‘ call cpu usage 10 #取10秒内平均值

API:

client.cpu.usage(10)

磁盘信息模块

功能:

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

命令:

func ‘*‘ call disk usage
func ‘*‘ call disk usage /data

API:

client.disk.usage(‘/dev/sda3‘)

拷贝远程文件模块

功能:

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

API:

client.getfile.get(‘/etc/sysctl.conf‘,‘/tmp/‘)

iptables管理模块

功能:

IPtablesModule实现远程主机iptables配置

命令:

func ‘*‘ call iptables.port drop_to 53 192.168.0.0/24 udp src #丢弃从本地53端口发给远端192.168.0.0/24网段的包
func ‘*‘ call iptables drop_from 192.168.0.10 #丢弃从192.168.0.10接收到的包

API:

client.iptables.port.drop_to(8080,‘192.168.0.10‘,‘tcp‘,‘dst‘)

系统硬件信息模块

功能:

HardwareModule返回远程主机系统硬件信息

命令:

func ‘*‘ call hardware info
func ‘*‘ call hardware hal_info

API:

client.hardware.info(with_devices=True)
client.hardware.hal_info()

系统Mount管理模块

功能:

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

命令:

func ‘*‘ call mount list #获取远程主机的挂载信息
func ‘*‘ call mount mount /dev/sda3 /data #远程主机将/dev/sda3设备挂载到/data目录
func ‘*‘ call mount umount ‘/data‘ #卸载/data目录

API:

client.mount.list()
client.mount.umount(‘/data‘)
client.mount.mount(‘/dev/sda3‘,‘/data‘)

系统进程管理模块

功能:

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

命令:

func ‘*‘ call process info ‘aux‘ #获取进程信息,等同于ps aux
func ‘*‘ call process pkill nginx -9
func ‘*‘ call process kill nginx SIGHUP

API:

client.process.info(‘aux‘)
client.process.pkill(‘nginx‘,‘-9‘)
client.process.kill(‘nginx‘,‘SIGHUP‘)

系统服务管理模块

功能:

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

命令:

func ‘*‘ call service start nginx #启动nginx

API:

client.service.start(‘nginx‘)

系统内核参数管理模块

功能:

SysctlModule实现远程Linux主机系统内核参数管理

命令:

func ‘*‘ call sysctl list #获取所有内核参数
func ‘*‘ call sysctl get net.nf_conntrack_max #获取内核参数net.nf_conntrack_max
func ‘*‘ call sysctl set net.nf_conntrack_max 15449 #设置内核参数net.nf_conntrack_max

API:

client.sysctl.list()
client.sysctl.get(‘net.ipv4.icmp_echo_ignore_broadcasts‘)
client.sysctl.set(‘net.ipv4.tcp_syncookies‘,1)


参考资料:

根据刘天斯《Python自动化运维技术与最佳实践》整理

时间: 2024-10-12 10:39:14

Func系列2:常用模块及API的相关文章

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

说明 salt '*' sys.list_modules #列出当前版本支持的模块 API原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmd()方法来实现的.以下API实现test.ping的示例:(其他API调用只需要改变cmd即可) import salt.client client = salt.client.LocalClient() ret = client.cmd('*','test.ping) #cmd内格式:'<操作目标>','&l

Saltstack常用模块及API(4)

Saltstack提供了非常丰富的功能模块(用python所写),涉及操作系统的基础功能.常用工具支持等,当然也可以通过sys模块列出当前版本支持的模块 #salt '*' sys.list_modules 接下来抽取常见的模块进行介绍,同时也会列举模块的API使用方法.API的原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmda()方法来实现的.以下是API实现test.ping的示例: import salt.client client = sa

Ansible常用模块及API

Ansible安装 安装EPEL作为安装Ansible的yum源(CentOS6.4): rpm -Uvh http://ftp.linux.ncsu.edu/pub/epel/6/i386/epel-release-6-8.noarch.rpm 安装Ansible: yum install ansible -y 配置文件: 路径:/etc/ansible/hosts配置说明:webservers为组名,下面的ip或域名则是属于该组的主机. [webservers] 192.168.1.111

salt常用模块及API

saltstack提供了非常丰富的功能模块,涉及操作系统的基础功能,常用工具支持等,更多模块信息见官网模块介绍:https://docs.saltstack.com/en/latest/ref/modules/all/index.html 当然,也可以通过sys模块列出当前版本支持的模块.命令如下: #salt '*' sys.list_modules API的原理是通过调用master client模块,实例化一个LocalClient对象,再调用cmd()方法来实现的,以下是API实现tes

Saltstack-Salt常用模块及API

Salt提供了非常丰富的功能模块,涉及操作系统的基础功能.常用工具支持等,可以通过sys模块列出当前版本支持的模块. salt '*' sys.list_modules 781915e2:  - acl  - aliases  - alternatives  - apache  - archive  - artifactory  - at  - blockdev  - btrfs  - buildout  - cloud  - cmd ...... API的原理是通过调用master clien

saltstack一些常用模块和api调用方法

研究可执行模块的时候,发现很多自带的模块已经很完善,可以帮助我们完成日常工作了,这里写入自己的记录操作: 1.使用salt.clien调用接口操作举例: >>> import salt.client>>> client = salt.client.LocalClient()>>> ret = client.cmd('*','test.ping')>>> ret{'monitor': True} 我们看到调用了LocalClient()

ansible学习系列2-ansible常用模块使用

1. 查看支持的模块 [[email protected] ~]# ansible-doc -l 这里我们看下ansible的支持的模块个数 [[email protected] ~]# ansible-doc -l |wc -l #查看支持的模块个数 1039 [[email protected] ~]# ansible --version #查看我们的ansible版本号 ansible 2.3.1.0 config file = /etc/ansible/ansible.cfg confi

Saltstack常用模块及API之查看主机支持的模块清单

查看主机minion001支持的模块清单 sys.list_modules [[email protected] ~]# salt 'minion001' sys.list_modules minion001:     - acl     - aliases     - alternatives     - apache     - archive     - at     - blockdev     - bridge     - buildout     - cloud     - cmd

Saltstack 常用的模块及API

Saltstack提供了非常丰富的功能模块,设计操作系统的基础功能,常用工具支持等, 官网模块介绍 http://docs.saltstack.com/ref/modules/all/index.html 一 列出当前版本支持的模块 [[email protected]020 ~]# salt '*' sys.list_modules hzbj-tomcat-021: - acl - aliases - alternatives - apache - archive - artifactory