mirror of
https://github.com/k8s-at-home/charts.git
synced 2025-01-23 15:39:02 +00:00
uptimerobot chart
This commit is contained in:
parent
29f65c1a63
commit
a26cb4ac2f
23
uptimerobot/.helmignore
Normal file
23
uptimerobot/.helmignore
Normal file
@ -0,0 +1,23 @@
|
||||
# Patterns to ignore when building packages.
|
||||
# This supports shell glob matching, relative path matching, and
|
||||
# negation (prefixed with !). Only one pattern per line.
|
||||
.DS_Store
|
||||
# Common VCS dirs
|
||||
.git/
|
||||
.gitignore
|
||||
.bzr/
|
||||
.bzrignore
|
||||
.hg/
|
||||
.hgignore
|
||||
.svn/
|
||||
# Common backup files
|
||||
*.swp
|
||||
*.bak
|
||||
*.tmp
|
||||
*~
|
||||
# Various IDEs
|
||||
.project
|
||||
.idea/
|
||||
*.tmproj
|
||||
# OWNERS file for Kubernetes
|
||||
OWNERS
|
15
uptimerobot/Chart.yaml
Normal file
15
uptimerobot/Chart.yaml
Normal file
@ -0,0 +1,15 @@
|
||||
apiVersion: v1
|
||||
name: uptimerobot
|
||||
version: 1.0.0
|
||||
appVersion: 1.0.0
|
||||
description: A tool to get statistics from Uptime Robot and log it into InfluxDB
|
||||
keywords:
|
||||
- uptimerobot
|
||||
- influxdb
|
||||
home: https://github.com/billimek/node-influx-uptimerobot
|
||||
sources:
|
||||
- https://github.com/billimek/node-influx-uptimerobot
|
||||
- https://github.com/billimek/billimek-charts
|
||||
maintainers:
|
||||
- name: billimek
|
||||
email: jeff@billimek.com
|
4
uptimerobot/OWNERS
Normal file
4
uptimerobot/OWNERS
Normal file
@ -0,0 +1,4 @@
|
||||
approvers:
|
||||
- billimek
|
||||
reviewers:
|
||||
- billimek
|
70
uptimerobot/README.md
Normal file
70
uptimerobot/README.md
Normal file
@ -0,0 +1,70 @@
|
||||
# A tool to get statistics from Uptime Robot and log it into InfluxDB
|
||||
|
||||
![Screenshot](https://github.com/billimek/node-influx-uptimerobot/blob/master/docs/dashboard.png)
|
||||
|
||||
This tool allows you to run periodic uptimerobot data usage checks and save the results to Influxdb
|
||||
|
||||
## TL;DR;
|
||||
|
||||
```console
|
||||
$ helm repo add billimek https://raw.githubusercontent.com/billimek/helm-repo/master
|
||||
$ helm install billimek/uptimerobot
|
||||
```
|
||||
|
||||
## Introduction
|
||||
|
||||
This code is adopted from [this original repo](https://github.com/trojanc/node-influx-uptimerobot)
|
||||
|
||||
## Installing the Chart
|
||||
|
||||
To install the chart with the release name `my-release`:
|
||||
|
||||
```console
|
||||
$ helm install --name my-release billimek/uptimerobot
|
||||
```
|
||||
## Uninstalling the Chart
|
||||
|
||||
To uninstall/delete the `my-release` deployment:
|
||||
|
||||
```console
|
||||
$ helm delete my-release --purge
|
||||
```
|
||||
|
||||
The command removes all the Kubernetes components associated with the chart and deletes the release.
|
||||
|
||||
## Configuration
|
||||
|
||||
The configuration is set as a block of text through a configmap and mouted as a file in /src/config.ini Any value in this text block should match the defined uptimerobot configuration. There are several values here that will have to match our kubernetes configuration.
|
||||
|
||||
## Configuration
|
||||
|
||||
The following tables lists the configurable parameters of the Sentry chart and their default values.
|
||||
|
||||
| Parameter | Description | Default |
|
||||
| ------------------------------- | ------------------------------- | ---------------------------------------------------------- |
|
||||
| `image.repository` | uptimerobot image | `billimek/uptimerobotusage-for-influxdb` |
|
||||
| `image.tag` | uptimerobot image tag | `latest` |
|
||||
| `image.pullPolicy` | uptimerobot image pull policy | `IfNotPresent` |
|
||||
| `delay` | number of seconds to wait between collections | `300` |
|
||||
| `config.delay` | how many seconds to wait between checks | `3600` |
|
||||
| `config.influxdb.host` | InfluxDB hostname | `influxdb-influxdb` |
|
||||
| `config.influxdb.port` | InfluxDB port | `8086` |
|
||||
| `config.influxdb.database` | InfluxDB database | `uptimerobot` |
|
||||
| `config.influxdb.protocol` | InfluxDB protocol | `http` |
|
||||
| `config.uptimerobot.apikey` | uptimerobot API key (REQUIRED) | `someapikey` |
|
||||
|
||||
Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. For example,
|
||||
|
||||
```console
|
||||
$ helm install --name my-release \
|
||||
--set config.uptimerobot.apikey=thisismyapikey \
|
||||
billimek/uptimerobot
|
||||
```
|
||||
|
||||
Alternatively, a YAML file that specifies the values for the above parameters can be provided while installing the chart. For example,
|
||||
|
||||
```console
|
||||
$ helm install --name my-release -f values.yaml billimek/uptimerobot
|
||||
```
|
||||
|
||||
Read through the [values.yaml](values.yaml) file. It has several commented out suggested values.
|
7
uptimerobot/templates/NOTES.txt
Normal file
7
uptimerobot/templates/NOTES.txt
Normal file
@ -0,0 +1,7 @@
|
||||
You can connect to the container running uptimerobot. To open a shell session in the pod run the following:
|
||||
|
||||
- kubectl exec -i -t --namespace {{ .Release.Namespace }} $(kubectl get pods --namespace {{ .Release.Namespace }} -l app={{ template "uptimerobot.fullname" . }} -o jsonpath='{.items[0].metadata.name}') /bin/sh
|
||||
|
||||
To trail the logs for the uptimerobot pod run the following:
|
||||
|
||||
- kubectl logs -f --namespace {{ .Release.Namespace }} $(kubectl get pods --namespace {{ .Release.Namespace }} -l app={{ template "uptimerobot.fullname" . }} -o jsonpath='{ .items[0].metadata.name }')
|
27
uptimerobot/templates/_helpers.tpl
Normal file
27
uptimerobot/templates/_helpers.tpl
Normal file
@ -0,0 +1,27 @@
|
||||
{{/* vim: set filetype=mustache: */}}
|
||||
|
||||
{{/*
|
||||
Expand the name of the chart.
|
||||
*/}}
|
||||
{{- define "uptimerobot.name" -}}
|
||||
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||
{{- end -}}
|
||||
|
||||
|
||||
{{/*
|
||||
Create a default fully qualified app name.
|
||||
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||
If release name contains chart name it will be used as a full name.
|
||||
*/}}
|
||||
{{- define "uptimerobot.fullname" -}}
|
||||
{{- if .Values.fullnameOverride -}}
|
||||
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
|
||||
{{- else -}}
|
||||
{{- $name := default .Chart.Name .Values.nameOverride -}}
|
||||
{{- if contains $name .Release.Name -}}
|
||||
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
|
||||
{{- else -}}
|
||||
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
|
||||
{{- end -}}
|
||||
{{- end -}}
|
||||
{{- end -}}
|
22
uptimerobot/templates/configmap.yaml
Normal file
22
uptimerobot/templates/configmap.yaml
Normal file
@ -0,0 +1,22 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: {{ template "uptimerobot.fullname" . }}
|
||||
labels:
|
||||
app: {{ template "uptimerobot.name" . }}
|
||||
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||
release: "{{ .Release.Name }}"
|
||||
heritage: "{{ .Release.Service }}"
|
||||
data:
|
||||
config.json: |
|
||||
{
|
||||
"uptimerobot" : {
|
||||
"apikey" : "{{ .Values.config.uptimerobot.apikey }}"
|
||||
},
|
||||
"influx" : {
|
||||
"host" : "{{ .Values.config.influxdb.host }}",
|
||||
"port" : {{ .Values.config.influxdb.port }},
|
||||
"protocol" : "{{ .Values.config.influxdb.protocol }}",
|
||||
"database" : "{{ .Values.config.influxdb.database }}"
|
||||
}
|
||||
}
|
45
uptimerobot/templates/deployment.yaml
Normal file
45
uptimerobot/templates/deployment.yaml
Normal file
@ -0,0 +1,45 @@
|
||||
apiVersion: extensions/v1beta1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: {{ template "uptimerobot.fullname" . }}
|
||||
labels:
|
||||
app: {{ template "uptimerobot.name" . }}
|
||||
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
|
||||
release: {{ .Release.Name }}
|
||||
heritage: {{ .Release.Service }}
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: {{ template "uptimerobot.name" . }}
|
||||
release: {{ .Release.Name }}
|
||||
replicas: {{ default 1 .Values.replicas }}
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: {{ template "uptimerobot.name" . }}
|
||||
release: {{ .Release.Name }}
|
||||
spec:
|
||||
containers:
|
||||
- name: {{ .Chart.Name }}
|
||||
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
|
||||
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
||||
env:
|
||||
- name: DELAY
|
||||
value: "{{ .Values.delay }}"
|
||||
resources:
|
||||
{{ toYaml .Values.resources | indent 12 }}
|
||||
volumeMounts:
|
||||
- name: {{ template "uptimerobot.name" . }}
|
||||
mountPath: /usr/src/node-influx-uptimerobot/config.json
|
||||
subPath: config.json
|
||||
{{- if .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{ toYaml .Values.nodeSelector | indent 8 }}
|
||||
{{- end }}
|
||||
volumes:
|
||||
- name: {{ template "uptimerobot.name" . }}
|
||||
configMap:
|
||||
name: {{ template "uptimerobot.fullname" . }}
|
||||
items:
|
||||
- key: config.json
|
||||
path: config.json
|
31
uptimerobot/values.yaml
Normal file
31
uptimerobot/values.yaml
Normal file
@ -0,0 +1,31 @@
|
||||
# Default values for comcast.
|
||||
# This is a YAML-formatted file.
|
||||
# Declare variables to be passed into your templates.
|
||||
replicaCount: 1
|
||||
image:
|
||||
repository: billimek/uptimerobot-influxdb
|
||||
tag: latest
|
||||
pullPolicy: IfNotPresent
|
||||
resources: {}
|
||||
# We usually recommend not to specify default resources and to leave this as a conscious
|
||||
# choice for the user. This also increases chances charts run on environments with little
|
||||
# resources, such as Minikube. If you do want to specify resources, uncomment the following
|
||||
# lines, adjust them as necessary, and remove the curly braces after 'resources:'.
|
||||
# limits:
|
||||
# cpu: 100m
|
||||
# memory: 128Mi
|
||||
# requests:
|
||||
# cpu: 100m
|
||||
# memory: 128Mi
|
||||
nodeSelector: {}
|
||||
delay: 300 # number of seconds to wait between collections
|
||||
config:
|
||||
influxdb:
|
||||
# host/port/database are mandatory - change as needed
|
||||
host: influxdb-influxdb
|
||||
port: 8086
|
||||
protocol: http
|
||||
database: uptimerobot
|
||||
uptimerobot:
|
||||
# API key is mandatory and must be populated
|
||||
apikey: someapikey
|
Loading…
Reference in New Issue
Block a user