Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/onzack/rkm

Remote Kubernetes Monitoring (RKM) monitors as much as necessary and as little as possible to keep things simple and easy.
https://github.com/onzack/rkm

grafana influxdb kubernetes kubernetes-monitoring monitoring

Last synced: about 1 month ago
JSON representation

Remote Kubernetes Monitoring (RKM) monitors as much as necessary and as little as possible to keep things simple and easy.

Awesome Lists containing this project

README

        

# RKM - Remote Kubernetes Monitoring
Simple monitoring tool for local and remote Kubernetes clusters.
Used technonlogies:

* Go
* Docker
* Bash
* InfluxDB
* Grafana

# Architecture
![A Sample Graph for visualization ](./docs/rkm.png)

# Grafana Dashbaord
![Grafana Dashboard ](./docs/rkm-mission-control.png)

# Installation

## RKM Mission Control

### Install InfluxDB
The RKM-Outpost metrics are stored in an InfluxDB.
If you don't already have an InfluxDB, install one for example with the [InfluxDB Helm Chart](https://github.com/influxdata/helm-charts/tree/master/charts/influxdb) on Kubernetes.
The InfluxDB and RKM-Outpost have a few dependencies:
1. The InfluxDB must be reachable for RKM-Outpost
3. An InfluxDB database for the RKM-Outpost metrics, for example "rkm"
4. User and password for the InfluxDB database

### Install Grafana
If your don't have a Grafana instance, install one for example with the [Grafana Helm Chart](https://github.com/helm/charts/tree/master/stable/grafana) on Kubernetes. Grafana must have access to the InfluxDB database.
Add the InfluxDB database as a datasource to Grafana and import the [RKM Mission Control Dashboard](https://github.com/onzack/rkm/blob/main/Grafana/rkm-mission-control-dashboard.json).

## RKM Outpost
Install RKM Outpost Helm Chart:
1. Create rkm-outpost namespace:
`kubectl create namespace rkm-outpost`
2. Create secret for InfluxDB authentication:
`kubectl create secret generic rkm-secrets --from-literal=INFLUXDB_USER= --from-literal=INFLUXDB_PW= -n rkm-outpost`
3. Clone this repository:
`git clone https://github.com/onzack/rkm.git`
4. Create and adjust the custom-values.yaml file for your cluster:
`cp ./rkm/deployments/kubernetes/helm/rkm-outpost/custom-values.yaml cluster-1-values.yaml`
`vim custom-values.yaml`
**Importat**
rkm-outpost does not have proxy support yet. We are working on it.

5. Install Helm Chart:
`helm install -f custom-values.yaml -n rkm-outpost rkm-outpost ./rkm/deployments/kubernetes/helm/rkm-outpost`

# Docker repositories
RKM-Outpost: https://quay.io/repository/onzack/rkm-outpost
RKM-Outpost operator: https://quay.io/repository/onzack/rkm-outpost-operator

# Licence
Copyright 2021 [ONZACK AG](https://www.onzack.com)

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

[http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0)

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.