123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 |
- {
- "apiVersion": "v1",
- "kind": "Template",
- "labels": {
- "template": "postgresql-persistent-template"
- },
- "message": "The following service(s) have been created in your project: ${DATABASE_SERVICE_NAME}.\n\n Username: ${POSTGRESQL_USER}\n Password: ${POSTGRESQL_PASSWORD}\n Database Name: ${POSTGRESQL_DATABASE}\n Connection URL: postgresql://${DATABASE_SERVICE_NAME}:5432/\n\nFor more information about using this template, including OpenShift considerations, see https://github.com/sclorg/postgresql-container/.",
- "metadata": {
- "annotations": {
- "description": "PostgreSQL database service, with persistent storage. For more information about using this template, including OpenShift considerations, see https://github.com/sclorg/postgresql-container/.\n\nNOTE: Scaling to more than one replica is not supported. You must have persistent volumes available in your cluster to use this template.",
- "iconClass": "icon-postgresql",
- "openshift.io/display-name": "PostgreSQL",
- "openshift.io/documentation-url": "https://docs.openshift.org/latest/using_images/db_images/postgresql.html",
- "openshift.io/long-description": "This template provides a standalone PostgreSQL server with a database created. The database is stored on persistent storage. The database name, username, and password are chosen via parameters when provisioning this service.",
- "openshift.io/provider-display-name": "Red Hat, Inc.",
- "openshift.io/support-url": "https://access.redhat.com",
- "tags": "database,postgresql"
- },
- "name": "postgresql-persistent"
- },
- "objects": [
- {
- "apiVersion": "v1",
- "kind": "Secret",
- "metadata": {
- "annotations": {
- "template.openshift.io/expose-database_name": "{.data['database-name']}",
- "template.openshift.io/expose-password": "{.data['database-password']}",
- "template.openshift.io/expose-username": "{.data['database-user']}"
- },
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "stringData": {
- "database-name": "${POSTGRESQL_DATABASE}",
- "database-password": "${POSTGRESQL_PASSWORD}",
- "database-user": "${POSTGRESQL_USER}"
- }
- },
- {
- "apiVersion": "v1",
- "kind": "Service",
- "metadata": {
- "annotations": {
- "template.openshift.io/expose-uri": "postgres://{.spec.clusterIP}:{.spec.ports[?(.name==\"postgresql\")].port}"
- },
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "spec": {
- "ports": [
- {
- "name": "postgresql",
- "nodePort": 0,
- "port": 5432,
- "protocol": "TCP",
- "targetPort": 5432
- }
- ],
- "selector": {
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "sessionAffinity": "None",
- "type": "ClusterIP"
- },
- "status": {
- "loadBalancer": {}
- }
- },
- {
- "apiVersion": "v1",
- "kind": "PersistentVolumeClaim",
- "metadata": {
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "spec": {
- "accessModes": [
- "ReadWriteOnce"
- ],
- "resources": {
- "requests": {
- "storage": "${VOLUME_CAPACITY}"
- }
- }
- }
- },
- {
- "apiVersion": "v1",
- "kind": "DeploymentConfig",
- "metadata": {
- "annotations": {
- "template.alpha.openshift.io/wait-for-ready": "true"
- },
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "spec": {
- "replicas": 1,
- "selector": {
- "name": "${DATABASE_SERVICE_NAME}"
- },
- "strategy": {
- "type": "Recreate"
- },
- "template": {
- "metadata": {
- "labels": {
- "name": "${DATABASE_SERVICE_NAME}"
- }
- },
- "spec": {
- "containers": [
- {
- "capabilities": {},
- "env": [
- {
- "name": "POSTGRESQL_USER",
- "valueFrom": {
- "secretKeyRef": {
- "key": "database-user",
- "name": "${DATABASE_SERVICE_NAME}"
- }
- }
- },
- {
- "name": "POSTGRESQL_PASSWORD",
- "valueFrom": {
- "secretKeyRef": {
- "key": "database-password",
- "name": "${DATABASE_SERVICE_NAME}"
- }
- }
- },
- {
- "name": "POSTGRESQL_DATABASE",
- "valueFrom": {
- "secretKeyRef": {
- "key": "database-name",
- "name": "${DATABASE_SERVICE_NAME}"
- }
- }
- }
- ],
- "image": " ",
- "imagePullPolicy": "IfNotPresent",
- "livenessProbe": {
- "exec": {
- "command": [
- "/usr/libexec/check-container",
- "--live"
- ]
- },
- "initialDelaySeconds": 120,
- "timeoutSeconds": 10
- },
- "name": "postgresql",
- "ports": [
- {
- "containerPort": 5432,
- "protocol": "TCP"
- }
- ],
- "readinessProbe": {
- "exec": {
- "command": [
- "/usr/libexec/check-container"
- ]
- },
- "initialDelaySeconds": 5,
- "timeoutSeconds": 1
- },
- "resources": {
- "limits": {
- "memory": "${MEMORY_LIMIT}"
- }
- },
- "securityContext": {
- "capabilities": {},
- "privileged": false
- },
- "terminationMessagePath": "/dev/termination-log",
- "volumeMounts": [
- {
- "mountPath": "/var/lib/pgsql/data",
- "name": "${DATABASE_SERVICE_NAME}-data"
- }
- ]
- }
- ],
- "dnsPolicy": "ClusterFirst",
- "restartPolicy": "Always",
- "volumes": [
- {
- "name": "${DATABASE_SERVICE_NAME}-data",
- "persistentVolumeClaim": {
- "claimName": "${DATABASE_SERVICE_NAME}"
- }
- }
- ]
- }
- },
- "triggers": [
- {
- "imageChangeParams": {
- "automatic": true,
- "containerNames": [
- "postgresql"
- ],
- "from": {
- "kind": "ImageStreamTag",
- "name": "postgresql:${POSTGRESQL_VERSION}",
- "namespace": "${NAMESPACE}"
- },
- "lastTriggeredImage": ""
- },
- "type": "ImageChange"
- },
- {
- "type": "ConfigChange"
- }
- ]
- },
- "status": {}
- }
- ],
- "parameters": [
- {
- "description": "Maximum amount of memory the container can use.",
- "displayName": "Memory Limit",
- "name": "MEMORY_LIMIT",
- "required": true,
- "value": "512Mi"
- },
- {
- "description": "The OpenShift Namespace where the ImageStream resides.",
- "displayName": "Namespace",
- "name": "NAMESPACE",
- "value": "openshift"
- },
- {
- "description": "The name of the OpenShift Service exposed for the database.",
- "displayName": "Database Service Name",
- "name": "DATABASE_SERVICE_NAME",
- "required": true,
- "value": "postgresql"
- },
- {
- "description": "Username for PostgreSQL user that will be used for accessing the database.",
- "displayName": "PostgreSQL Connection Username",
- "from": "user[A-Z0-9]{3}",
- "generate": "expression",
- "name": "POSTGRESQL_USER",
- "required": true
- },
- {
- "description": "Password for the PostgreSQL connection user.",
- "displayName": "PostgreSQL Connection Password",
- "from": "[a-zA-Z0-9]{16}",
- "generate": "expression",
- "name": "POSTGRESQL_PASSWORD",
- "required": true
- },
- {
- "description": "Name of the PostgreSQL database accessed.",
- "displayName": "PostgreSQL Database Name",
- "name": "POSTGRESQL_DATABASE",
- "required": true,
- "value": "sampledb"
- },
- {
- "description": "Volume space available for data, e.g. 512Mi, 2Gi.",
- "displayName": "Volume Capacity",
- "name": "VOLUME_CAPACITY",
- "required": true,
- "value": "1Gi"
- },
- {
- "description": "Version of PostgreSQL image to be used (9.4, 9.5, 9.6 or latest).",
- "displayName": "Version of PostgreSQL Image",
- "name": "POSTGRESQL_VERSION",
- "required": true,
- "value": "9.6"
- }
- ]
- }
|