mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-10-25 14:31:11 +02:00 
			
		
		
		
	This removes use of private fork with custom `ip=` kernel argument handling and switches fully to upstream version of it. Firecracker Go SDK version is `master` + following PRs: * https://github.com/firecracker-microvm/firecracker-go-sdk/pull/167 * https://github.com/firecracker-microvm/firecracker-go-sdk/pull/177 * https://github.com/firecracker-microvm/firecracker-go-sdk/pull/178 MTU handling support was implemented as well. Changes: * hostname to each node is passed via `talos.hostname=` kernel arg * IP configuration is generated by SDK from CNI result * fixed bugs with wrong netmask * nameservers & MTU is passed via Talos config Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
		
			
				
	
	
		
			114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // This Source Code Form is subject to the terms of the Mozilla Public
 | |
| // License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
| // file, You can obtain one at http://mozilla.org/MPL/2.0/.
 | |
| 
 | |
| package provision
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"net"
 | |
| 
 | |
| 	"github.com/talos-systems/talos/internal/pkg/runtime"
 | |
| 	"github.com/talos-systems/talos/pkg/config/machine"
 | |
| )
 | |
| 
 | |
| // ClusterRequest is the root object describing cluster to be provisioned.
 | |
| type ClusterRequest struct {
 | |
| 	Name string
 | |
| 
 | |
| 	Network NetworkRequest
 | |
| 	Nodes   NodeRequests
 | |
| 
 | |
| 	Image             string
 | |
| 	KernelPath        string
 | |
| 	InitramfsPath     string
 | |
| 	KubernetesVersion string
 | |
| 
 | |
| 	// Path to osctl executable to re-execute itself as needed.
 | |
| 	SelfExecutable string
 | |
| 
 | |
| 	// Path to root of state directory (~/.talos/clusters by default).
 | |
| 	StateDirectory string
 | |
| }
 | |
| 
 | |
| // CNIConfig describes CNI part of NetworkRequest.
 | |
| type CNIConfig struct {
 | |
| 	BinPath  []string
 | |
| 	ConfDir  string
 | |
| 	CacheDir string
 | |
| }
 | |
| 
 | |
| // NetworkRequest describe cluster network.
 | |
| type NetworkRequest struct {
 | |
| 	Name        string
 | |
| 	CIDR        net.IPNet
 | |
| 	GatewayAddr net.IP
 | |
| 	MTU         int
 | |
| 	Nameservers []net.IP
 | |
| 
 | |
| 	// CNI-specific parameters.
 | |
| 	CNI CNIConfig
 | |
| }
 | |
| 
 | |
| // NodeRequests is a list of NodeRequest.
 | |
| type NodeRequests []NodeRequest
 | |
| 
 | |
| // FindInitNode looks up init node, it returns an error if no init node is present or if it's duplicate.
 | |
| func (reqs NodeRequests) FindInitNode() (req NodeRequest, err error) {
 | |
| 	found := false
 | |
| 
 | |
| 	for i := range reqs {
 | |
| 		if reqs[i].Config.Machine().Type() == machine.TypeInit {
 | |
| 			if found {
 | |
| 				err = fmt.Errorf("duplicate init node in requests")
 | |
| 				return
 | |
| 			}
 | |
| 
 | |
| 			req = reqs[i]
 | |
| 			found = true
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if !found {
 | |
| 		err = fmt.Errorf("no init node found in requests")
 | |
| 	}
 | |
| 
 | |
| 	return
 | |
| }
 | |
| 
 | |
| // MasterNodes returns subset of nodes which are Init/ControlPlane type.
 | |
| func (reqs NodeRequests) MasterNodes() (nodes []NodeRequest) {
 | |
| 	for i := range reqs {
 | |
| 		if reqs[i].Config.Machine().Type() == machine.TypeInit || reqs[i].Config.Machine().Type() == machine.TypeControlPlane {
 | |
| 			nodes = append(nodes, reqs[i])
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return
 | |
| }
 | |
| 
 | |
| // WorkerNodes returns subset of nodes which are Init/ControlPlane type.
 | |
| func (reqs NodeRequests) WorkerNodes() (nodes []NodeRequest) {
 | |
| 	for i := range reqs {
 | |
| 		if reqs[i].Config.Machine().Type() == machine.TypeWorker {
 | |
| 			nodes = append(nodes, reqs[i])
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return
 | |
| }
 | |
| 
 | |
| // NodeRequest describes a request for a node.
 | |
| type NodeRequest struct {
 | |
| 	Name   string
 | |
| 	IP     net.IP
 | |
| 	Config runtime.Configurator
 | |
| 
 | |
| 	// Share of CPUs, in 1e-9 fractions
 | |
| 	NanoCPUs int64
 | |
| 	// Memory limit in bytes
 | |
| 	Memory int64
 | |
| 	// Disk (volume) size in bytes, if applicable
 | |
| 	DiskSize int64
 | |
| }
 |