103 lines
3.5 KiB
YAML
103 lines
3.5 KiB
YAML
Namespaces:
|
|
=: io.murano.apps.docker.kubernetes
|
|
std: io.murano
|
|
res: io.murano.resources
|
|
sys: io.murano.system
|
|
|
|
Name: KubernetesMinionNode
|
|
|
|
Extends: KubernetesNode
|
|
|
|
Properties:
|
|
enableMonitoring:
|
|
Contract: $.bool().notNull()
|
|
Default: false
|
|
|
|
|
|
Methods:
|
|
initialize:
|
|
Body:
|
|
- $._environment: $.find(std:Environment).require()
|
|
- $._cluster: $.find(KubernetesCluster).require()
|
|
|
|
|
|
deployInstance:
|
|
Body:
|
|
- If: not $.getAttr(instanceDeployed, false)
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Creating Kubernetes Minion')
|
|
- $.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)
|
|
|
|
- If: $.enableMonitoring
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Adding access to cAdvisor')
|
|
- $securityGroupIngress:
|
|
- ToPort: 4194
|
|
FromPort: 4194
|
|
IpProtocol: tcp
|
|
External: true
|
|
- $._environment.securityGroupManager.addGroupIngress($securityGroupIngress)
|
|
|
|
- $._environment.reporter.report($, 'Setup Kubernetes Minion on {0}'.format($.instance.name))
|
|
- $template: $resources.yaml('KubeMinionSetup.template').bind(dict(
|
|
name => $.instance.name,
|
|
ip => $.getIp(),
|
|
masterIp => $._cluster.masterNode.getIp(),
|
|
enableMonitoring => $.enableMonitoring,
|
|
dockerRegistry => $._cluster.dockerRegistry
|
|
))
|
|
- $.instance.agent.call($template, $resources)
|
|
|
|
- $template: $resources.yaml('KubeRegisterNode.template').bind(dict(
|
|
name => $.instance.name,
|
|
nodeId => $.getIp()
|
|
))
|
|
- $._cluster.masterNode.instance.agent.call($template, $resources)
|
|
- $.setAttr(nodeConfigured, true)
|
|
|
|
|
|
removeFromCluster:
|
|
Body:
|
|
- If: $.getAttr(nodeConfigured, false)
|
|
Then:
|
|
- $._environment.reporter.report($this, 'Deleting Kubernetes Minion')
|
|
- $resources: new(sys:Resources)
|
|
- $template: $resources.yaml('RemoveMinion.template').bind(dict(
|
|
nodeId => $.getIp()
|
|
))
|
|
- $._cluster.masterNode.instance.agent.call($template, $resources)
|
|
- $._environment.reporter.report($this, 'Node {0} deleted'.format($.instance.name))
|
|
- $.setAttr(nodeConfigured, false)
|