An AppDynamics extension to be used with a stand alone Java machine agent to provide metrics for Zookeeper servers. This extensions uses 4 letter zookeeper command (stat, mntr) and extract metrics from the server.
Java 8
to build the extension artifact from source. You can check the java version used in maven using command mvn -v
or mvn --version
. If your maven is using some other java version then please download java 8 for your platform and set JAVA_HOME parameter before starting maven.git clone <repoUrl>
command.ZookeeperMonitor-VERSION.zip
from target
directory into the "<MachineAgent_Dir>/monitors" directory.Please place the extension in the "monitors" directory of your Machine Agent installation directory. Do not place the extension in the "extensions" directory of your Machine Agent installation directory.
Configure the zookeeper instances by editing the config.yml file in <MACHINE_AGENT_HOME>/monitors/ZookeeperMonitor/
.
servers:
- host: "localhost"
port: 2181
name: "zh1"
Provide zookeeper host, port and display name for your zookeeper server.
You can configure multiple zookeeper servers like below:
servers:
- host: "localhost"
port: 2181
name: "zh1"
- host: "localhost"
port: 2182
name: "zh2"
Please make sure to provide unique display names if multiple servers are configured.
Always include one thread per server + 1.
For example, if you have 4 zookeeper servers configured, then number of threads required are 5 (4 thread per server + 1 to run main task)
Please copy all the contents of the config.yml file and go to https://jsonformatter.org/yaml-validator . On reaching the website, paste the contents and press the “Validate YAML” button. Resolve the errors if there are any.
You can add/remove metrics of your choice by modifying the provided metrics.xml file. Please look at how the metrics have been defined and follow the same convention when adding new metrics. You do have the ability to also chose your Rollup types as well as for each metric as well as set an alias name that you would like displayed on the metric browser.
The list of metrics provided is self-configurable. The metrics are extracted by running the commands listed in the Zookeeper Documentation.
The commands and the fields to be extracted can be configured in the config.yml file mentioned below.
We also send "ruok" with a value 0 when an error occurs and 1 when the metrics collection is successful.
We support cluster level metrics only if each node in the cluster has a separate machine agent installed on it. There are two configurations required for this setup
Make sure that nodes belonging to the same cluster has the same in the <MACHINE_AGENT_HOME>/conf/controller-info.xml, we can gather cluster level metrics. The tier-name here should be your cluster name.
Make sure that in every node in the cluster, the <MACHINE_AGENT_HOME>/monitors/ZookeeperMonitor/config.yml should emit the same metric path.
Please visit Encryption Guidelines to get detailed instructions on password encryption. The steps in this document will guide you through the whole process.
If you want to use password encryption, please send arguments as connectionProperties. You will have to fill in the encrypted Password and Encryption Key fields in the config but you will also have to give an empty "" value to the password field and the encrypted password will be automatically picked up.
Workbench is an inbuilt feature provided with each extension in order to assist you to fine tune the extension setup before you actually deploy it on the controller. Please review the following document on How to use the Extensions WorkBench.
Please follow the steps listed in this troubleshooting-document in order to troubleshoot your issue. These are a set of common issues that customers might have faced during the installation of the extension.
Check if below command output is successful
>echo ruok | nc <host> <port>
imok //expected output
>echo <command> | nc <host> <port> //command can be any like stat, mntr etc.
>echo stat | nc localhost 2181
Zookeeper version: 3.4.14-4c25d480e66aadd371de8bd2fd8da255ac140bcf, built on 03/06/2019 16:18 GMT
Clients:
/127.0.0.1:49398[1](queued=0,recved=2999,sent=3000)
/0:0:0:0:0:0:0:1:53911[0](queued=0,recved=1,sent=0)
Latency min/avg/max: 0/0/15
Received: 3028
Sent: 3028
Connections: 2
Outstanding: 0
Zxid: 0x1088
Mode: standalone
Node count: 133
Always feel free to fork and contribute any changes directly via GitHub.
Name | Version |
---|---|
Extension Version | 1.1.1 |
Product Tested on | 3.4.14 |
Last Update | 06/01/2021 |
Changes list | ChangeLog |
Note: While extensions are maintained and supported by customers under the open-source licensing model, they interact with agents and Controllers that are subject to AppDynamics’ maintenance and support policy. Some extensions have been tested with AppDynamics 4.5.13+ artifacts, but you are strongly recommended against using versions that are no longer supported.
Owner
Contributors
Categories
ObservabilityProducts
AppDynamicsProgramming Languages
JavaLicense
Code Exchange Community
Get help, share code, and collaborate with other developers in the Code Exchange community.View Community