diff options
author | nico <nico@magicbroccoli.de> | 2019-09-22 17:07:28 +0200 |
---|---|---|
committer | nico <nico@magicbroccoli.de> | 2019-09-22 17:07:28 +0200 |
commit | 1065bab81cd4106f3bbfd48882a09f34d2e06bd7 (patch) | |
tree | 7359fc03166a2b0f36968917edd9eda2a7dcd56b | |
parent | bde6e46db4f724c36bb29d99cab172680573c29c (diff) |
bad documentation
+ add more documentation
* correct bad documentation
-rw-r--r-- | README.md | 40 |
1 files changed, 27 insertions, 13 deletions
@@ -1,28 +1,42 @@ # Nextcloud Munin Plugin [![CodeFactor](https://www.codefactor.io/repository/github/mightybroccoli/nextcloud-munin-py/badge/master)](https://www.codefactor.io/repository/github/mightybroccoli/nextcloud-munin-py/overview/master) -Within this repository there are some basic Munin Plugins gathering information from the NextCloud external API. I choose to also include a multigraph plugin `nextcloud_multi.py` which does everything the other plugins dynamically. +This repository contains some basic Munin Plugins for gathering information from the NextCloud external API. To further simplify the monitory process I choose to also include a multigraph plugin `nextcloud_multi.py` which does everything the other plugins do in a single plugin. There are requirements for using a multigraph plugin which can be read up here : [Munin-Monitoring.org/multigraphing](http://guide.munin-monitoring.org/en/latest/plugin/multigraphing.html) ## install -To use these plugins properly some configuration parameters need to be added to the plugin-config `/etc/munin/plugin-config.d/custom-config`. +### requirements +The Python environment need to have access to the [requests](https://github.com/psf/requests) module. It is possible to run the plugins in a virtual environment, with the virtual environment tool of your choice. +The `requirements.txt` file contains all necessary libraries pip will install. ``` -[nextcloud_*] -url = https://URL.TO.YOUR.NEXTCLOUD.tld/ocs/v2.php/apps/serverinfo/api/v1/info -username = username -password = password or logintoken +virtualenv -p python3 /path/to/your/venv +pip install -r requirements.txt ``` -To install these plugins, you just have to symlink those plugins you would like to activate to the munin plugin directory eg. `/etc/munin/plugins/`. Or if you want to use the multigraph plugin only symlink that one the the munin plugin directory. -After this has been done the munin-node needs to be restarted to facilitate the new plugins. -`systemctl restart munin-node` - -It is possible to run the plugins in a virtual environment, for that the environment needs to be initialized and the required packages to be installed. +#### Tip +Unfortunately you need to invoke the plugin with the virtual environment runtime. Thus you have to change the shebang from '#!/usr/bin/env python3' to the python3 path, or you could simply add a wrapper script. +That way you only modify untracked files which helps with git updates. +```bash +#!/bin/bash +# path to my virtual env python runtime # the unchanged nextcloud_multi.py file +/usr/share/munin/custom-plugins/nextcloud-munin-py/venv/bin/python /usr/share/munin/custom-plugins/nextcloud-munin-py/nextcloud_multi.py $@ ``` -virtualenv -p python3 /path/to/your/venv -pip install -r requirements.txt +### configuration +To use these plugins properly some configuration parameters need to be added to the plugin-config `/etc/munin/plugin-config.d/z-custom-config`. +``` +[nextcloud_*] +env.username username +env.password password or logintoken +env.url https://URL.TO.YOUR.NEXTCLOUD.tld/ocs/v2.php/apps/serverinfo/api/v1/info ``` +### activating the plugin +Finally you need to symlink the plugins you would like to activate into the munin plugin directory eg. `/etc/munin/plugins/`. +Or if you want to use the multigraph plugin only symlink that one the the munin plugin directory. + +After this has been done the munin-node needs to be restarted to facilitate the new plugins. +`systemctl restart munin-node` + ### everything working? To check if everything is working as expected check if the plugins are listed and actually gather data. ``` |