Add kubelet.
This commit is contained in:
@@ -8,6 +8,7 @@
|
||||
# installCheckPhase
|
||||
# distPhase
|
||||
{
|
||||
config,
|
||||
lib,
|
||||
stdenv,
|
||||
writeShellScript,
|
||||
@@ -16,17 +17,35 @@
|
||||
...
|
||||
}:
|
||||
let
|
||||
vm_name_to_hostname =
|
||||
let
|
||||
mapping = {
|
||||
"nc0" = "controller0";
|
||||
"nc1" = "controller1";
|
||||
"nc2" = "controller2";
|
||||
"nw0" = "worker0";
|
||||
"nw1" = "worker1";
|
||||
"nw2" = "worker2";
|
||||
};
|
||||
in
|
||||
(vm_name: mapping."${vm_name}");
|
||||
|
||||
deploy_script_body = (
|
||||
''
|
||||
set -euo pipefail
|
||||
IFS=$'\n\t'
|
||||
DIR="$( cd "$( dirname "''${BASH_SOURCE[0]}" )" && pwd )"
|
||||
''
|
||||
+ (lib.concatMapStringsSep "\n" deploy_machine [
|
||||
+ (lib.concatMapStringsSep "\n" deploy_control_plane [
|
||||
"nc0"
|
||||
"nc1"
|
||||
"nc2"
|
||||
])
|
||||
+ (lib.concatMapStringsSep "\n" deploy_worker [
|
||||
"nw0"
|
||||
"nw1"
|
||||
"nw2"
|
||||
])
|
||||
);
|
||||
deploy_script = (writeShellScript "deploy-script" deploy_script_body);
|
||||
deploy_file = (
|
||||
@@ -50,14 +69,14 @@ let
|
||||
|
||||
''
|
||||
);
|
||||
deploy_machine = (
|
||||
deploy_control_plane = (
|
||||
vm_name:
|
||||
(
|
||||
''
|
||||
##
|
||||
## Create directories on ${vm_name}
|
||||
##
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 11235 -g 11235 -m 0755 /vm/${vm_name}/persist/keys
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 0 -g 0 -m 0755 /vm/${vm_name}/persist/keys
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 10016 -g 10016 -m 0755 /vm/${vm_name}/persist/keys/etcd
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 10024 -g 10024 -m 0755 /vm/${vm_name}/persist/keys/kube
|
||||
|
||||
@@ -152,6 +171,55 @@ let
|
||||
])
|
||||
)
|
||||
);
|
||||
deploy_worker = (
|
||||
vm_name:
|
||||
(
|
||||
''
|
||||
##
|
||||
## Create directories on ${vm_name}
|
||||
##
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 0 -g 0 -m 0755 /vm/${vm_name}/persist/keys
|
||||
${openssh}/bin/ssh mrmanager doas install -d -o 10024 -g 10024 -m 0755 /vm/${vm_name}/persist/keys/kube
|
||||
|
||||
|
||||
''
|
||||
+ (lib.concatMapStringsSep "\n" deploy_file [
|
||||
{
|
||||
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
||||
file = "${k8s.ca}/ca.crt";
|
||||
owner = 10024;
|
||||
group = 10024;
|
||||
mode = "0640";
|
||||
}
|
||||
{
|
||||
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
||||
file = "${k8s.keys."${vm_name_to_hostname vm_name}"}/${vm_name_to_hostname vm_name}.crt";
|
||||
name = "kubelet.crt";
|
||||
owner = 10024;
|
||||
group = 10024;
|
||||
mode = "0640";
|
||||
}
|
||||
{
|
||||
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
||||
file = "${k8s.keys."${vm_name_to_hostname vm_name}"}/${vm_name_to_hostname vm_name}.key";
|
||||
name = "kubelet.key";
|
||||
owner = 10024;
|
||||
group = 10024;
|
||||
mode = "0600";
|
||||
}
|
||||
{
|
||||
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
||||
file = "${
|
||||
k8s.client-configs."${vm_name_to_hostname vm_name}"
|
||||
}/${vm_name_to_hostname vm_name}.kubeconfig";
|
||||
name = "kubeconfig";
|
||||
owner = 10024;
|
||||
group = 10024;
|
||||
mode = "0600";
|
||||
}
|
||||
])
|
||||
)
|
||||
);
|
||||
in
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
name = "deploy-script";
|
||||
|
||||
@@ -69,12 +69,6 @@ let
|
||||
];
|
||||
};
|
||||
};
|
||||
# _vm_name_to_hostname = {
|
||||
# "nc0" = "controller0";
|
||||
# "nc1" = "controller1";
|
||||
# "nc2" = "controller2";
|
||||
# };
|
||||
# vm_name_to_hostname = (vm_name: _vm_name_to_hostname."${vm_name}");
|
||||
in
|
||||
makeScope newScope (
|
||||
self:
|
||||
@@ -113,27 +107,36 @@ makeScope newScope (
|
||||
{
|
||||
controller0 = {
|
||||
config_user = "system:node:controller0";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
controller1 = {
|
||||
config_user = "system:node:controller1";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
controller2 = {
|
||||
config_user = "system:node:controller2";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
worker0 = {
|
||||
config_user = "system:node:worker0";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://[2620:11f:7001:7:ffff:ffff:ad7:1dd]:6443";
|
||||
# config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
worker1 = {
|
||||
config_user = "system:node:worker1";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://[2620:11f:7001:7:ffff:ffff:ad7:1dd]:6443";
|
||||
# config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
worker2 = {
|
||||
config_user = "system:node:worker2";
|
||||
config_server = "https://server.kubernetes.local:6443";
|
||||
config_server = "https://[2620:11f:7001:7:ffff:ffff:ad7:1dd]:6443";
|
||||
# config_server = "https://127.0.0.1:6443";
|
||||
# config_server = "https://server.kubernetes.local:6443";
|
||||
};
|
||||
kube-proxy = {
|
||||
config_user = "system:kube-proxy";
|
||||
|
||||
Reference in New Issue
Block a user