KubraGen Builder: Node Exporter
Project description
KubraGen Builder: Node Exporter
kg_nodeexporter is a builder for KubraGen that deploys a Node Exporter service in Kubernetes.
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_nodeexporter
- Repository: https://github.com/RangelReale/kg_nodeexporter.git
- Documentation: https://kg_nodeexporter.readthedocs.org/
- PyPI: https://pypi.python.org/pypi/kg_nodeexporter
Example
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_nodeexporter import NodeExporterBuilder, NodeExporterOptions
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: node-exporter
#
nodeexporter_config = NodeExporterBuilder(kubragen=kg, options=NodeExporterOptions({
'namespace': OptionRoot('namespaces.mon'),
'basename': 'mynodeexporter',
'config': {
'prometheus_annotation': True,
},
'kubernetes': {
'resources': {
'daemonset': {
'requests': {
'cpu': '150m',
'memory': '300Mi'
},
'limits': {
'cpu': '300m',
'memory': '450Mi'
},
},
},
}
}))
nodeexporter_config.ensure_build_names(nodeexporter_config.BUILD_SERVICE)
#
# OUTPUTFILE: node-exporter.yaml
#
file = OutputFile_Kubernetes('node-exporter.yaml')
out.append(file)
file.append(nodeexporter_config.build(nodeexporter_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-node-exporter.yaml ********
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: mynodeexporter
namespace: app-monitoring
labels:
app: mynodeexporter
spec:
selector:
matchLabels:
app: mynodeexporter
template:
metadata:
labels:
app: mynodeexporter
annotations:
prometheus.io/scrape: 'true'
prometheus.io/path: '/metrics'
prometheus.io/port: '9100'
spec:
hostPID: true
hostIPC: true
hostNetwork: true
containers:
- name: node-exporter
ports:
- containerPort: 9100
protocol: TCP
securityContext:
privileged: true
image: prom/node-exporter:v1.0.1
args: [--path.procfs, /host/proc, --path.sysfs, /host/sys, --collector.filesystem.ignored-mount-points,
'"^/(sys|proc|dev|host|etc)($|/)"']
volumeMounts:
- name: dev
mountPath: /host/dev
- name: proc
mountPath: /host/proc
- name: sys
mountPath: /host/sys
- name: rootfs
mountPath: /rootfs
resources:
requests:
cpu: 150m
memory: 300Mi
limits:
cpu: 300m
memory: 450Mi
volumes:
- name: proc
hostPath:
path: /proc
- name: dev
hostPath:
path: /dev
- name: sys
hostPath:
path: /sys
- name: rootfs
hostPath:
path: /
****** END FILE: 002-node-exporter.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-node-exporter.yaml
****** END FILE: create_gke.sh ********
Credits
Based on
Kubernetes: monitoring with Prometheus — exporters, a Service Discovery, and its roles
Author
Rangel Reale (rangelreale@gmail.com)
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kg_nodeexporter-0.8.0.tar.gz.
File metadata
- Download URL: kg_nodeexporter-0.8.0.tar.gz
- Upload date:
- Size: 7.7 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.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1939dbfc5517cd78d294444e02d6193dc5b730689039016855f2ef19e6721a81
|
|
| MD5 |
8dc6ca1cc00f3b55711ed421d4e1e1c4
|
|
| BLAKE2b-256 |
5b7e05d99f2b9c860df601b114c18236dd5903428e8413c932582c039fec322d
|
File details
Details for the file kg_nodeexporter-0.8.0-py3-none-any.whl.
File metadata
- Download URL: kg_nodeexporter-0.8.0-py3-none-any.whl
- Upload date:
- Size: 8.4 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.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
da62f4daaf3393fbd9b782183e0c339223af982dca0c6cf759d9e8e0ebac967b
|
|
| MD5 |
55940805960d3cdceba0454bd2643045
|
|
| BLAKE2b-256 |
7d41a301aa1e9dcbfd73f5f949cbcea472e8ff5aeb7c7466a98ab319e3c2926d
|