Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FDN-2707: release arm and deploy registry arm #577

Merged
merged 2 commits into from
Aug 16, 2024
Merged

Conversation

arias-m
Copy link
Contributor

@arias-m arias-m commented Aug 16, 2024

No description provided.

@flow-tech
Copy link
Contributor

helm diff output for registry:
production, registry, Service (v1) has changed:
  # Source: flow-generic/templates/service.yaml
  apiVersion: v1
  kind: Service
  metadata:
    name: registry
    labels:
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app.kubernetes.io/name: registry
      app: registry
  spec:
    ports:
      - port: 80
        targetPort: http
        protocol: TCP
        name: http
    selector:
      app.kubernetes.io/name: registry
      app.kubernetes.io/instance: registry
production, registry-flow-io, Gateway (networking.istio.io) has changed:
  # Source: flow-generic/templates/ingress-defaults.yaml
  apiVersion: networking.istio.io/v1alpha3
  kind: Gateway
  metadata:
    name: registry-flow-io
    labels:
      app.kubernetes.io/name: registry
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app: registry
    annotations:
      kubernetes.io/ingress.class: "ingressgateway"
      kubernetes.io/ingress.tld: "api.flow.io"
      external-dns.alpha.kubernetes.io/ttl: "120"
      external-dns.alpha.kubernetes.io/target: "alb-prod.api.flow.io"
      external-dns.alpha.kubernetes.io/alias: "true"

  spec:
    selector:
      istio: ingressgateway
    servers:
      - port:
          number: 80
          name: http
          protocol: HTTP2
        hosts:
          - registry.api.flow.io
        tls:
          httpsRedirect: true
      - port:
          number: 443
          name: https
          protocol: HTTP2
        hosts:
          - registry.api.flow.io
production, registry-live, Deployment (apps) has changed:
  # Source: flow-generic/templates/deployment.yaml
  apiVersion: apps/v1
  kind: Deployment
  metadata:
    name: registry-live
    labels:
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app.kubernetes.io/name: registry
      app.kubernetes.io/stage: live
      app: registry
      tags.datadoghq.com/service: registry
      tags.datadoghq.com/env: live
      tags.datadoghq.com/version: 0.7.27
      flow.io/version: 0.7.27
      flow.io/team: foundation
  spec:
    replicas: 0
    selector:
      matchLabels:
        app.kubernetes.io/name: registry
        app.kubernetes.io/instance: registry
        app.kubernetes.io/stage: live
    template:
      metadata:
        labels:
          app.kubernetes.io/name: registry
          app.kubernetes.io/instance: registry
          app.kubernetes.io/stage: live
          app: registry
          tags.datadoghq.com/service: registry
          tags.datadoghq.com/env: live
          tags.datadoghq.com/version: 0.7.27
          flow.io/version: 0.7.27
          flow.io/team: foundation
        annotations:
          iam.amazonaws.com/role: arn:aws:iam::479720515435:role/ecsInstanceRole
          sumologic.com/sourceCategory: registry
          sidecar.istio.io/logLevel: info
          proxy.istio.io/config: '{"terminationDrainDuration": 60s}'
      spec:
        terminationGracePeriodSeconds: 60
        containers:
          - name: registry
            image: "flowcommerce/registry:0.7.27"
            imagePullPolicy: IfNotPresent
            env:
              - name: JAVA_OPTS
                value: "-Xms500m -Xmx500m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/dumps/oom.bin -XX:+UseG1GC -XX:+UseStringDeduplication -XX:FlightRecorderOptions=stackdepth=256"
              - name: FLOW_KUBERNETES_NODE_NAME
                valueFrom:
                  fieldRef:
                    fieldPath: spec.nodeName
              - name: FLOW_KUBERNETES_NODE_IP
                valueFrom:
                  fieldRef:
                    fieldPath: status.hostIP
              - name: FLOW_KUBERNETES_POD_NAME
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.name
              - name: FLOW_KUBERNETES_POD_NAMESPACE
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.namespace
              - name: FLOW_KUBERNETES_POD_IP
                valueFrom:
                  fieldRef:
                    fieldPath: status.podIP
              - name: FLOW_KUBERNETES_POD_UID
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.uid
              - name: DD_SERVICE
                value: registry
              - name: DD_ENV
                value: live
              - name: DD_VERSION
                value: 0.7.27
              - name: DD_JMXFETCH_STATSD_HOST
                value: 'unix:///var/run/datadog/dsd.socket'
              - name: DD_DOGSTATSD_URL
                value: 'unix:///var/run/datadog/dsd.socket'
              - name: DD_TRACE_AGENT_URL
                value: 'unix:///var/run/datadog/apm.socket'
              - name: DD_SERVICE_MAPPING
                value: "postgresql:registry-postgresql,java-aws-sdk:registry-aws-sdk"
              - name: DD_TAGS
                value: "team:foundation"
              - name: DD_KUBERNETES_POD_LABELS_AS_TAGS
                value: '{"*": "label_%%label%%"}'
              - name: DD_CONTAINER_ENV_AS_TAGS
                value: '{"FLOW_KUBERNETES_POD_NAME":"env_flow_kubernetes_pod_name","FLOW_KUBERNETES_POD_NAMESPACE":"env_flow_kubernetes_pod_namespace"}'
            args: ["production"]
            ports:
              - name: http
                containerPort: 9000
                protocol: TCP
            volumeMounts:
              - name: dsdsocket
                mountPath: /var/run/datadog
              - name: heap-dumps
                mountPath: /dumps
            startupProbe:
              httpGet:
                path: /_internal_/startup
                port: http
              failureThreshold: 30
              periodSeconds: 10
            livenessProbe:
              httpGet:
                path: /_internal_/live
                port: http
              failureThreshold: 6
              periodSeconds: 10
              timeoutSeconds: 5
            readinessProbe:
              httpGet:
                path: /_internal_/ready
                port: http
              failureThreshold: 1
              periodSeconds: 10
              timeoutSeconds: 1
            resources:
              limits:
                memory: 900Mi
              requests:
                cpu: 0.05
                memory: 900Mi
              
        imagePullSecrets:
          - name: flow-docker-hub
          
        topologySpreadConstraints:
          - maxSkew: 1
            topologyKey: topology.kubernetes.io/zone
            whenUnsatisfiable: ScheduleAnyway
            labelSelector:
              matchLabels:
                app: registry
        dnsConfig:
          options:
            - name: ndots
              value: "1"
        volumes:
          - name: dsdsocket
            hostPath:
              path: /var/run/datadog/
              type: DirectoryOrCreate
          - name: heap-dumps
            emptyDir: {}
    strategy:
      type: RollingUpdate
