A Kubernetes Cluster is a collection of Docker hosts, and a set of management features for running Docker containers in a clustered environment. A sample Kubernetes Cluster definition, together with information on all the properties that can be added in a Kubernetes Cluster definition JSON are as follows:
The following are sample configurations that can be used in a JSON to define a Kubernetes-CoreOS Cluster:
{ "clusterId": "kubernetes-cluster-1", "description": "Kubernetes Cluster 1", "kubernetesMaster": { "hostId": "master", "hostname": "master.dev.kubernetes.org", "privateIPAddress": "172.17.8.101", "publicIPAddress": "172.17.8.101", "property": [ ] }, "portRange": { "upper": "5000", "lower": "4500" }, "kubernetesHosts": [ { "hostId": "minion-1", "hostname": "minion-1.dev.kubernetes.org", "privateIPAddress": "172.17.8.102", "publicIPAddress": "172.17.8.102", "property": [ ] } ], "property": [ { "name": "payload_parameter.MB_IP", "value": "172.17.8.1" }, { "name": "payload_parameter.MB_PORT", "value": "1883" }, { "name": "payload_parameter.CEP_IP", "value": "172.17.8.1" }, { "name": "payload_parameter.CEP_PORT", "value": "7711" }, { "name": "payload_parameter.LOG_LEVEL", "value": "DEBUG" }, { "name": "payload_parameter.METADATA_SERVICE_URL", "value": "https://172.17.8.1:9443" } ] }
{ "clusterId": "kubernetes-cluster-1", "description": "Kubernetes Cluster 1", "kubernetesMaster": { "hostId": "master", "hostname": "master.dev.kubernetes.org", "privateIPAddress": "172.17.8.101", "publicIPAddress": "172.17.8.101", "property": [ ] }, "portRange": { "upper": "32767", "lower": "30000" }, "kubernetesHosts": [ { "hostId": "minion-1", "hostname": "minion-1.dev.kubernetes.org", "privateIPAddress": "172.17.8.102", "publicIPAddress": "172.17.8.102", "property": [ ] } ], "property": [ { "name": "payload_parameter.MB_IP", "value": "172.17.8.1" }, { "name": "payload_parameter.MB_PORT", "value": "1883" }, { "name": "payload_parameter.CEP_IP", "value": "172.17.8.1" }, { "name": "payload_parameter.CEP_PORT", "value": "7711" }, { "name": "payload_parameter.LOG_LEVEL", "value": "DEBUG" }, { "name": "payload_parameter.METADATA_SERVICE_URL", "value": "https://172.17.8.1:9443" } ] }
The portRange
values changed in 4.1.1. Apache Stratos now supports both the NodePort and ClusterIP service types in Kubernetes.
You can configure the KUBERNETES_MASTER_PORT
by defining it under the Kubernetes Master property
parameter.
Example:
{ "name": "KUBERNETES_MASTER_PORT", "value": "8080" }
All the properties that correspond to the Kubernetes Cluster resource are explained as follows:
Property | Description | Data | Example | ||||||
---|---|---|---|---|---|---|---|---|---|
JSON | UI | ||||||||
| clusterId | √ | √ | X | ID of the Kubernetes cluster. This needs to be a unique value. | Yes | N/A | String | kubernetes-cluster-1 |
| description | √ | √ | √ | A short description of the Kubernetes Cluster. | Yes | N/A | String | Kubernetes Cluster 1 |
| kubernetesMaster | √ | √ | √ | The Kubernetes master definition. For more information on the sub-properties, see kubernetesMaster. | Yes | N/A | kubernetesMaster | N/A |
| portRange | √ | √ | √ | The allowed port range for the service. | Yes | N/A | portRange | N/A |
| kubernetesHosts | √ | √ | √ | The Kubernetes host (salve/minion) definition. or more information on the sub-properties, see kubernetesHosts. | Yes | N/A | kubernetesHosts array | N/A |
| property | √ | √ | √ | These are properties that are used by Stratos when creating the Stratos Kubernetes Cluster. These properties are listed as name value pairs. | Yes | N/A | property array | N/A |
Property | Description | Data | Example | ||||||
---|---|---|---|---|---|---|---|---|---|
JSON | UI | ||||||||
| hostId | √ | √ | X | Unique ID of the Kubernetes master. | Yes | N/A | String | master |
| hostname | √ | √ | √ | The hostname of the Kubernetes master. | Yes | N/A | String | master.dev.kubernetes.org |
| privateIPAddress | √ | √ | √ | The IP address of the Kubernetes master used to communicate within the Kubernetes cluster. | Yes | N/A | String | 172.17.8.101 |
| publicIPAddress | √ | √ | √ | The IP address of the Kubernetes master used for external communication. | Yes | N/A | String | 172.17.8.101 |
| property | √ | √ | √ | These are properties that are used by Stratos when creating the Stratos Kubernetes Master. These properties are listed as name value pairs. For more information on the sub-properties, see property . | Yes | N/A | property array | N/A |
Property | Description | Data | Example | ||||||
---|---|---|---|---|---|---|---|---|---|
JSON | UI | ||||||||
| hostId | √ | √ | X | Unique ID of the Kubernetes Host. | Yes | N/A | String | minion-1 |
| hostname | √ | √ | √ | The hostname of the Kubernetes Host. | Yes | N/A | String | minion-1.dev.kubernetes.org |
| privateIPAddress | √ | √ | √ | The IP address of the Kubernetes Host used to communicate within the Kubernetes Cluster. | Yes | N/A | String | 172.17.8.102 |
| publicIPAddress | √ | √ | √ | The IP address of the Kubernetes Host used for external communication. | Yes | N/A | String | 172.17.8.102 |
| property | √ | √ | √ | These are properties that are used by Stratos when creating the Stratos Kubernetes Host. These properties are listed as name value pairs. For more information on the sub-properties, see property. | Yes | N/A | property array | N/A |
Property | Description | Data | Example | ||||||
---|---|---|---|---|---|---|---|---|---|
JSON | UI | ||||||||
| lower | √ | √ | √ | This is the lower limit of the service port range. | Yes | N/A | Int | 4500 |
| upper | √ | √ | √ | This is the upper limit of the service port range. | Yes | N/A | Int | 5000 |
Property Name | Description | Required | Example Value |
---|---|---|---|
| Message Broker IP. | Yes | 172.17.42.1 |
| Message Broker port. | Yes | 1883 |
| Complex Event Processor IP. | Yes | 172.17.42.1 |
| Complex Event Processor port. | Yes | 7611 |
| If this property is set to | Yes | DEBUG |
| The URL used to access the Metadata service. | Yes |