Search code examples
dockerflaskkubernetesredis

Connecting a flask container to a Redis container over Kubernetes


I've just setup a Redis instance however I can't seem to get the two containers to talk to each-other, the setup works over local machine with docker-compose but does not seem to be working with Kubernetes.

My logs tell me flask can't find the service, so the error must be my configuration files.

Flask code:

rDB = redis.Redis(host='redis', port=6379, db=0)

Flask server:

apiVersion: apps/v1beta2
kind: Deployment
metadata:
  name: dashboard
  namespace: default
  labels:
    run: dashboard
spec:
  replicas: 2
  selector:
    matchLabels:
      run: dashboard
  template:
    metadata:
      labels:
        run: dashboard
    spec:
      containers:
      - image: gcr.io/******/dashboard_server:v102
        name: dashboard
        livenessProbe:
          httpGet:
            path: /
            port: 8000
          initialDelaySeconds: 300
          timeoutSeconds: 5
          periodSeconds: 300
          failureThreshold: 3
        ports:
          - containerPort: 8000
            name: http
            protocol: TCP

Redis instance:

apiVersion: apps/v1 #  for k8s versions before 1.9.0 use apps/v1beta2  and before 1.8.0 use extensions/v1beta1
kind: Deployment
metadata:
  name: redis
  namespace: default
spec:
  selector:
    matchLabels:
      run: dashboard
      role: master
      tier: backend
  replicas: 1
  template:
    metadata:
      labels:
        run: dashboard
        role: master
        tier: backend
    spec:
      containers:
      - name: redis
        image: redis  # or just image: redis
        resources:
          requests:
            cpu: 100m
            memory: 100Mi
        ports:
        - containerPort: 6379

Service code

apiVersion: v1
kind: Service
metadata:
  name: dash-service
  namespace: default
  labels:
    run: frontend
spec:
  selector:
    run: dashboard
  ports:
    - name: http
      protocol: TCP
      port: 80
      targetPort: 8000
  type: ClusterIP

Solution

  • Here is a service I created my Redis cluster inside K8s.

    apiVersion: v1
    kind: Service
    metadata:
      labels:
        app: redis
      name: my-redis-svc
      namespace: default
    spec:
      ports:
      - name: redis
        port: 6379
        targetPort: 6379
        protocol: TCP
      selector:
        app: redis
      type: ClusterIP
    

    If you create that service, your pods should be accessible by other pods in same namespace using that hostname :

    my-redis-svc.default.svc.cluster.local
    

    That means, in your app code you have to change that line :

    rDB = redis.Redis(host='my-redis-svc.default.svc.cluster.local', port=6379, db=0)