ansible role update
This commit is contained in:
@@ -0,0 +1,19 @@
|
||||
apiVersion: v1
|
||||
appVersion: 0.20.0
|
||||
description: Kafka GUI for Apache Kafka to manage topics, topics data, consumers group,
|
||||
schema registry, connect and more...
|
||||
home: https://akhq.io
|
||||
icon: https://raw.githubusercontent.com/tchiotludo/akhq/master/client/src/images/logo_black.png
|
||||
keywords:
|
||||
- kafka
|
||||
- confluent
|
||||
- gui
|
||||
- schema-registry
|
||||
- kafka-connect
|
||||
maintainers:
|
||||
- email: tchiot.ludo@gmail.com
|
||||
name: tchiotludo
|
||||
name: akhq
|
||||
sources:
|
||||
- https://github.com/tchiotludo/akhq
|
||||
version: 0.2.7
|
||||
201
ansible/roles/helm_install/files/kafka/charts/akhq/LICENSE
Normal file
201
ansible/roles/helm_install/files/kafka/charts/akhq/LICENSE
Normal file
@@ -0,0 +1,201 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "{}"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright {yyyy} {name of copyright owner}
|
||||
|
||||
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
|
||||
|
||||
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.
|
||||
124
ansible/roles/helm_install/files/kafka/charts/akhq/README.md
Normal file
124
ansible/roles/helm_install/files/kafka/charts/akhq/README.md
Normal file
@@ -0,0 +1,124 @@
|
||||
# AKHQ (previously known as KafkaHQ)
|
||||
|
||||

|
||||

|
||||

|
||||

|
||||

|
||||

