KubraGen Builder: Prometheus Stack
Project description
KubraGen Builder: Prometheus Stack
kg_prometheusstack is a builder for KubraGen that deploys a Prometheus stack in Kubernetes.
The stack consist of Prometheus (required), Grafana, Kube-State-Metrics and Node Exporter.
KubraGen is a Kubernetes YAML generator library that makes it possible to generate configurations using the full power of the Python programming language.
- Website: https://github.com/RangelReale/kg_prometheusstack
- Repository: https://github.com/RangelReale/kg_prometheusstack.git
- Documentation: https://kg_prometheusstack.readthedocs.org/
- PyPI: https://pypi.python.org/pypi/kg_prometheusstack
Example
from kg_prometheus import PrometheusConfigFile, PrometheusConfigFileOptions
from kubragen import KubraGen
from kubragen.consts import PROVIDER_GOOGLE, PROVIDERSVC_GOOGLE_GKE
from kubragen.object import Object
from kubragen.option import OptionRoot
from kubragen.options import Options
from kubragen.output import OutputProject, OD_FileTemplate, OutputFile_ShellScript, OutputFile_Kubernetes, \
OutputDriver_Print
from kubragen.provider import Provider
from kg_prometheusstack import PrometheusStackBuilder, PrometheusStackOptions
kg = KubraGen(provider=Provider(PROVIDER_GOOGLE, PROVIDERSVC_GOOGLE_GKE), options=Options({
'namespaces': {
'mon': 'app-monitoring',
},
}))
out = OutputProject(kg)
shell_script = OutputFile_ShellScript('create_gke.sh')
out.append(shell_script)
shell_script.append('set -e')
#
# OUTPUTFILE: app-namespace.yaml
#
file = OutputFile_Kubernetes('app-namespace.yaml')
file.append([
Object({
'apiVersion': 'v1',
'kind': 'Namespace',
'metadata': {
'name': 'app-monitoring',
},
}, name='ns-monitoring', source='app', instance='app')
])
out.append(file)
shell_script.append(OD_FileTemplate(f'kubectl apply -f ${{FILE_{file.fileid}}}'))
shell_script.append(f'kubectl config set-context --current --namespace=app-monitoring')
#
# SETUP: prometheusstack
#
pstack_config = PrometheusStackBuilder(kubragen=kg, options=PrometheusStackOptions({
'namespace': OptionRoot('namespaces.mon'),
'basename': 'mypstack',
'config': {
'prometheus_annotation': True,
'prometheus_config': PrometheusConfigFile(options=PrometheusConfigFileOptions({
'scrape': {
'prometheus': {
'enabled': True,
}
},
}))
},
'kubernetes': {
'volumes': {
'prometheus-data': {
'persistentVolumeClaim': {
'claimName': 'prometheusstack-storage-claim'
}
}
},
},
}))
pstack_config.ensure_build_names(pstack_config.BUILD_ACCESSCONTROL, pstack_config.BUILD_CONFIG,
pstack_config.BUILD_SERVICE)
#
# OUTPUTFILE: prometheusstack-config.yaml
#
file = OutputFile_Kubernetes('prometheusstack-config.yaml')
out.append(file)
file.append(pstack_config.build(pstack_config.BUILD_ACCESSCONTROL, pstack_config.BUILD_CONFIG))
shell_script.append(OD_FileTemplate(f'kubectl apply -f ${{FILE_{file.fileid}}}'))
#
# OUTPUTFILE: prometheusstack.yaml
#
file = OutputFile_Kubernetes('prometheusstack.yaml')
out.append(file)
file.append(pstack_config.build(pstack_config.BUILD_SERVICE))
shell_script.append(OD_FileTemplate(f'kubectl apply -f ${{FILE_{file.fileid}}}'))
#
# Write files
#
out.output(OutputDriver_Print())
# out.output(OutputDriver_Directory('/tmp/build-gke'))
Output:
****** BEGIN FILE: 001-app-namespace.yaml ********
apiVersion: v1
kind: Namespace
metadata:
name: app-monitoring
****** END FILE: 001-app-namespace.yaml ********
****** BEGIN FILE: 002-prometheusstack-config.yaml ********
apiVersion: v1
kind: ServiceAccount
metadata:
name: mypstack
namespace: app-monitoring
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: mypstack-prometheus
rules:
- apiGroups: ['']
<...more...>
****** END FILE: 002-prometheusstack-config.yaml ********
****** BEGIN FILE: 003-prometheusstack.yaml ********
kind: Service
apiVersion: v1
metadata:
name: mypstack-prometheus
namespace: app-monitoring
spec:
selector:
app: mypstack-prometheus
ports:
- protocol: TCP
port: 80
targetPort: 9090
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mypstack-prometheus
namespace: app-monitoring
<...more...>
****** END FILE: 003-prometheusstack.yaml ********
****** BEGIN FILE: create_gke.sh ********
#!/bin/bash
set -e
kubectl apply -f 001-app-namespace.yaml
kubectl config set-context --current --namespace=app-monitoring
kubectl apply -f 002-prometheusstack-config.yaml
kubectl apply -f 003-prometheusstack.yaml
****** END FILE: create_gke.sh ********
Author
Rangel Reale (rangelspam@gmail.com)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file kg_prometheusstack-0.7.4.tar.gz
.
File metadata
- Download URL: kg_prometheusstack-0.7.4.tar.gz
- Upload date:
- Size: 9.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 670d8d118ac9e011a67c87dabb89a98a2011d802e97ff0698ed1eb262fb2d2d9 |
|
MD5 | f592d4de8df051924ccdd9f32c645ad3 |
|
BLAKE2b-256 | 4650ceaf1fec80da73c80b692c983b4c4b09535cfe2365ad0a450f90db47d41e |
File details
Details for the file kg_prometheusstack-0.7.4-py3-none-any.whl
.
File metadata
- Download URL: kg_prometheusstack-0.7.4-py3-none-any.whl
- Upload date:
- Size: 8.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0d517a105bf8e9a2150fa50f44a14bf10292861c655da49a35f2570a63a7d694 |
|
MD5 | 423b5151ccbecf8c6f117c299c616433 |
|
BLAKE2b-256 | e2af1249beeae0161880f4f9c311e8089d8cc45645a4d8c3004fde8a3a63b57d |