replicaset connections requires

4/10/2020

currently i'm trying to set up countly application on kubernetes. I have a problem that I can't understand. maybe it's because I've been in it too long and I don't have enough distance.

When my pods (frontend & api) countly start I get the error below :

ERROR   [db:read]   Error reading apps {"name":"find","args":[{}]} MongoError: seed list 

    contains no mongos proxies, replicaset connections requires the parameter replicaSet to be supplied in the URI or options object, mongodb://server:port/db?replicaSet=name {"name":"MongoError"}
    No apps to upgrade

I checked on the mongodb website how to set up the replicaset string connection

At the bottom I put the result of the command kubectl get all to see the service name and pod name. I've tried a lot of different ways, but every time I've made a mistake.

Deployment.yaml :

# Source: countly-chart/templates/frontend.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: RELEASE-NAME-frontend
  labels:
    name: RELEASE-NAME-frontend
    app: RELEASE-NAME
    product: dgt
    environment: dev
    version: HEAD
    component: frontend
spec:
  replicas: 1
  revisionHistoryLimit: 1
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxUnavailable: 1
  selector:
    matchLabels:
      name: RELEASE-NAME-frontend
      app: RELEASE-NAME
      product: dgt
      environment: dev
      version: HEAD
      component: frontend
  template:
    metadata:
      labels:
        name: RELEASE-NAME-frontend
        app: RELEASE-NAME
        product: dgt
        environment: dev
        version: HEAD
        component: frontend
    spec:
      affinity:
        podAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            - labelSelector:
                matchExpressions:
                  - key: app
                    operator: In
                    values:
                      - mongodb
                      - mongodb
              topologyKey: "kubernetes.io/hostname"
      terminationGracePeriodSeconds: 10
      containers:
        - name: countly-frontend
          image: countly/frontend:19.08.1
          resources:
            limits:
              cpu: 100m
              memory: 512Mi
            requests:
              cpu: 100m
              memory: 512Mi
          imagePullPolicy: Always
          ports:
            - containerPort: 6001
          readinessProbe:
            httpGet:
              path: /ping
              port: 6001
            initialDelaySeconds: 60
            periodSeconds: 10
            timeoutSeconds: 3
          env:
            - name: COUNTLY_PLUGINS
              value: "mobile,web,desktop,density,locale,browser,sources,views,enterpriseinfo,logger,systemlogs,errorlogs,populator,reports,crashes,push,star-rating,slipping-away-users,compare,server-stats,dbviewer,assistant,plugin-upload,times-of-day,compliance-hub,video-intelligence-monetization,alerts,onboarding"
            - name: COUNTLY_CONFIG_API_FILESTORAGE
              value: "gridfs"
            - name: COUNTLY_CONFIG_API_MONGODB
              value: "mongodb://mongodb-0.mongodb:27017,mongodb-1.mongodb:27017/countly?replicaSet=rs0"
            - name: COUNTLY_CONFIG_FRONTEND_MONGODB
              value: "mongodb://mongodb-0.mongodb:27017,mongodb-1.mongodb:27017/countly?replicaSet=rs0"
            - name: COUNTLY_CONFIG_HOSTNAME
              value: dgt-iointc-countly.xxx.xx

Service.yaml :

# Source: countly-chart/templates/frontend.yaml
apiVersion: v1
kind: Service
metadata:
  name: RELEASE-NAME-frontend
  labels:
    app: RELEASE-NAME
    product: dgt
    environment: dev
    version: HEAD
    component: frontend
spec:
  type: NodePort
  ports:
  - port: 6001
    targetPort: 6001
    protocol: TCP
  selector:
    app: RELEASE-NAME
    component: frontend


ApiVersion: apps/v1
kind: StatefulSet
metadata:
  creationTimestamp: "2020-04-09T15:06:27Z"
  generation: 7
  labels:
    app: mongodb
    component: mongo
    environment: iointc
    product: mongodb
  name: mongodb
  namespace: dgt-iointc
  resourceVersion: "510868664"
  selfLink: /apis/apps/v1/namespaces/dgt-iointc/statefulsets/mongodb
  uid: af9eb929-7a73-11ea-a219-0679473f89f6
spec:
  podManagementPolicy: OrderedReady
  replicas: 2
  revisionHistoryLimit: 1
  selector:
    matchLabels:
      app: mongodb
      component: mongo
  serviceName: mongodb
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: mongodb
        component: mongo
        environment: iointc
        product: mongodb
    spec:
      containers:
      - command:
        - mongod
        - --replSet
        - rs0
        - --bind_ip_all
        env:
        - name: MONGODB_REPLICA_SET_NAME
          value: rs0
        image: docker.xxx.xx/run/mongo:3.6.12
        imagePullPolicy: IfNotPresent
        livenessProbe:
          exec:
            command:
            - mongo
            - --eval
            - db.adminCommand('ping')
          failureThreshold: 3
          initialDelaySeconds: 30
          periodSeconds: 10
          successThreshold: 1
          timeoutSeconds: 5
        name: mongo
        ports:
        - containerPort: 27017
          protocol: TCP
        readinessProbe:
          exec:
            command:
            - mongo
            - --eval
            - db.adminCommand('ping')
          failureThreshold: 3
          initialDelaySeconds: 5
          periodSeconds: 10
          successThreshold: 1
          timeoutSeconds: 1
       resources:
          limits:
            cpu: 500m
            memory: 1000Mi
          requests:
            cpu: 50m
            memory: 1000Mi
        securityContext:
          runAsUser: 999
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        volumeMounts:
        - mountPath: /data/db
          name: mongo-storage
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 10
  updateStrategy:
    type: RollingUpdate
  volumeClaimTemplates:
  - metadata:
      creationTimestamp: null
      name: mongo-storage
    spec:
      accessModes:
      - ReadWriteOnce
      dataSource: null
      resources:
        requests:
          storage: 600Mi
      storageClassName: nfs-external
    status:
      phase: Pending

Kubectl get all

NAME                                         READY   STATUS    RESTARTS   AGE
pod/countly-api-7b878d6fc5-ktlmg             0/1     Running   17         46m
pod/countly-frontend-6c4fc86c96-g47hx        0/1     Running   0          39m
pod/mongodb-0                                1/1     Running   0          5h19m
pod/mongodb-1                                1/1     Running   0          5h19m

NAME                            TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)          AGE
service/countly-api             NodePort    10.80.11.164   <none>        3001:32612/TCP   37h
service/countly-frontend        NodePort    10.80.104.62   <none>        6001:31176/TCP   37h
service/mongodb                 ClusterIP   None           <none>        27017/TCP        18h

NAME                                    DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/countly-api             1         1         1            0           12h
deployment.apps/countly-frontend        1         1         1            0           12h

NAME                                               DESIRED   CURRENT   READY   AGE
replicaset.apps/countly-api-7b878d6fc5             1         1         0       46m
replicaset.apps/countly-frontend-6c4fc86c96        1         1         0       39m

NAME                       DESIRED   CURRENT   AGE
statefulset.apps/mongodb   2         2         18h
-- morla
google-kubernetes-engine
kubernetes
kubernetes-ingress
kubernetes-pod

0 Answers