Puppet Class: k8s::proxy

Defined in:
modules/k8s/manifests/proxy.pp

Overview

SPDX-License-Identifier: Apache-2.0 Class that sets up and configures kube-proxy

Parameters:

  • version (K8s::KubernetesVersion)
  • kubeconfig (Stdlib::Unixpath)
  • cluster_cidr (K8s::ClusterCIDR)
  • ipv6dualstack (Boolean) (defaults to: false)
  • proxy_mode (Enum['iptables', 'ipvs']) (defaults to: 'iptables')
  • v_log_level (Integer) (defaults to: 0)


3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# File 'modules/k8s/manifests/proxy.pp', line 3

class k8s::proxy (
    K8s::KubernetesVersion $version,
    Stdlib::Unixpath $kubeconfig,
    K8s::ClusterCIDR $cluster_cidr,
    Boolean $ipv6dualstack = false,
    Enum['iptables', 'ipvs'] $proxy_mode = 'iptables',
    Integer $v_log_level = 0,
) {
    k8s::package { 'proxy':
        package => 'node',
        version => $version,
    }

    $_clustercidr = $ipv6dualstack ? {
        true  => "${cluster_cidr['v4']},${cluster_cidr['v6']}",
        false => $cluster_cidr['v4'],
    }

    # Create the KubeProxyConfiguration YAML
    $config_yaml = {
        apiVersion         => 'kubeproxy.config.k8s.io/v1alpha1',
        kind               => 'KubeProxyConfiguration',
        hostnameOverride   => $facts['fqdn'],
        clientConnection   => { kubeconfig => $kubeconfig },
        clusterCIDR        => $_clustercidr,
        mode               => $proxy_mode,
        metricsBindAddress => '0.0.0.0',
    }
    $config_file = '/etc/kubernetes/kube-proxy-config.yaml'
    file { $config_file:
        ensure  => file,
        owner   => 'kube',
        group   => 'kube',
        mode    => '0400',
        content => $config_yaml.filter |$k, $v| { $v =~ NotUndef and !$v.empty }.to_yaml,
        notify  => Service['kube-proxy'],
        require => K8s::Package['proxy'],
    }

    file { '/etc/default/kube-proxy':
        ensure  => file,
        owner   => 'root',
        group   => 'root',
        mode    => '0644',
        content => template('k8s/kube-proxy.default.erb'),
        notify  => Service['kube-proxy'],
    }

    systemd::service { 'kube-proxy':
        ensure    => present,
        restart   => true,
        override  => true,
        content   => "[Unit]\nAfter = ferm.service",
        subscribe => File[$kubeconfig],
    }
}