# 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) setupCalico: Body: - $._environment.reporter.report($this, 'Setup Calico network on node {0}'.format($.instance.name)) - $resources: new(sys:Resources) - $template: $resources.yaml('SetupCalicoNode.template').bind(dict( ip => $.getIp(), masterIp => $._cluster.masterNode.getIp() )) - $.instance.agent.call($template, $resources) - $._enableCalicoTraffic() setupFlannel: Body: - $._environment.reporter.report($this, 'Setup Flannel network on node {0}'.format($.instance.name)) - $resources: new(sys:Resources) - $template: $resources.yaml('SetupFlannelNode.template') - $.instance.agent.call($template, $resources) setupNode: Body: - If: not $.getAttr(nodeConfigured, false) Then: - $resources: new(sys: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, useFlannel => $._cluster.useFlannel )) - $.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))