This is a very simple console tool for monitoring column families read/write activities at remote cassandra host.
You can see which column families mostly affects disk utilization in near real time.
-
When not using a properties file
java -jar ctop.jar <host:jmx_port> <key_space> [interval_sec(default: 10)]
-
When using a properties file. When not passed ctop.properties will be loaded from classpath with argument -p
java -jar ctop.jar -p [<propertyFilePath>]
-
To print help usage
java -jar ctop.jar -h
Sample properties file is given below
#ctop confs, defaults to 10 when not given
ctop.interval.sec=1
#cassandra confs
cassandra.host=<cassandraHost defaults to 127.0.0.1 when not given>
cassandra.jmx.port=<jmxPort defaults to 7199 when not given>
cassandra.jmx.username=<jmxUsername if auth enabled>
cassandra.jmx.pw=<jmxPassword if auth enabled>
cassandra.keyspace=<keyspace name or regex>
#target keyspace in Cassandra, possible values are KEYSPACE, REGEX, ALL
cassandra.target.type=REGEX
#metrics reporter confs, possible values are GRAPHITE, CONSOLE and NONE
metrics.type=GRAPHITE
#graphite reporter confs
graphite.prefix=<graphitePrefix and defaults to ctop>
graphite.host=<graphiteHost>
graphite.port=<graphitePort and defaults to 2003 when not given>
graphite.freq=<frequencyInterval in minutes and defaults to 1 when not given>
Default refresh interval is 10 seconds.
The application by defaults prints the metrics on console. When target type is set to KEYSPACE it will print all reads and writes metrics for the given specific keyspace.
When target type is ALL it will print all metrics for all keyspaces including system keyspace.
Cases on a hosted production the keyspaces follow company name prefixed and so REGEX is another option as JMX allows it. Our case all our keyspaces prefixed with cassks_keyspacename and so the recommended value for cassandra.keyspace is cassks_* and in that case all keyspace data is printed except the system keyspaces.
Graphite and Console metrics publishing is enabled when metrics.type is set to GRAPHITE or CONSOLE. To disable it the value should be NONE.
When enabled for Graphite there are metrics like
- com.pixonic.ctop.metrics.MetricsCollector.totalRead
- com.pixonic.ctop.metrics.MetricsCollector.totalWrite
is pushed as global count and for each specific keyspace metrics like
- keyspacename.table.tablename.read
- keyspacename.table.tablename.write
are published to graphiteHost.
Example: java -jar ctop.jar -p /Users/johndoe/Documents/ctop.properties
Use of -h as an argument prints the help/usage
Example: java -jar ctop.jar -h
============================
== Usage =================
============================
java -jar ctop.jar -p [<propertyFilePath> when not passed ctop.properties will be loaded from classpath with argument -p]
java -jar ctop.jar <host:jmx_port> <key_space> [interval_sec(default: 10)] when doesn't want to use any properties file
java -jar ctop.jar -h to print help
============================
Please note that to have CONSOLE or GRAPHITE reporting a properties file should be used to load the app. Run time command line arguments will just print in the console itself.
Use Ctrl+C to exit.
Java 8 is required.
mvn package