|
@@ -0,0 +1,208 @@
|
|
|
+{
|
|
|
+ "kind": "Template",
|
|
|
+ "apiVersion": "v1",
|
|
|
+ "metadata": {
|
|
|
+ "name": "mariadb-persistent",
|
|
|
+ "annotations": {
|
|
|
+ "description": "MariaDB database service, with persistent storage. Scaling to more than one replica is not supported. You must have persistent volumes available in your cluster to use this template.",
|
|
|
+ "iconClass": "icon-mariadb",
|
|
|
+ "tags": "database,mariadb"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "objects": [
|
|
|
+ {
|
|
|
+ "kind": "Service",
|
|
|
+ "apiVersion": "v1",
|
|
|
+ "metadata": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ },
|
|
|
+ "spec": {
|
|
|
+ "ports": [
|
|
|
+ {
|
|
|
+ "name": "mariadb",
|
|
|
+ "port": 3306
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "selector": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "kind": "PersistentVolumeClaim",
|
|
|
+ "apiVersion": "v1",
|
|
|
+ "metadata": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ },
|
|
|
+ "spec": {
|
|
|
+ "accessModes": [
|
|
|
+ "ReadWriteOnce"
|
|
|
+ ],
|
|
|
+ "resources": {
|
|
|
+ "requests": {
|
|
|
+ "storage": "${VOLUME_CAPACITY}"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "kind": "DeploymentConfig",
|
|
|
+ "apiVersion": "v1",
|
|
|
+ "metadata": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ },
|
|
|
+ "spec": {
|
|
|
+ "strategy": {
|
|
|
+ "type": "Recreate"
|
|
|
+ },
|
|
|
+ "triggers": [
|
|
|
+ {
|
|
|
+ "type": "ImageChange",
|
|
|
+ "imageChangeParams": {
|
|
|
+ "automatic": true,
|
|
|
+ "containerNames": [
|
|
|
+ "mariadb"
|
|
|
+ ],
|
|
|
+ "from": {
|
|
|
+ "kind": "ImageStreamTag",
|
|
|
+ "name": "mariadb:10.1",
|
|
|
+ "namespace": "${NAMESPACE}"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "type": "ConfigChange"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "replicas": 1,
|
|
|
+ "selector": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ },
|
|
|
+ "template": {
|
|
|
+ "metadata": {
|
|
|
+ "labels": {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "spec": {
|
|
|
+ "containers": [
|
|
|
+ {
|
|
|
+ "name": "mariadb",
|
|
|
+ "image": " ",
|
|
|
+ "ports": [
|
|
|
+ {
|
|
|
+ "containerPort": 3306
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "readinessProbe": {
|
|
|
+ "timeoutSeconds": 1,
|
|
|
+ "initialDelaySeconds": 5,
|
|
|
+ "exec": {
|
|
|
+ "command": [ "/bin/sh", "-i", "-c",
|
|
|
+ "MYSQL_PWD=\"$MYSQL_PASSWORD\" mysql -h 127.0.0.1 -u $MYSQL_USER -D $MYSQL_DATABASE -e 'SELECT 1'"]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "livenessProbe": {
|
|
|
+ "timeoutSeconds": 1,
|
|
|
+ "initialDelaySeconds": 30,
|
|
|
+ "tcpSocket": {
|
|
|
+ "port": 3306
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "env": [
|
|
|
+ {
|
|
|
+ "name": "MYSQL_USER",
|
|
|
+ "value": "${MYSQL_USER}"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "MYSQL_PASSWORD",
|
|
|
+ "value": "${MYSQL_PASSWORD}"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "MYSQL_DATABASE",
|
|
|
+ "value": "${MYSQL_DATABASE}"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "resources": {
|
|
|
+ "limits": {
|
|
|
+ "memory": "${MEMORY_LIMIT}"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "volumeMounts": [
|
|
|
+ {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}-data",
|
|
|
+ "mountPath": "/var/lib/mysql/data"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "imagePullPolicy": "IfNotPresent"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "volumes": [
|
|
|
+ {
|
|
|
+ "name": "${DATABASE_SERVICE_NAME}-data",
|
|
|
+ "persistentVolumeClaim": {
|
|
|
+ "claimName": "${DATABASE_SERVICE_NAME}"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "parameters": [
|
|
|
+ {
|
|
|
+ "name": "MEMORY_LIMIT",
|
|
|
+ "displayName": "Memory Limit",
|
|
|
+ "description": "Maximum amount of memory the container can use.",
|
|
|
+ "value": "512Mi",
|
|
|
+ "required": true
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "NAMESPACE",
|
|
|
+ "displayName": "Namespace",
|
|
|
+ "description": "The OpenShift Namespace where the ImageStream resides.",
|
|
|
+ "value": "openshift"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "DATABASE_SERVICE_NAME",
|
|
|
+ "displayName": "Database Service Name",
|
|
|
+ "description": "The name of the OpenShift Service exposed for the database.",
|
|
|
+ "value": "mariadb",
|
|
|
+ "required": true
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "MYSQL_USER",
|
|
|
+ "displayName": "MariaDB Connection Username",
|
|
|
+ "description": "Username for MariaDB user that will be used for accessing the database.",
|
|
|
+ "generate": "expression",
|
|
|
+ "from": "user[A-Z0-9]{3}",
|
|
|
+ "required": true
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "MYSQL_PASSWORD",
|
|
|
+ "displayName": "MariaDB Connection Password",
|
|
|
+ "description": "Password for the MariaDB connection user.",
|
|
|
+ "generate": "expression",
|
|
|
+ "from": "[a-zA-Z0-9]{16}",
|
|
|
+ "required": true
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "MYSQL_DATABASE",
|
|
|
+ "displayName": "MariaDB Database Name",
|
|
|
+ "description": "Name of the MariaDB database accessed.",
|
|
|
+ "value": "sampledb",
|
|
|
+ "required": true
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "VOLUME_CAPACITY",
|
|
|
+ "displayName": "Volume Capacity",
|
|
|
+ "description": "Volume space available for data, e.g. 512Mi, 2Gi.",
|
|
|
+ "value": "1Gi",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "labels": {
|
|
|
+ "template": "mariadb-persistent-template"
|
|
|
+ }
|
|
|
+}
|