74 lines
2.2 KiB
Python
Executable file
74 lines
2.2 KiB
Python
Executable file
#!/usr/bin/env python
|
|
|
|
#
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance
|
|
# with the License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on an
|
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
# KIND, either express or implied. See the License for the
|
|
# specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
|
|
import os
|
|
import optparse
|
|
import sys
|
|
import socket
|
|
from time import time, strftime, gmtime, sleep
|
|
from qmf.console import Console, Session
|
|
|
|
class EventConsole(Console):
|
|
def event(self, broker, event):
|
|
print event
|
|
|
|
def brokerConnected(self, broker):
|
|
print strftime("%c", gmtime(time())), "NOTIC qpid-printevents:brokerConnected broker=%s" % broker.getUrl()
|
|
|
|
def brokerDisconnected(self, broker):
|
|
print strftime("%c", gmtime(time())), "NOTIC qpid-printevents:brokerDisconnected broker=%s" % broker.getUrl()
|
|
|
|
|
|
##
|
|
## Main Program
|
|
##
|
|
def main():
|
|
_usage = "%prog [options] [broker-addr]..."
|
|
_description = \
|
|
"""Collect and print events from one or more Qpid message brokers. If no broker-addr is
|
|
supplied, %prog will connect to 'localhost:5672'.
|
|
broker-addr is of the form: [username/password@] hostname | ip-address [:<port>]
|
|
ex: localhost, 10.1.1.7:10000, broker-host:10000, guest/guest@localhost
|
|
"""
|
|
p = optparse.OptionParser(usage=_usage, description=_description)
|
|
|
|
options, arguments = p.parse_args()
|
|
if len(arguments) == 0:
|
|
arguments.append("localhost")
|
|
|
|
console = EventConsole()
|
|
session = Session(console, rcvObjects=False, rcvHeartbeats=False, manageConnections=True)
|
|
brokers = []
|
|
for host in arguments:
|
|
brokers.append(session.addBroker(host))
|
|
|
|
try:
|
|
while (True):
|
|
sleep(10)
|
|
except KeyboardInterrupt:
|
|
for broker in brokers:
|
|
session.delBroker(broker)
|
|
print
|
|
sys.exit(0)
|
|
|
|
if __name__ == '__main__':
|
|
main()
|
|
|