1
// This Source Code Form is subject to the terms of the Mozilla Public
2
// License, v. 2.0. If a copy of the MPL was not distributed with this
3
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
15
"github.com/siderolabs/gen/xslices"
17
"github.com/siderolabs/talos/pkg/provision"
25
// CreateLoadBalancer creates load balancer.
26
func (p *Provisioner) CreateLoadBalancer(state *State, clusterReq provision.ClusterRequest) error {
27
pidPath := state.GetRelativePath(lbPid)
29
logFile, err := os.OpenFile(state.GetRelativePath(lbLog), os.O_APPEND|os.O_CREATE|os.O_RDWR, 0o666)
34
defer logFile.Close() //nolint:errcheck
36
controlPlaneIPs := xslices.Map(clusterReq.Nodes.ControlPlaneNodes(), func(req provision.NodeRequest) string { return req.IPs[0].String() })
37
ports := xslices.Map(clusterReq.Network.LoadBalancerPorts, strconv.Itoa)
40
"loadbalancer-launch",
41
"--loadbalancer-addr", clusterReq.Network.GatewayAddrs[0].String(),
42
"--loadbalancer-upstreams", strings.Join(controlPlaneIPs, ","),
46
args = append(args, "--loadbalancer-ports", strings.Join(ports, ","))
49
cmd := exec.Command(clusterReq.SelfExecutable, args...)
52
cmd.SysProcAttr = &syscall.SysProcAttr{
53
Setsid: true, // daemonize
56
if err = cmd.Start(); err != nil {
60
if err = os.WriteFile(pidPath, []byte(strconv.Itoa(cmd.Process.Pid)), os.ModePerm); err != nil {
61
return fmt.Errorf("error writing LB PID file: %w", err)
67
// DestroyLoadBalancer destroys load balancer.
68
func (p *Provisioner) DestroyLoadBalancer(state *State) error {
69
pidPath := state.GetRelativePath(lbPid)
71
return StopProcessByPidfile(pidPath)