KubraGen Builder: Loki Stack
Project description
KubraGen Builder: Loki Stack
kg_lokistack is a builder for KubraGen that deploys a Loki Stack stack in Kubernetes.
The Loki Stack consists of Loki, Promtail and Grafana (optional).
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_lokistack
- Repository: https://github.com/RangelReale/kg_lokistack.git
- Documentation: https://kg_lokistack.readthedocs.org/
- PyPI: https://pypi.python.org/pypi/kg_lokistack
Example
from kg_loki import LokiConfigFile, LokiConfigFileOptions
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_lokistack import LokiStackBuilder, LokiStackOptions
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: lokistack
#
lokiconfigfile = LokiConfigFile(options=LokiConfigFileOptions({
}))
lokistack_config = LokiStackBuilder(kubragen=kg, options=LokiStackOptions({
'namespace': OptionRoot('namespaces.mon'),
'basename': 'mylokistack',
'config': {
'loki': {
'loki_config': lokiconfigfile,
},
'grafana': {
'admin': {
'user': 'myuser',
'password': 'mypassword',
},
}
},
'kubernetes': {
'volumes': {
'loki-data': {
'persistentVolumeClaim': {
'claimName': 'lokistack-storage-claim'
}
}
},
'resources': {
'loki-statefulset': {
'requests': {
'cpu': '150m',
'memory': '300Mi'
},
'limits': {
'cpu': '300m',
'memory': '450Mi'
},
},
},
}
}))
lokistack_config.ensure_build_names(lokistack_config.BUILD_ACCESSCONTROL, lokistack_config.BUILD_CONFIG,
lokistack_config.BUILD_SERVICE)
#
# OUTPUTFILE: lokistack-config.yaml
#
file = OutputFile_Kubernetes('lokistack-config.yaml')
out.append(file)
file.append(lokistack_config.build(lokistack_config.BUILD_ACCESSCONTROL, lokistack_config.BUILD_CONFIG))
shell_script.append(OD_FileTemplate(f'kubectl apply -f ${{FILE_{file.fileid}}}'))
#
# OUTPUTFILE: lokistack.yaml
#
file = OutputFile_Kubernetes('lokistack.yaml')
out.append(file)
file.append(lokistack_config.build(lokistack_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-lokistack-config.yaml ********
apiVersion: v1
kind: ServiceAccount
metadata:
name: mylokistack
namespace: app-monitoring
---
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
name: mylokistack-promtail
rules:
- apiGroups: ['']
resources: [nodes, nodes/proxy, services, endpoints, pods]
verbs: [get, watch, list]
---
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
name: mylokistack-promtail
subjects:
- kind: ServiceAccount
name: mylokistack
namespace: app-monitoring
<...more...>
****** END FILE: 002-lokistack-config.yaml ********
****** BEGIN FILE: 003-lokistack.yaml ********
apiVersion: v1
kind: Service
metadata:
name: mylokistack-loki-headless
namespace: app-monitoring
labels:
app: mylokistack-loki
spec:
clusterIP: None
ports:
- port: 3100
protocol: TCP
name: http-metrics
targetPort: http-metrics
selector:
app: mylokistack-loki
---
apiVersion: v1
kind: Service
metadata:
name: mylokistack-loki
<...more...>
****** END FILE: 003-lokistack.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-lokistack-config.yaml
kubectl apply -f 003-lokistack.yaml
****** END FILE: create_gke.sh ********
Credits
based on
Author
Rangel Reale (rangelreale@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
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_lokistack-0.8.3.tar.gz.
File metadata
- Download URL: kg_lokistack-0.8.3.tar.gz
- Upload date:
- Size: 10.6 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 |
d8afa7c8e7c147bae8564fabc9c4beebdec1bdf2a9ce7af4470a17bca72de4ac
|
|
| MD5 |
7e5f8dee7082d623c600d304b81c5fe4
|
|
| BLAKE2b-256 |
60f4d365ed0e5632fd580f4bebdcb976a2a857d7ca792c4ad84c895686f5e8b7
|
File details
Details for the file kg_lokistack-0.8.3-py3-none-any.whl.
File metadata
- Download URL: kg_lokistack-0.8.3-py3-none-any.whl
- Upload date:
- Size: 12.9 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 |
29600bbddb81417f1f7efe8610958f62c28bf28ac1147e9108f86c3c4a0948d3
|
|
| MD5 |
93155a10d1a8a757b312cde035b83a1d
|
|
| BLAKE2b-256 |
2c5d6279ec8691236dec2baf3537284b0c3c1bdad68bd39616ce74f8fef6a599
|