This repository has been archived by the owner on Nov 8, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 294
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Documentation for stand-alone mode & plugin diagnostics
- Loading branch information
1 parent
9377eae
commit 6b992c4
Showing
2 changed files
with
108 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# Plugin Diagnostics | ||
|
||
Plugin diagnostics provides a simple way to verify that a plugin is capable of running without requiring the plugin to be loaded and a task started. | ||
This feature works for collector plugins written using one of our snap-plugin-libs ([snap-plugin-lib-go](https://github.com/intelsdi-x/snap-plugin-lib-go), [snap-plugin-lib-py](https://github.com/intelsdi-x/snap-plugin-lib-py), [snap-plugin-lib-cpp](https://github.com/intelsdi-x/snap-plugin-lib-cpp)). | ||
|
||
Plugin diagnostics delivers following information: | ||
- runtime details (plugin name, version, etc.) | ||
- configuration details | ||
- list of metrics expose by the plugin | ||
- metrics with their values that can be collected right now | ||
- and times required to retrieve this information | ||
|
||
## Running plugin diagnostics | ||
It is possible to run plugin diagnostics without any arguments (default values are used), e.g.: | ||
``` | ||
$ ./snap-plugin-collector-psutil | ||
``` | ||
or with plugin configuration in the form of a JSON: | ||
``` | ||
$ ./snap-plugin-collector-psutil --config {\"mouting_points\":\"/dev/sda\"} | ||
``` | ||
|
||
For example: | ||
|
||
``` | ||
$ ./snap-plugin-collector-psutil | ||
Runtime Details: | ||
PluginName: psutil, Version: 14 | ||
RPC Type: gRPC, RPC Version: 1 | ||
Operating system: linux | ||
Architecture: amd64 | ||
Go version: go1.7 | ||
printRuntimeDetails took 11.878µs | ||
Config Policy: | ||
NAMESPACE KEY TYPE REQUIRED DEFAULT MINIMUM MAXIMUM | ||
intel.psutil.disk mount_points string false | ||
printConfigPolicy took 67.654µs | ||
Metric catalog will be updated to include: | ||
Namespace: /intel/psutil/load/load1 | ||
Namespace: /intel/psutil/load/load5 | ||
Namespace: /intel/psutil/load/load15 | ||
Namespace: /intel/psutil/cpu/*/softirq | ||
Namespace: /intel/psutil/cpu/cpu-total/softirq | ||
[...] | ||
printMetricTypes took 504.483µs | ||
Metrics that can be collected right now are: | ||
Namespace: /intel/psutil/load/load1 Type: float64 Value: 1.48 | ||
Namespace: /intel/psutil/load/load5 Type: float64 Value: 1.68 | ||
Namespace: /intel/psutil/load/load15 Type: float64 Value: 1.65 | ||
Namespace: /intel/psutil/cpu/cpu0/softirq Type: float64 Value: 20.36 | ||
Namespace: /intel/psutil/cpu/cpu1/softirq Type: float64 Value: 13.62 | ||
Namespace: /intel/psutil/cpu/cpu2/softirq Type: float64 Value: 9.96 | ||
Namespace: /intel/psutil/cpu/cpu3/softirq Type: float64 Value: 3.6 | ||
Namespace: /intel/psutil/cpu/cpu4/softirq Type: float64 Value: 1.42 | ||
Namespace: /intel/psutil/cpu/cpu5/softirq Type: float64 Value: 0.69 | ||
Namespace: /intel/psutil/cpu/cpu6/softirq Type: float64 Value: 0.54 | ||
Namespace: /intel/psutil/cpu/cpu7/softirq Type: float64 Value: 0.31 | ||
Namespace: /intel/psutil/cpu/cpu-total/softirq Type: float64 Value: 50.52 | ||
[...] | ||
printCollectMetrics took 7.470091ms | ||
showDiagnostics took 8.076025ms | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
# Stand-alone mode | ||
|
||
Stand-alone mode enables plugin launching on different machine than Snap daemon (`snapteld`). | ||
This feature works for plugins written using one of our snap-plugin-libs ([snap-plugin-lib-go](https://github.com/intelsdi-x/snap-plugin-lib-go), | ||
[snap-plugin-lib-py](https://github.com/intelsdi-x/snap-plugin-lib-py), [snap-plugin-lib-cpp](https://github.com/intelsdi-x/snap-plugin-lib-cpp)). | ||
|
||
## Running a plugin in stand-alone mode | ||
To run a plugin in stand-alone mode, you must start it with the `--stand-alone` flag, e.g.: | ||
``` | ||
$ ./snap-plugin-collector-psutil --stand-alone | ||
``` | ||
|
||
A plugin running in stand-alone mode creates a HTTP server for communication with the Snap framework. | ||
By default the plugin listens on port `8182`. | ||
|
||
To specify a different listening port, use the `--stand-alone-port` flag, e.g.: | ||
``` | ||
$ ./snap-plugin-collector-psutil --stand-alone --stand-alone-port 8183 | ||
``` | ||
## Loading a plugin | ||
When loading a plugin in stand-alone mode into `snapteld` you must provide a URL to indicate which | ||
machine the plugin is running (IP address/hostname with port number), e.g.: | ||
|
||
``` | ||
$ snaptel plugin load http://127.0.0.1:8182 | ||
``` | ||
|
||
or | ||
|
||
``` | ||
$ snaptel plugin load http://localhost:8182 | ||
``` | ||
|
||
The rest of operations remains exactly the same as is it for plugins running in regular mode. | ||
|
||
## Notice | ||
|
||
If the connection between `snapteld` and the plugin running in stand-alone mode is disrupted | ||
it will try to reconnect. If it is unable to reconnect the plugin will be unloaded, | ||
metric catalog updated, and any dependent tasks will stop, | ||
see also [github issue](https://github.com/intelsdi-x/snap/issues/1697). |