132 lines
4.8 KiB
YAML
132 lines
4.8 KiB
YAML
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
Namespaces:
|
|
=: com.mirantis.docker.kubernetes
|
|
std: io.murano
|
|
res: io.murano.resources
|
|
sys: io.murano.system
|
|
|
|
Name: KubernetesMinionNode
|
|
|
|
Extends: KubernetesNode
|
|
|
|
Properties:
|
|
exposeCAdvisor:
|
|
Contract: $.bool().notNull()
|
|
Default: false
|
|
|
|
|
|
Methods:
|
|
.init:
|
|
Body:
|
|
- $._environment: $.find(std:Environment).require()
|
|
- $._cluster: $.find(KubernetesCluster).require()
|
|
|
|
|
|
deployInstance:
|
|
Body:
|
|
- If: not $.getAttr(instanceDeployed, false)
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Creating Kubernetes Node {0}'.format($.instance.name))
|
|
- super($, $.deployInstance())
|
|
- $.setAttr(instanceDeployed, true)
|
|
|
|
|
|
setupEtcd:
|
|
Body:
|
|
- If: not $.getAttr(etcdConfigured, false)
|
|
Then:
|
|
- $._environment.reporter.report($, 'Configuring etcd node {0}'.format($.instance.name))
|
|
- $resources: new(sys:Resources)
|
|
- $template: $resources.yaml('EtcdAddMember.template').bind(dict(
|
|
name => $.instance.name,
|
|
ip => $.getIp()
|
|
))
|
|
- $clusterConfig: $._cluster.masterNode.instance.agent.call($template, $resources)
|
|
|
|
- $template: $resources.yaml('MemberEtcdSetup.template').bind(dict(
|
|
name => $.instance.name,
|
|
ip => $.getIp(),
|
|
clusterConfig => $clusterConfig
|
|
))
|
|
- $.instance.agent.call($template, $resources)
|
|
- $.setAttr(etcdConfigured, true)
|
|
|
|
|
|
setupNode:
|
|
Body:
|
|
- If: not $.getAttr(nodeConfigured, false)
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Setup Flannel network on {0}'.format($.instance.name))
|
|
- $resources: new(sys:Resources)
|
|
- $template: $resources.yaml('SetupFlannelNode.template')
|
|
- $.instance.agent.call($template, $resources)
|
|
|
|
- $securityGroupIngress:
|
|
- ToPort: 4194
|
|
FromPort: 4194
|
|
IpProtocol: tcp
|
|
External: $.exposeCAdvisor
|
|
- $._environment.securityGroupManager.addGroupIngress($securityGroupIngress)
|
|
|
|
- $._environment.reporter.report($, 'Setup Kubernetes Node on {0}'.format($.instance.name))
|
|
- $template: $resources.yaml('KubeMinionSetup.template').bind(dict(
|
|
name => $.instance.name,
|
|
ip => $.getIp(),
|
|
masterIp => $._cluster.masterNode.getIp(),
|
|
dockerRegistry => $._cluster.dockerRegistry,
|
|
dockerMirror => $._cluster.dockerMirror,
|
|
gcloudKey => $._cluster.gcloudKey
|
|
))
|
|
- $.instance.agent.call($template, $resources)
|
|
- $.setAttr(nodeConfigured, true)
|
|
- $msg: 'cAdvisor monitoring for Node {0} is now available at http://{1}:4194'
|
|
- $ip: $.getIp($.exposeCAdvisor)
|
|
- $._environment.reporter.report($this, $msg.format($.instance.name, $ip))
|
|
|
|
|
|
removeFromCluster:
|
|
Body:
|
|
- If: $.getAttr(nodeConfigured, false)
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Deleting Kubernetes Node')
|
|
- $resources: new(sys:Resources)
|
|
- $template: $resources.yaml('EtcdRemoveMember.template').bind(dict(
|
|
nodeId => $.getIp()
|
|
))
|
|
- $.instance.agent.call($template, $resources)
|
|
- $template: $resources.yaml('RemoveMinion.template').bind(dict(
|
|
nodeId => $.getIp()
|
|
))
|
|
- $._cluster.masterNode.instance.agent.call($template, $resources)
|
|
- $.instance.releaseResources()
|
|
- $._environment.reporter.report($this, 'Node {0} was deleted'.format($.instance.name))
|
|
- $.setAttr(nodeConfigured, false)
|
|
- $.setAttr(etcdConfigured, false)
|
|
- $.setAttr(instanceDeployed, false)
|
|
|
|
|
|
restartContainers:
|
|
Arguments:
|
|
- podName:
|
|
Contract: $.string().notNull()
|
|
|
|
Body:
|
|
- $._environment.reporter.report($this, 'Restarting {0} containers on {1}'.format($podName, $.instance.name))
|
|
- $resources: new(sys:Resources)
|
|
- $template: $resources.yaml('RestartContainers.template').bind(dict(
|
|
podName => $podName
|
|
))
|
|
- $.instance.agent.call($template, $resources)
|
|
- $._environment.reporter.report($this, '{0} containers on {1} restarted'.format($podName, $.instance.name))
|