production, registry-rollout-live, VirtualService (networking.istio.io) has changed:
  # Source: flow-generic/templates/istio-rollout.yaml
  apiVersion: networking.istio.io/v1alpha3
  kind: VirtualService
  metadata:
    name: registry-rollout-live
    labels:
      app.kubernetes.io/name: registry
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app: registry
  spec:
    hosts:
      - registry
      - registry.api.flow.io
    gateways:
      - mesh
      - registry-flow-io
    http:
    - name: primary
      route:
      - destination:
          host: registry
          port:
            number: 80
          subset:  live
        weight: 100
      - destination:
          host: registry
          port:
            number: 80
          subset: canary
        weight: 0

@flow-tech
Copy link
Contributor

@flow-tech
Copy link
Contributor

helm diff output for registry:
production, registry, Service (v1) has changed:
  # Source: flow-generic/templates/service.yaml
  apiVersion: v1
  kind: Service
  metadata:
    name: registry
    labels:
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app.kubernetes.io/name: registry
      app: registry
  spec:
    ports:
      - port: 80
        targetPort: http
        protocol: TCP
        name: http
    selector:
      app.kubernetes.io/name: registry
      app.kubernetes.io/instance: registry
production, registry-flow-io, Gateway (networking.istio.io) has changed:
  # Source: flow-generic/templates/ingress-defaults.yaml
  apiVersion: networking.istio.io/v1alpha3
  kind: Gateway
  metadata:
    name: registry-flow-io
    labels:
      app.kubernetes.io/name: registry
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app: registry
    annotations:
      kubernetes.io/ingress.class: "ingressgateway"
      kubernetes.io/ingress.tld: "api.flow.io"
      external-dns.alpha.kubernetes.io/ttl: "120"
      external-dns.alpha.kubernetes.io/target: "alb-prod.api.flow.io"
      external-dns.alpha.kubernetes.io/alias: "true"

  spec:
    selector:
      istio: ingressgateway
    servers:
      - port:
          number: 80
          name: http
          protocol: HTTP2
        hosts:
          - registry.api.flow.io
        tls:
          httpsRedirect: true
      - port:
          number: 443
          name: https
          protocol: HTTP2
        hosts:
          - registry.api.flow.io
