Skip to content
This repository has been archived by the owner on Feb 22, 2022. It is now read-only.

[stable/redis-ha] Add a dedicated port in haproxy for redis slaves #16824

Merged
merged 4 commits into from
Sep 9, 2019
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion stable/redis-ha/Chart.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,15 @@ keywords:
- redis
- keyvalue
- database
version: 3.7.3
version: 3.7.6
appVersion: 5.0.5
description: Highly available Kubernetes implementation of Redis
icon: https://upload.wikimedia.org/wikipedia/en/thumb/6/6b/Redis_Logo.svg/1200px-Redis_Logo.svg.png
maintainers:
- email: salimsalaues@gmail.com
name: ssalaues
- email: aaron.layfield@gmail.com
name: dandydeveloper
details:
This Helm chart provides a highly available Redis implementation with a master/slave configuration
and uses Sentinel sidecars for failover management
Expand Down
4 changes: 3 additions & 1 deletion stable/redis-ha/OWNERS
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
approvers:
- ssalaues
- dandydeveloper
reviewers:
- ssalaues
- ssalaues
- dandydeveloper
2 changes: 2 additions & 0 deletions stable/redis-ha/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,8 @@ The following table lists the configurable parameters of the Redis chart and the
| `haproxy.resources` | HAProxy resources | `{}` |
| `haproxy.service.type` | HAProxy service type "ClusterIP" or "LoadBalancer" | `ClusterIP` |
| `haproxy.service.annotations` | HAProxy service annotations | `{}` |
| `haproxy.hapreadport.enable` | Enable a read only port for redis slaves | `false` |
| `haproxy.hapreadport.port` | Haproxy port for read only redis slaves | `6380` |
| `haproxy.exporter.enabled`| Enable Prometheus metric scraping | `false` |
| `haproxy.exporter.port` | Prometheus metric scraping port | `9101` |
| `haproxy.init.resources` | Extra init resources | `{}` |
Expand Down
33 changes: 29 additions & 4 deletions stable/redis-ha/templates/redis-ha-configmap.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -177,12 +177,18 @@ data:
{{- end }}

# decide redis backend to use
frontend ft_redis
#master
frontend ft_redis_master
bind *:6379
use_backend bk_redis

use_backend bk_redis_master
{{ if .Values.haproxy.readOnly.enabled }}
#slave
frontend ft_redis_slave
bind *:6380
use_backend bk_redis_slave
{{- end }}
# Check all redis servers to see if they think they are master
backend bk_redis
backend bk_redis_master
mode tcp
option tcp-check
tcp-check connect
Expand All @@ -199,7 +205,26 @@ data:
{{- range $i := until $replicas }}
use-server R{{ $i }} if { srv_is_up(R{{ $i }}) } { nbsrv(check_if_redis_is_master_{{ $i }}) ge 2 }
server R{{ $i }} {{ $fullName }}-announce-{{ $i }}:6379 check inter 1s fall 1 rise 1
{{- end }}
{{ if .Values.haproxy.readOnly.enabled }}
backend bk_redis_slave
mode tcp
option tcp-check
tcp-check connect
{{- if .Values.auth }}
tcp-check send AUTH\ {{ .Values.redisPassword }}\r\n
tcp-check expect string +OK
{{- end }}
tcp-check send PING\r\n
tcp-check expect string +PONG
tcp-check send info\ replication\r\n
tcp-check expect string role:slave
tcp-check send QUIT\r\n
tcp-check expect string +OK
{{- range $i := until $replicas }}
server R{{ $i }} {{ $fullName }}-announce-{{ $i }}:6379 check inter 1s fall 1 rise 1
{{- end }}
{{- end }}
{{- end }}
{{- end }}
haproxy_init.sh: |
Expand Down
9 changes: 8 additions & 1 deletion stable/redis-ha/templates/redis-haproxy-deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ spec:
serviceAccountName: {{ template "redis-ha.serviceAccountName" . }}-haproxy
nodeSelector:
{{ toYaml .Values.nodeSelector | indent 8 }}
tolerations:
{{ toYaml .Values.tolerations | indent 8 }}
initContainers:
- name: config-init
image: {{ .Values.haproxy.image.repository }}:{{ .Values.haproxy.image.tag }}
Expand Down Expand Up @@ -76,6 +78,11 @@ spec:
- name: redis
containerPort: {{ default "6379" .Values.redis.port }}
hostPort: 6379
{{- if .Values.haproxy.readOnly.enabled }}
- name: readonlyport
containerPort: {{ default "6380" .Values.haproxy.readOnly.port }}
hostPort: 6380
{{- end }}
resources:
{{ toYaml .Values.haproxy.resources | indent 10 }}
volumeMounts:
Expand All @@ -91,4 +98,4 @@ spec:
emptyDir: {}
- name: data
emptyDir: {}
{{- end }}
{{- end }}
8 changes: 7 additions & 1 deletion stable/redis-ha/templates/redis-haproxy-service.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,12 @@ spec:
port: {{ .Values.redis.port }}
protocol: TCP
targetPort: redis
{{- if .Values.haproxy.readOnly.enabled }}
- name: haproxyreadonly
port: {{ .Values.haproxy.readOnly.port }}
protocol: TCP
targetPort: {{ .Values.haproxy.readOnly.port }}
{{- end }}
{{- if .Values.exporter.enabled }}
- name: exporter-port
port: {{ .Values.haproxy.exporter.port }}
Expand All @@ -25,4 +31,4 @@ spec:
selector:
release: {{ .Release.Name }}
app: {{ template "redis-ha.name" . }}-haproxy
{{- end }}
{{- end }}
5 changes: 5 additions & 0 deletions stable/redis-ha/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,10 @@ serviceAccount:
## ref: https://cbonte.github.io/haproxy-dconv/1.9/intro.html
haproxy:
enabled: false
# Enable if you want a dedicated port in haproxy for redis-slaves
readOnly:
enabled: false
port: 6380
replicas: 1
image:
repository: haproxy
Expand Down Expand Up @@ -91,6 +95,7 @@ redis:
rdbcompression: "yes"
rdbchecksum: "yes"


## Custom redis.conf files used to override default settings. If this file is
## specified then the redis.config above will be ignored.
# customConfig: |-
Expand Down