Merge pull request #24 from tparikh/quayio-osd-deployment
added OpenShift template for Quay app
This commit is contained in:
commit
f915352138
1 changed files with 219 additions and 0 deletions
219
deploy/openshift/quay-app.yaml
Normal file
219
deploy/openshift/quay-app.yaml
Normal file
|
@ -0,0 +1,219 @@
|
|||
---
|
||||
apiVersion: v1
|
||||
kind: Template
|
||||
metadata:
|
||||
name: quay
|
||||
objects:
|
||||
- apiVersion: rbac.authorization.k8s.io/v1beta1
|
||||
kind: Role
|
||||
metadata:
|
||||
name: ${{NAME}}
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- secrets
|
||||
verbs:
|
||||
- get
|
||||
- patch
|
||||
- update
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- namespaces
|
||||
verbs:
|
||||
- get
|
||||
- apiGroups:
|
||||
- extensions
|
||||
- apps
|
||||
resources:
|
||||
- deployments
|
||||
verbs:
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiVersion: rbac.authorization.k8s.io/v1beta1
|
||||
kind: RoleBinding
|
||||
metadata:
|
||||
name: ${{NAME}}
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: ${{NAME}}
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: default
|
||||
- apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: quay-clusterip-service
|
||||
spec:
|
||||
type: ClusterIP
|
||||
ports:
|
||||
- protocol: TCP
|
||||
name: clusterip
|
||||
port: ${{CLUSTERIP_SERVICE_PORT}}
|
||||
targetPort: ${{CLUSTERIP_SERVICE_TARGET_PORT}}
|
||||
selector:
|
||||
${{QUAY_APP_COMPONENT_LABEL_KEY}}: ${{QUAY_APP_COMPONENT_LABEL_VALUE}}
|
||||
- apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: quay-loadbalancer-service
|
||||
spec:
|
||||
ports:
|
||||
- name: loadbalancer
|
||||
protocol: TCP
|
||||
port: ${{LOADBALANCER_SERVICE_PORT}}
|
||||
targetPort: ${{LOADBALANCER_SERVICE_TARGET_PORT}}
|
||||
loadBalancerIP:
|
||||
type: LoadBalancer
|
||||
selector:
|
||||
${{QUAY_APP_COMPONENT_LABEL_KEY}}: ${{QUAY_APP_COMPONENT_LABEL_VALUE}}
|
||||
- apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: quay-app
|
||||
labels:
|
||||
${{QUAY_APP_COMPONENT_LABEL_KEY}}: ${{QUAY_APP_COMPONENT_LABEL_VALUE}}
|
||||
spec:
|
||||
replicas: ${{QUAY_APP_DEPLOYMENT_REPLICAS}}
|
||||
minReadySeconds: ${{QUAY_APP_DEPLOYMENT_MIN_READY_SECONDS}}
|
||||
progressDeadlineSeconds: ${{QUAY_APP_DEPLOYMENT_PROGRESS_DEADLINE_SECONDS}}
|
||||
revisionHistoryLimit: ${{QUAY_APP_DEPLOYMENT_REVISION_HISTORY_LIMITS}}
|
||||
strategy:
|
||||
type: ${{QUAY_APP_DEPLOYMENT_STRATEGY_TYPE}}
|
||||
rollingUpdate:
|
||||
maxUnavailable: ${{QUAY_APP_DEPLOYMENT_MAX_UNAVAILABLE}}
|
||||
maxSurge: ${{QUAY_APP_DEPLOYMENT_MAX_SURGE}}
|
||||
selector:
|
||||
matchLabels:
|
||||
${{QUAY_APP_COMPONENT_LABEL_KEY}}: ${{QUAY_APP_COMPONENT_LABEL_VALUE}}
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
${{QUAY_APP_COMPONENT_LABEL_KEY}}: ${{QUAY_APP_COMPONENT_LABEL_VALUE}}
|
||||
spec:
|
||||
volumes:
|
||||
- name: configvolume
|
||||
secret:
|
||||
secretName: ${{QUAY_APP_CONFIG_SECRET}}
|
||||
containers:
|
||||
- name: quay-app
|
||||
image: ${IMAGE}:${IMAGE_TAG}
|
||||
imagePullPolicy: Always
|
||||
ports:
|
||||
- containerPort: 8443
|
||||
volumeMounts:
|
||||
- name: configvolume
|
||||
readOnly: false
|
||||
mountPath: /conf/stack
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /health/instance
|
||||
port: 8443
|
||||
initialDelaySeconds: ${{QUAY_APP_LIVENESS_PROBE_INITIAL_DELAY_SECONDS}}
|
||||
periodSeconds: ${{QUAY_APP_LIVENESS_PROBE_PERIOD_SECONDS}}
|
||||
timeoutSeconds: ${{QUAY_APP_LIVENESS_PROBE_TIMEOUT_SECONDS}}
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /health/endtoend
|
||||
port: 8443
|
||||
initialDelaySeconds: ${{QUAY_APP_READINESS_PROBE_INITIAL_DELAY_SECONDS}}
|
||||
periodSeconds: ${{QUAY_APP_READINESS_PROBE_PERIOD_SECONDS}}
|
||||
timeoutSeconds: ${{QUAY_APP_READINESS_PROBE_TIMEOUT_SECONDS}}
|
||||
resources:
|
||||
limits:
|
||||
cpu: ${{QUAY_APP_CPU_LIMIT}}
|
||||
memory: ${{QUAY_APP_MEMORY_LIMIT}}
|
||||
requests:
|
||||
cpu: ${{QUAY_APP_CPU_REQUEST}}
|
||||
memory: ${{QUAY_APP_MEMORY_REQUEST}}
|
||||
parameters:
|
||||
- name: NAME
|
||||
value: "quay"
|
||||
displayName: name
|
||||
description: Defaults to quay.
|
||||
- name: IMAGE
|
||||
value: "quay.io/app-sre/quay"
|
||||
displayName: quay image
|
||||
description: quay docker image. Defaults to quay.io/app-sre/quay.
|
||||
- name: IMAGE_TAG
|
||||
value: "latest"
|
||||
displayName: quay version
|
||||
description: quay version which defaults to latest
|
||||
- name: CLUSTERIP_SERVICE_PORT
|
||||
value: "443"
|
||||
displayName: clusterip service port
|
||||
- name: CLUSTERIP_SERVICE_TARGET_PORT
|
||||
value: "8443"
|
||||
displayName: clusterip service target port
|
||||
- name: QUAY_APP_COMPONENT_LABEL_KEY
|
||||
value: "quay-component"
|
||||
displayName: quay app selector label
|
||||
- name: QUAY_APP_COMPONENT_LABEL_VALUE
|
||||
value: "app"
|
||||
displayName: quay app selector label value
|
||||
- name: LOADBALANCER_SERVICE_PORT
|
||||
value: "443"
|
||||
displayName: loadbalancer service port
|
||||
- name: LOADBALANCER_SERVICE_TARGET_PORT
|
||||
value: "8443"
|
||||
displayName: loadbalancer service target port
|
||||
- name: QUAY_APP_CONFIG_SECRET
|
||||
value: "quay-config-secret"
|
||||
displayName: quay app config secret
|
||||
- name: QUAY_APP_DEPLOYMENT_REPLICAS
|
||||
value: "1"
|
||||
displayName: quay app deployment replicas
|
||||
- name: QUAY_APP_MEMORY_REQUEST
|
||||
value: "4096Mi"
|
||||
displayName: "quay app memory request"
|
||||
- name: QUAY_APP_CPU_REQUEST
|
||||
value: "1"
|
||||
displayName: "quay app CPU request"
|
||||
- name: QUAY_APP_MEMORY_LIMIT
|
||||
value: "4096Mi"
|
||||
displayName: "quay app memory limit"
|
||||
- name: QUAY_APP_CPU_LIMIT
|
||||
value: "1"
|
||||
displayName: "quay app CPU limit"
|
||||
- name: QUAY_APP_DEPLOYMENT_MIN_READY_SECONDS
|
||||
value: "0"
|
||||
displayName: quay app deployment min ready seconds
|
||||
- name: QUAY_APP_DEPLOYMENT_PROGRESS_DEADLINE_SECONDS
|
||||
value: "600s"
|
||||
displayName: quay app deployment progress deadline seconds
|
||||
- name: QUAY_APP_DEPLOYMENT_REVISION_HISTORY_LIMITS
|
||||
value: "10"
|
||||
displayName: quay app deployment revision history limits
|
||||
- name: QUAY_APP_DEPLOYMENT_STRATEGY_TYPE
|
||||
value: "RollingUpdate"
|
||||
displayName: quay app deployment strategy
|
||||
- name: QUAY_APP_DEPLOYMENT_MAX_SURGE
|
||||
value: "1"
|
||||
displayName: quay app deployment max surge
|
||||
- name: QUAY_APP_DEPLOYMENT_MAX_UNAVAILABLE
|
||||
value: "0"
|
||||
displayName: quay app deployment max unavailable
|
||||
- name: QUAY_APP_LIVENESS_PROBE_INITIAL_DELAY_SECONDS
|
||||
value: "15"
|
||||
displayName: quay app liveness probe initial delay seconds
|
||||
- name: QUAY_APP_LIVENESS_PROBE_PERIOD_SECONDS
|
||||
value: "30"
|
||||
displayName: quay app liveness probe period seconds
|
||||
- name: QUAY_APP_LIVENESS_PROBE_TIMEOUT_SECONDS
|
||||
value: "10"
|
||||
displayName: quay app liveness probe timeout
|
||||
- name: QUAY_APP_READINESS_PROBE_INITIAL_DELAY_SECONDS
|
||||
value: "15"
|
||||
displayName: quay app readiness probe initial delay seconds
|
||||
- name: QUAY_APP_READINESS_PROBE_PERIOD_SECONDS
|
||||
value: "30"
|
||||
displayName: quay app readiness probe period seconds
|
||||
- name: QUAY_APP_READINESS_PROBE_TIMEOUT_SECONDS
|
||||
value: "10"
|
||||
displayName: quay app readiness probe timeout
|
||||
|
Reference in a new issue