Skip to content

baseride/pyZabbixSender

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pyZabbixSender

Python implementation of zabbix_sender.

Take a look at the wiki page to get in deep details.

This is a module that allows you to send data to a Zabbix server using Python. You don't need the zabbix_sender binary anymore.

Users of the Twisted library can use an asynchronous version of the sender.

Has been tested with Python 2.5.1 and 2.7

Python 2.5.1 doesn't have a json module (needed to implement zabbix protocol), so you can use simplejson instead.

Installation

Install the package using a pip from the original repository:

pip install "git+git://github.com/kmomberg/pyZabbixSender.git"

or from one of the mirrors, like:

pip install "git+git://github.com/baseride/pyZabbixSender.git"

Usage

Here's a small example (synchronous code):

from pyZabbixSender.sy import syZabbixSender

# Creating a sender object
z = syZabbixSender(server="zabbix-server", port=10051)

# Adding data (without timestamp)
z.addData(hostname="test_host", key="test_trap_1", value="12")
z.addData("test_host", "test_trap_2", "2.43")

# Adding data (with timestamp)
z.addData("test_host", "test_trap_2", "2.43", 1365787627)

# Ready to send your data?
results = z.sendData()

# Check if everything was sent as expected
if not results[0][0]:
  print "oops! Sending data has been failed"
elif results[0][1]['info']['processed'] != 3:
  print "oops! Zabbix doesn't recognize passed identities"

# Clear internal data to start populating again
z.clearData()

# Wants to send a single data point right now?
z.sendSingle("test_host","test_trap","12")

The asynchronous code looks mostly the same, except asynchronous calls to send...() functions:

from pyZabbixSender.tx import txZabbixSender
from twisted.internet import reactor, defer

@defer.inlineCallbacks
def test():
  # Creating a sender object
  z = txZabbixSender(server="zabbix-server", port=10051)

  # Adding data (without timestamp)
  z.addData(hostname="test_host", key="test_trap_1", value="12")
  z.addData("test_host", "test_trap_2", "2.43")

  # Adding data (with timestamp)
  z.addData("test_host", "test_trap_2", "2.43", 1365787627)

  # Ready to send your data?
  results = yield z.sendData() # NOTE an asynchronous call

  # Check if everything was sent as expected
  if not results[0][0]:
    print "oops! Sending data has been failed"
  elif results[0][1]['info']['processed'] != 3:
    print "oops! Zabbix doesn't recognize passed identities"

  # Clear internal data to start populating again
  z.clearData()

  # Wants to send a single data point right now?
  yield z.sendSingle("test_host","test_trap","12") # NOTE an asynchronous call

The backward-compatible code looks mostly the same, except return value processing:

from pyZabbixSender import pyZabbixSender

# Creating a sender object
z = pyZabbixSender(server="zabbix-server", port=10051)

# Adding data (without timestamp)
z.addData(hostname="test_host", key="test_trap_1", value="12")
z.addData("test_host", "test_trap_2", "2.43")

# Adding data (with timestamp)
z.addData("test_host", "test_trap_2", "2.43", 1365787627)

# Ready to send your data?
results = z.sendData()

# Check if everything was sent as expected
if results[0][0] != z.RC_OK:
  print "oops!"

# Clear internal data to start populating again
z.clearData()

# Wants to send a single data point right now?
z.sendSingle("test_host","test_trap","12")

There are some more options, so take a look at the wiki page and discover how easy is to use it ;)

License

GNU GPLv2

About

Python implementation of zabbix_sender

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%