mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-11-04 02:11:12 +01:00 
			
		
		
		
	This implements `osctl cluster destroy` for Firecracker, adds new utility command `osctl cluser show`. Firecracker mode now has control process for firecracker VMs, allowing clean reboots and background operations. Lots of small fixes to Firecracker mode, clean CNI shutdown, cleaning up netns, etc. Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
		
			
				
	
	
		
			71 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			1.8 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 docker
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"fmt"
 | 
						|
 | 
						|
	"github.com/talos-systems/talos/internal/pkg/provision"
 | 
						|
)
 | 
						|
 | 
						|
// Create Talos cluster as a set of docker containers on docker network.
 | 
						|
//
 | 
						|
//nolint: gocyclo
 | 
						|
func (p *provisioner) Create(ctx context.Context, request provision.ClusterRequest, opts ...provision.Option) (provision.Cluster, error) {
 | 
						|
	var err error
 | 
						|
 | 
						|
	options := provision.DefaultOptions()
 | 
						|
 | 
						|
	for _, opt := range opts {
 | 
						|
		if err = opt(&options); err != nil {
 | 
						|
			return nil, err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	if err = p.ensureImageExists(ctx, request.Image, &options); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Fprintln(options.LogWriter, "creating network", request.Network.Name)
 | 
						|
 | 
						|
	if err = p.createNetwork(ctx, request.Network); err != nil {
 | 
						|
		return nil, fmt.Errorf("unable to create or re-use a docker network: %w", err)
 | 
						|
	}
 | 
						|
 | 
						|
	var nodeInfo []provision.NodeInfo
 | 
						|
 | 
						|
	fmt.Fprintln(options.LogWriter, "creating master nodes")
 | 
						|
 | 
						|
	if nodeInfo, err = p.createNodes(ctx, request, request.Nodes.MasterNodes()); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Fprintln(options.LogWriter, "creating worker nodes")
 | 
						|
 | 
						|
	var workerNodeInfo []provision.NodeInfo
 | 
						|
 | 
						|
	if workerNodeInfo, err = p.createNodes(ctx, request, request.Nodes.WorkerNodes()); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	nodeInfo = append(nodeInfo, workerNodeInfo...)
 | 
						|
 | 
						|
	res := &result{
 | 
						|
		clusterInfo: provision.ClusterInfo{
 | 
						|
			ClusterName: request.Name,
 | 
						|
			Network: provision.NetworkInfo{
 | 
						|
				Name:        request.Network.Name,
 | 
						|
				CIDR:        request.Network.CIDR,
 | 
						|
				GatewayAddr: request.Network.GatewayAddr,
 | 
						|
				MTU:         request.Network.MTU,
 | 
						|
			},
 | 
						|
			Nodes: nodeInfo,
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	return res, nil
 | 
						|
}
 |