production, registry-live, Deployment (apps) has changed:
  # Source: flow-generic/templates/deployment.yaml
  apiVersion: apps/v1
  kind: Deployment
  metadata:
    name: registry-live
    labels:
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app.kubernetes.io/name: registry
      app.kubernetes.io/stage: live
      app: registry
      tags.datadoghq.com/service: registry
      tags.datadoghq.com/env: live
      tags.datadoghq.com/version: 0.7.27
      flow.io/version: 0.7.27
      flow.io/team: foundation
  spec:
    replicas: 0
    selector:
      matchLabels:
        app.kubernetes.io/name: registry
        app.kubernetes.io/instance: registry
        app.kubernetes.io/stage: live
    template:
      metadata:
        labels:
          app.kubernetes.io/name: registry
          app.kubernetes.io/instance: registry
          app.kubernetes.io/stage: live
          app: registry
          tags.datadoghq.com/service: registry
          tags.datadoghq.com/env: live
          tags.datadoghq.com/version: 0.7.27
          flow.io/version: 0.7.27
          flow.io/team: foundation
        annotations:
          iam.amazonaws.com/role: arn:aws:iam::479720515435:role/ecsInstanceRole
          sumologic.com/sourceCategory: registry
          sidecar.istio.io/logLevel: info
          proxy.istio.io/config: '{"terminationDrainDuration": 60s}'
      spec:
        terminationGracePeriodSeconds: 60
        containers:
          - name: registry
            image: "flowcommerce/registry:0.7.27"
            imagePullPolicy: IfNotPresent
            env:
              - name: JAVA_OPTS
                value: "-Xms500m -Xmx500m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/dumps/oom.bin -XX:+UseG1GC -XX:+UseStringDeduplication -XX:FlightRecorderOptions=stackdepth=256"
              - name: FLOW_KUBERNETES_NODE_NAME
                valueFrom:
                  fieldRef:
                    fieldPath: spec.nodeName
              - name: FLOW_KUBERNETES_NODE_IP
                valueFrom:
                  fieldRef:
                    fieldPath: status.hostIP
              - name: FLOW_KUBERNETES_POD_NAME
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.name
              - name: FLOW_KUBERNETES_POD_NAMESPACE
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.namespace
              - name: FLOW_KUBERNETES_POD_IP
                valueFrom:
                  fieldRef:
                    fieldPath: status.podIP
              - name: FLOW_KUBERNETES_POD_UID
                valueFrom:
                  fieldRef:
                    fieldPath: metadata.uid
              - name: DD_SERVICE
                value: registry
              - name: DD_ENV
                value: live
              - name: DD_VERSION
                value: 0.7.27
              - name: DD_JMXFETCH_STATSD_HOST
                value: 'unix:///var/run/datadog/dsd.socket'
              - name: DD_DOGSTATSD_URL
                value: 'unix:///var/run/datadog/dsd.socket'
              - name: DD_TRACE_AGENT_URL
                value: 'unix:///var/run/datadog/apm.socket'
              - name: DD_SERVICE_MAPPING
                value: "postgresql:registry-postgresql,java-aws-sdk:registry-aws-sdk"
              - name: DD_TAGS
                value: "team:foundation"
              - name: DD_KUBERNETES_POD_LABELS_AS_TAGS
                value: '{"*": "label_%%label%%"}'
              - name: DD_CONTAINER_ENV_AS_TAGS
                value: '{"FLOW_KUBERNETES_POD_NAME":"env_flow_kubernetes_pod_name","FLOW_KUBERNETES_POD_NAMESPACE":"env_flow_kubernetes_pod_namespace"}'
            args: ["production"]
            ports:
              - name: http
                containerPort: 9000
                protocol: TCP
            volumeMounts:
              - name: dsdsocket
                mountPath: /var/run/datadog
              - name: heap-dumps
                mountPath: /dumps
            startupProbe:
              httpGet:
                path: /_internal_/startup
                port: http
              failureThreshold: 30
              periodSeconds: 10
            livenessProbe:
              httpGet:
                path: /_internal_/live
                port: http
              failureThreshold: 6
              periodSeconds: 10
              timeoutSeconds: 5
            readinessProbe:
              httpGet:
                path: /_internal_/ready
                port: http
              failureThreshold: 1
              periodSeconds: 10
              timeoutSeconds: 1
            resources:
              limits:
                memory: 900Mi
              requests:
                cpu: 0.05
                memory: 900Mi
              
+       nodeSelector:
+         role: workers-arm64
+         
        imagePullSecrets:
          - name: flow-docker-hub
          
        topologySpreadConstraints:
          - maxSkew: 1
            topologyKey: topology.kubernetes.io/zone
            whenUnsatisfiable: ScheduleAnyway
            labelSelector:
              matchLabels:
                app: registry
+       tolerations:
+         - effect: NoSchedule
+           key: role
+           operator: Equal
+           value: workers-arm64
+         
        dnsConfig:
          options:
            - name: ndots
              value: "1"
        volumes:
          - name: dsdsocket
            hostPath:
              path: /var/run/datadog/
              type: DirectoryOrCreate
          - name: heap-dumps
            emptyDir: {}
    strategy:
      type: RollingUpdate
production, registry-rollout-live, VirtualService (networking.istio.io) has changed:
  # Source: flow-generic/templates/istio-rollout.yaml
  apiVersion: networking.istio.io/v1alpha3
  kind: VirtualService
  metadata:
    name: registry-rollout-live
    labels:
      app.kubernetes.io/name: registry
-     helm.sh/chart: flow-generic-1.5.47
+     helm.sh/chart: flow-generic-1.5.48
      app.kubernetes.io/instance: registry
      app.kubernetes.io/managed-by: Tiller
      app: registry
  spec:
    hosts:
      - registry
      - registry.api.flow.io
    gateways:
      - mesh
      - registry-flow-io
    http:
    - name: primary
      route:
      - destination:
          host: registry
          port:
            number: 80
          subset:  live
        weight: 100
      - destination:
          host: registry
          port:
            number: 80
          subset: canary
        weight: 0

@flow-tech
Copy link
Contributor

@arias-m arias-m merged commit 86e235a into main Aug 16, 2024
5 checks passed
@arias-m arias-m deleted the FDN-2707-release-arm branch August 16, 2024 09:22
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants