Monitoring C++ applications
- by Scott A
We're implementing a new centralized monitoring solution (Zenoss). Incorporating servers, networking, and Java programs is straightforward with SNMP and JMX.
The question, however, is what are the best practices for monitoring and managing custom C++ applications in large, heterogenous (Solaris x86, RHEL Linux, Windows) environments?
Possibilities I see are:
Net SNMP
Advantages
single, central daemon on each server
well-known standard
easy integration into monitoring solutions
we run Net SNMP daemons on our servers already
Disadvantages:
complex implementation (MIBs, Net SNMP library)
new technology to introduce for the C++ developers
rsyslog
Advantages
single, central daemon on each server
well-known standard
unknown integration into monitoring solutions (I know they can do alerts based on text, but how well would it work for sending telemetry like memory usage, queue depths, thread capacity, etc)
simple implementation
Disadvantages:
possible integration issues
somewhat new technology for C++ developers
possible porting issues if we switch monitoring vendors
probably involves coming up with an ad-hoc communication protocol (or using RFC5424 structured data; I don't know if Zenoss supports that without custom Zenpack coding)
Embedded JMX (embed a JVM and use JNI)
Advantages
consistent management interface for both Java and C++
well-known standard
easy integration into monitoring solutions
somewhat simple implementation (we already do this today for other purposes)
Disadvantages:
complexity (JNI, thunking layer between native C++ and Java, basically writing the management code twice)
possible stability problems
requires a JVM in each process, using considerably more memory
JMX is new technology for C++ developers
each process has it's own JMX port (we run a lot of processes on each machine)
Local JMX daemon, processes connect to it
Advantages
single, central daemon on each server
consistent management interface for both Java and C++
well-known standard
easy integration into monitoring solutions
Disadvantages:
complexity (basically writing the management code twice)
need to find or write such a daemon
need a protocol between the JMX daemon and the C++ process
JMX is new technology for C++ developers
CodeMesh JunC++ion
Advantages
consistent management interface for both Java and C++
well-known standard
easy integration into monitoring solutions
single, central daemon on each server when run in shared JVM mode
somewhat simple implementation (requires code generation)
Disadvantages:
complexity (code generation, requires a GUI and several rounds of tweaking to produce the proxied code)
possible JNI stability problems
requires a JVM in each process, using considerably more memory (in embedded mode)
Does not support Solaris x86 (deal breaker)
Even if it did support Solaris x86, there are possible compiler compatibility issues (we use an odd combination of STLPort and Forte on Solaris
each process has it's own JMX port when run in embedded mode (we run a lot of processes on each machine)
possibly precludes a shared JMX server for non-C++ processes (?)
Is there some reasonably standardized, simple solution I'm missing?
Given no other reasonable solutions, which of these solutions is typically used for custom C++ programs?
My gut feel is that Net SNMP is how people do this, but I'd like other's input and experience before I make a decision.