|
||||
[](https://artifacthub.io/packages/search?repo=akhq)
|
||||
|
||||
> Kafka GUI for [Apache Kafka](http://kafka.apache.org/) to manage topics, topics data, consumers group, schema registry, connect and more...
|
||||
|
||||
<p align="center">
|
||||
<img width="460" src="client/src/images/logo_black.svg" alt="AKHQ for Kafka logo" /><br /><br />
|
||||
<img width="720" src="docs/.vuepress/public/assets/images/video.gif" alt="AKHQ for Kafka preview" />
|
||||
</p>
|
||||
|
||||
## Documentation
|
||||
* The official AKHQ documentation can be found under: [akhq.io](https://akhq.io/docs)
|
||||
|
||||
|
||||
## Sponsors
|
||||
<table>
|
||||
<tr>
|
||||
<td>
|
||||
<img width="1000" height="0">
|
||||
<a href="https://upstash.com/?utm_source=AKHQ" >
|
||||
<img src="https://raw.githubusercontent.com/upstash/sponsorship/master/kafka.png" alt="Upstash" width="260" align="right">
|
||||
</a>
|
||||
|
||||
<h3>Upstash: Serverless Kafka</h3>
|
||||
|
||||
<ul>
|
||||
<li>True Serverless Kafka with per-request-pricing</li>
|
||||
<li>Managed Apache Kafka, works with all Kafka clients</li>
|
||||
<li>Built-in REST API designed for serverless and edge functions</li>
|
||||
</ul>
|
||||
|
||||
[Start for free in 30 seconds!](https://upstash.com/?utm_source=AKHQ)
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
<table>
|
||||
<tr>
|
||||
<td>
|
||||
<img width="1000" height="0">
|
||||
<a href="https://redpanda.com/?utm_source=AKHQ" >
|
||||
|
||||
<img style="background-color: #FFF;padding:10px" src="https://user-images.githubusercontent.com/2064609/164302508-76ac1dfb-6c50-43d4-a092-ff275b25a032.svg" alt="Upstash" width="260" align="right">
|
||||
</a>
|
||||
|
||||
<h3>Redpanda</h3>
|
||||
|
||||
<ul>
|
||||
<li>Redpanda is a streaming data platform for developers.</li>
|
||||
<li>Kafka API compatible.</li>
|
||||
<li>10x faster. No ZooKeeper. No JVM!</li>
|
||||
</ul>
|
||||
|
||||
[redpanda.com](https://redpanda.com/?utm_source=AKHQ)
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
## From AKHQ project creator
|
||||
<table>
|
||||
<tr>
|
||||
<td>
|
||||
<img width="1000" height="0">
|
||||
<a href="https://github.com/kestra-io/kestra?utm_source=AKHQ" >
|
||||
<img src="https://kestra.io/video.gif" alt="Upstash" width="320" align="right">
|
||||
</a>
|
||||
|
||||
<h3>Kestra: Open source data orchestration and scheduling platform</h3>
|
||||
|
||||
<p>
|
||||
Kestra is an infinitely scalable orchestration and scheduling platform, creating, running, scheduling, and monitoring millions of complex pipelines.
|
||||
</p>
|
||||
|
||||
[Discover the project!](https://github.com/kestra-io/kestra?utm_source=AKHQ)
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
|
||||
|
||||
## Who's using AKHQ
|
||||
* [Adeo](https://www.adeo.com/)
|
||||
* [Avlino](https://avlino.com/)
|
||||
* [Auchan Retail](https://www.auchan-retail.com/)
|
||||
* [BARMER](https://www.barmer.de/)
|
||||
* [Bell](https://www.bell.ca)
|
||||
* [Best buy](https://www.bestbuy.com)
|
||||
* [BMW Group](https://www.bmwgroup.com)
|
||||
* [Boulanger](https://www.boulanger.com/)
|
||||
* [BPCE-IT](https://www.bpce-it.fr/)
|
||||
* [Decathlon](https://www.decathlon.fr/)
|
||||
* [Depop](https://www.depop.com)
|
||||
* [Galeries Lafayette](https://www.galerieslafayette.com/)
|
||||
* [GetYourGuide](https://www.getyourguide.com)
|
||||
* [Kitopi](https://kitopi.com)
|
||||
* [Klarna](https://www.klarna.com)
|
||||
* [La Redoute](https://laredoute.io/)
|
||||
* [Leroy Merlin](https://www.leroymerlin.fr/)
|
||||
* [NEXT Technologies](https://www.nextapp.co/)
|
||||
* [Nuxeo](https://www.nuxeo.com/)
|
||||
* [Pipedrive](https://www.pipedrive.com)
|
||||
* [TVG](https://www.tvg.com)
|
||||
* [Vodeno](https://www.vodeno.com/)
|
||||
|
||||
|
||||
|
||||
## Credits
|
||||
|
||||
Many thanks to:
|
||||
|
||||
* [JetBrains](https://www.jetbrains.com/?from=AKHQ) for their free OpenSource license.
|
||||
* Apache, Apache Kafka, Kafka, and associated open source project names are trademarks of the Apache Software Foundation. AKHQ is not affiliated with, endorsed by, or otherwise associated with the Apache Software.
|
||||
|
||||
[](https://www.jetbrains.com/?from=AKHQ)
|
||||
|
||||
|
||||
## License
|
||||
Apache 2.0 © [tchiotludo](https://github.com/tchiotludo)
|
||||
@@ -0,0 +1,21 @@
|
||||
1. Get the application URL by running these commands:
|
||||
{{- if .Values.ingress.enabled }}
|
||||
{{- range $host := .Values.ingress.hosts }}
|
||||
{{- range $.Values.ingress.paths }}
|
||||
http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host }}{{ . }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- else if contains "NodePort" .Values.service.type }}
|
||||
export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "akhq.fullname" . }})
|
||||
export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}")
|
||||
echo http://$NODE_IP:$NODE_PORT
|
||||
{{- else if contains "LoadBalancer" .Values.service.type }}
|
||||
NOTE: It may take a few minutes for the LoadBalancer IP to be available.
|
||||
You can watch the status of by running 'kubectl get svc -w {{ include "akhq.fullname" . }}'
|
||||
export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "akhq.fullname" . }} -o jsonpath='{.status.loadBalancer.ingress[0].ip}')
|
||||
echo http://$SERVICE_IP:{{ .Values.service.port }}
|
||||
{{- else if contains "ClusterIP" .Values.service.type }}
|
||||
export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "akhq.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
|
||||
echo "Visit http://127.0.0.1:8080 to use your application"
|
||||
kubectl port-forward $POD_NAME 8080:{{ .Values.service.port }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,56 @@
|
||||
{{/* vim: set filetype=mustache: */}}
|
||||
{{/*
|
||||
Expand the name of the chart.
|
||||
*/}}
|
||||
{{- define "akhq.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 "akhq.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 -}}
|
||||
|
||||
{{/*
|
||||
Create chart name and version as used by the chart label.
|
||||
*/}}
|
||||
{{- define "akhq.chart" -}}
|
||||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
|
||||
{{- end -}}
|
||||
|
||||
{{/*
|
||||
Create the name of the service account to use
|
||||
*/}}
|
||||
{{- define "akhq.serviceAccountName" -}}
|
||||
{{- if .Values.serviceAccount.create }}
|
||||
{{- default (include "akhq.fullname" .) .Values.serviceAccountName }}
|
||||
{{- else }}
|
||||
{{- default "default" .Values.serviceAccountName }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Return the appropriate apiVersion for Ingress
|
||||
*/}}
|
||||
{{- define "akhq.ingress.apiVersion" -}}
|
||||
{{- if semverCompare "<1.14-0" .Capabilities.KubeVersion.Version -}}
|
||||
{{- print "extensions/v1beta1" -}}
|
||||
{{- else if semverCompare "<1.19-0" .Capabilities.KubeVersion.Version -}}
|
||||
{{- print "networking.k8s.io/v1beta1" -}}
|
||||
{{- else -}}
|
||||
{{- print "networking.k8s.io/v1" -}}
|
||||
{{- end -}}
|
||||
{{- end -}}
|
||||
@@ -0,0 +1,14 @@
|
||||
{{- if .Values.configuration }}
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: {{ template "akhq.fullname" . }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
data:
|
||||
application.yml: |
|
||||
{{ toYaml .Values.configuration | indent 4}}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,129 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: {{ include "akhq.fullname" . }}
|
||||
{{- with .Values.annotations }}
|
||||
annotations:
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- with .Values.labels }}
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
replicas: {{ .Values.replicaCount | default 1 }}
|
||||
selector:
|
||||
matchLabels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
template:
|
||||
metadata:
|
||||
annotations:
|
||||
{{- if .Values.configuration }}
|
||||
checksum/config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }}
|
||||
{{- end }}
|
||||
{{- if and (not .Values.existingSecret) (.Values.secrets) }}
|
||||
checksum/secrets: {{ include (print $.Template.BasePath "/secret.yaml") . | sha256sum }}
|
||||
{{- end }}
|
||||
{{- with .Values.podAnnotations }}
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{- with .Values.podLabels }}
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
{{- if .Values.imagePullSecrets }}
|
||||
imagePullSecrets:
|
||||
{{ toYaml .Values.imagePullSecrets | indent 8 }}
|
||||
{{- end }}
|
||||
{{- if .Values.securityContext }}
|
||||
securityContext:
|
||||
{{ toYaml .Values.securityContext | nindent 8 }}
|
||||
{{- end }}
|
||||
serviceAccountName: {{ include "akhq.serviceAccountName" . }}
|
||||
{{- if .Values.initContainers }}
|
||||
initContainers:
|
||||
{{- range $key, $value := .Values.initContainers }}
|
||||
- name: {{ $key }}
|
||||
{{ toYaml $value | indent 10 }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
containers:
|
||||
- name: {{ .Chart.Name }}
|
||||
image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}"
|
||||
imagePullPolicy: {{ .Values.image.pullPolicy | default "Always" }}
|
||||
{{- if .Values.containerSecurityContext }}
|
||||
securityContext:
|
||||
{{ toYaml .Values.containerSecurityContext | nindent 12 }}
|
||||
{{- end }}
|
||||
env:
|
||||
{{- if .Values.extraEnv }}{{ toYaml .Values.extraEnv | trim | nindent 12 }}{{ end }}
|
||||
{{- if or (.Values.existingSecrets) (.Values.secrets) }}
|
||||
- name: MICRONAUT_ENVIRONMENTS
|
||||
value: secrets
|
||||
- name: MICRONAUT_CONFIG_FILES
|
||||
value: /app/application.yml,/app/application-secrets.yml
|
||||
{{- end }}
|
||||
volumeMounts:
|
||||
{{- if .Values.extraVolumeMounts }}{{ toYaml .Values.extraVolumeMounts | trim | nindent 12 }}{{ end }}
|
||||
{{- if .Values.configuration }}
|
||||
- name: config
|
||||
mountPath: /app/application.yml
|
||||
subPath: application.yml
|
||||
{{- end }}
|
||||
{{- if or (.Values.existingSecrets) (.Values.secrets) }}
|
||||
- name: secrets
|
||||
mountPath: /app/application-secrets.yml
|
||||
subPath: application-secrets.yml
|
||||
{{- end }}
|
||||
ports:
|
||||
- name: http
|
||||
containerPort: 8080
|
||||
protocol: TCP
|
||||
- name: management
|
||||
containerPort: 28081
|
||||
protocol: TCP
|
||||
livenessProbe:
|
||||
tcpSocket:
|
||||
port: management
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: {{ .Values.readinessProbe.prefix | default "" }}/health
|
||||
port: management
|
||||
resources:
|
||||
{{- toYaml .Values.resources | nindent 12 }}
|
||||
{{- with .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.affinity }}
|
||||
affinity:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.tolerations }}
|
||||
tolerations:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
volumes:
|
||||
{{- if .Values.extraVolumes }}{{ toYaml .Values.extraVolumes | trim | nindent 6 }}{{ end }}
|
||||
{{- if .Values.configuration }}
|
||||
- name: config
|
||||
configMap:
|
||||
name: {{ template "akhq.fullname" . }}
|
||||
{{- end }}
|
||||
{{- if or (.Values.existingSecrets) (.Values.secrets) }}
|
||||
- name: secrets
|
||||
secret:
|
||||
{{- if .Values.existingSecrets }}
|
||||
secretName: {{ .Values.existingSecrets }}
|
||||
{{- else }}
|
||||
secretName: {{ template "akhq.fullname" . }}-secrets
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,53 @@
|
||||
{{- if .Values.ingress.enabled -}}
|
||||
{{- $fullName := include "akhq.fullname" . -}}
|
||||
{{- $ingressPaths := .Values.ingress.paths -}}
|
||||
apiVersion: {{ include "akhq.ingress.apiVersion" . }}
|
||||
kind: Ingress
|
||||
metadata:
|
||||
name: {{ $fullName }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- with .Values.ingress.annotations }}
|
||||
annotations:
|
||||
{{- tpl (toYaml .) $ | nindent 4 }}
|
||||
{{- end }}
|
||||
spec:
|
||||
{{- if and .Values.ingress.ingressClassName (eq (include "akhq.ingress.apiVersion" $) "networking.k8s.io/v1") }}
|
||||
ingressClassName: {{ .Values.ingress.ingressClassName }}
|
||||
{{- end }}
|
||||
{{- if .Values.ingress.tls }}
|
||||
tls:
|
||||
{{- range .Values.ingress.tls }}
|
||||
- hosts:
|
||||
{{- range .hosts }}
|
||||
- {{ . | quote }}
|
||||
{{- end }}
|
||||
secretName: {{ .secretName }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
rules:
|
||||
{{- range .Values.ingress.hosts }}
|
||||
- host: {{ . | quote }}
|
||||
http:
|
||||
paths:
|
||||
{{- range $ingressPaths }}
|
||||
- path: {{ . }}
|
||||
{{- if eq (include "akhq.ingress.apiVersion" $) "networking.k8s.io/v1" }}
|
||||
pathType: "ImplementationSpecific"
|
||||
{{- end }}
|
||||
backend:
|
||||
{{- if eq (include "akhq.ingress.apiVersion" $) "networking.k8s.io/v1" }}
|
||||
service:
|
||||
name: {{ $fullName }}
|
||||
port:
|
||||
name: http
|
||||
{{ else }}
|
||||
serviceName: {{ $fullName }}
|
||||
servicePort: http
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,19 @@
|
||||
{{- if and ( not .Values.existingSecrets) (.Values.secrets) }}
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: {{ template "akhq.fullname" . }}-secrets
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
type: Opaque
|
||||
data:
|
||||
application-secrets.yml: {{ toYaml .Values.secrets | b64enc | quote }}
|
||||
{{- if .Values.kafkaSecrets }}
|
||||
{{- range $key, $value := .Values.kafkaSecrets }}
|
||||
{{ $key }}: {{ $value | quote }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,31 @@
|
||||
{{- if .Values.service.enabled }}
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "akhq.fullname" . }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- range $key, $value := .Values.service.labels }}
|
||||
{{ $key }}: {{ $value | quote }}
|
||||
{{- end }}
|
||||
annotations:
|
||||
{{- range $key, $value := .Values.service.annotations }}
|
||||
{{ $key }}: {{ $value | quote }}
|
||||
{{- end }}
|
||||
spec:
|
||||
type: {{ .Values.service.type }}
|
||||
ports:
|
||||
- port: {{ .Values.service.port }}
|
||||
targetPort: http
|
||||
protocol: TCP
|
||||
name: http
|
||||
{{- if and (eq "NodePort" .Values.service.type) .Values.service.httpNodePort }}
|
||||
nodePort: {{ .Values.service.httpNodePort }}
|
||||
{{- end }}
|
||||
selector:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,15 @@
|
||||
{{- if .Values.serviceAccount.create }}
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "akhq.name" . }}
|
||||
helm.sh/chart: {{ include "akhq.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- with .Values.serviceAccount.annotations }}
|
||||
annotations:
|
||||
{{ toYaml . | indent 4 }}
|
||||
{{- end }}
|
||||
name: {{ include "akhq.serviceAccountName" . }}
|
||||
{{- end }}
|
||||
145
ansible/roles/helm_install/files/kafka/charts/akhq/values.yaml
Normal file
145
ansible/roles/helm_install/files/kafka/charts/akhq/values.yaml
Normal file
@@ -0,0 +1,145 @@
|
||||
# imagePullSecrets:
|
||||
# - name: my-repository-secret
|
||||
image:
|
||||
repository: tchiotludo/akhq
|
||||
tag: "" # uses Chart.AppVersion by default
|
||||
|
||||
# custom annotations (example: for prometheus)
|
||||
annotations: {}
|
||||
#prometheus.io/scrape: 'true'
|
||||
#prometheus.io/port: '8080'
|
||||
#prometheus.io/path: '/prometheus'
|
||||
|
||||
podAnnotations: {}
|
||||
|
||||
# custom labels
|
||||
labels: {}
|
||||
# custom.label: 'true'
|
||||
|
||||
podLabels: {}
|
||||
|
||||
## You can put directly your configuration here... or add java opts or any other env vars
|
||||
extraEnv: []
|
||||
# - name: AKHQ_CONFIGURATION
|
||||
# value: |
|
||||
# akhq:
|
||||
# secrets:
|
||||
# docker-kafka-server:
|
||||
# properties:
|
||||
# bootstrap.servers: "kafka:9092"
|
||||
# - name: JAVA_OPTS
|
||||
# value: "-Djavax.net.ssl.trustStore=/usr/local/openjdk-11/lib/security/cacerts -Djavax.net.ssl.trustStorePassword=password"
|
||||
# - name: CLASSPATH
|
||||
# value: "/any/additional/jars/desired.jar:/go/here.jar"
|
||||
|
||||
## Or you can also use configmap for the configuration...
|
||||
configuration:
|
||||
akhq:
|
||||
server:
|
||||
access-log:
|
||||
enabled: false
|
||||
name: org.akhq.log.access
|
||||
|
||||
##... and secret for connection information
|
||||
existingSecrets: ""
|
||||
# name of the existingSecret
|
||||
secrets:
|
||||
akhq:
|
||||
connections:
|
||||
my-cluster-plain-text:
|
||||
properties:
|
||||
bootstrap.servers: "kafka:9092"
|
||||
# schema-registry:
|
||||
# url: "http://schema-registry:8085"
|
||||
# type: "confluent"
|
||||
# basic-auth-username: basic-auth-user
|
||||
# basic-auth-password: basic-auth-pass
|
||||
# connect:
|
||||
# - name: "my-connect"
|
||||
# url: "http://connect:8083"
|
||||
# basic-auth-username: basic-auth-user
|
||||
# basic-auth-password: basic-auth-pass
|
||||
|
||||
kafkaSecrets: []
|
||||
#Provide extra base64 encoded kubernetes secrets (keystore/truststore)
|
||||
|
||||
# Any extra volumes to define for the pod (like keystore/truststore)
|
||||
extraVolumes: []
|
||||
|
||||
# Any extra volume mounts to define for the akhq container
|
||||
extraVolumeMounts: []
|
||||
|
||||
# Specify ServiceAccount for pod
|
||||
serviceAccountName: null
|
||||
serviceAccount:
|
||||
create: false
|
||||
#annotations:
|
||||
# eks.amazonaws.com/role-arn: arn:aws:iam::123456789000:role/iam-role-name-here
|
||||
|
||||
# Add your own init container or uncomment and modify the example.
|
||||
initContainers: {}
|
||||
# create-keystore:
|
||||
# image: "openjdk:11-slim"
|
||||
# command: ['sh', '-c', 'keytool']
|
||||
# volumeMounts:
|
||||
# - mountPath: /tmp
|
||||
# name: certs
|
||||
|
||||
# Configure the Pod Security Context
|
||||
# ref: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
|
||||
securityContext: {}
|
||||
# runAsNonRoot: true
|
||||
# runAsUser: 1000
|
||||
|
||||
# Configure the Container Security Context
|
||||
# ref: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/
|
||||
containerSecurityContext: {}
|
||||
# allowPrivilegeEscalation: false
|
||||
# privileged: false
|
||||
# capabilities:
|
||||
# drop:
|
||||
# - ALL
|
||||
# runAsNonRoot: true
|
||||
# runAsUser: 1001
|
||||
# readOnlyRootFilesystem: true
|
||||
|
||||
service:
|
||||
enabled: true
|
||||
type: NodePort
|
||||
port: 80
|
||||
nodePort: 32551
|
||||
labels: {}
|
||||
annotations:
|
||||
# cloud.google.com/load-balancer-type: "Internal"
|
||||
|
||||
ingress:
|
||||
enabled: false
|
||||
ingressClassName: ""
|
||||
annotations: {}
|
||||
# kubernetes.io/ingress.class: nginx
|
||||
# kubernetes.io/tls-acme: "true"
|
||||
paths:
|
||||
- /
|
||||
hosts:
|
||||
- akhq.demo.com
|
||||
tls: []
|
||||
# - secretName: akhq-tls
|
||||
# hosts:
|
||||
# - akhq.demo.com
|
||||
|
||||
readinessProbe:
|
||||
prefix: "" # set same as `micronaut.server.context-path`
|
||||
|
||||
resources: {}
|
||||
# limits:
|
||||
# cpu: 100m
|
||||
# memory: 128Mi
|
||||
# requests:
|
||||
# cpu: 100m
|
||||
# memory: 128Mi
|
||||
|
||||
nodeSelector: {}
|
||||
|
||||
tolerations: []
|
||||
|
||||
affinity: {}
|
||||
Reference in New Issue
Block a user