Skip to content

Commit

Permalink
[kwokctl] Integrate metrics-server
Browse files Browse the repository at this point in the history
  • Loading branch information
wzshiming committed Oct 21, 2023
1 parent f293931 commit 4daa82a
Show file tree
Hide file tree
Showing 47 changed files with 1,538 additions and 26 deletions.
40 changes: 38 additions & 2 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -197,22 +197,58 @@ jobs:
run: |
export GOBIN="$(go env GOPATH)/bin"
cd "${GITHUB_WORKSPACE}/kubernetes" && go install ./cmd/{kube-apiserver,kube-controller-manager,kube-scheduler}
mkdir -p "${GITHUB_WORKSPACE//\\//}/workdir" && cat >"${GITHUB_WORKSPACE//\\//}/workdir/kwok.yaml" << EOF
mkdir -p "${GITHUB_WORKSPACE//\\//}/workdir" && cat >>"${GITHUB_WORKSPACE//\\//}/workdir/kwok.yaml" << EOF
kind: KwokctlConfiguration
apiVersion: config.kwok.x-k8s.io/v1alpha1
options:
kubeBinaryPrefix: "${GOBIN//\\//}"
---
EOF
- name: Build Kubernetes Binary for MacOS
if: ${{ matrix.kwokctl-runtime == 'binary' && matrix.os == 'macos-latest' }}
shell: bash
run: |
cd "${GITHUB_WORKSPACE}/kubernetes" && make WHAT="cmd/kube-apiserver cmd/kube-controller-manager cmd/kube-scheduler"
mkdir -p "${GITHUB_WORKSPACE}/workdir" && cat >"${GITHUB_WORKSPACE}/workdir/kwok.yaml" << EOF
mkdir -p "${GITHUB_WORKSPACE}/workdir" && cat >>"${GITHUB_WORKSPACE}/workdir/kwok.yaml" << EOF
kind: KwokctlConfiguration
apiVersion: config.kwok.x-k8s.io/v1alpha1
options:
kubeBinaryPrefix: "${GITHUB_WORKSPACE}/kubernetes/_output/bin"
---
EOF
# Build metrics-server binary
- name: Download Metrics Server Source Code
uses: actions/checkout@v3
if: ${{ matrix.kwokctl-runtime == 'binary' }}
with:
repository: kubernetes-sigs/metrics-server
path: metrics-server
ref: v0.6.3
- name: Build Metrics Server Binary for Linux and MacOS
if: ${{ matrix.kwokctl-runtime == 'binary' && matrix.os != 'windows-latest' }}
shell: bash
run: |
cd "${GITHUB_WORKSPACE}/metrics-server" && make metrics-server
mkdir -p "${GITHUB_WORKSPACE}/workdir" && cat >>"${GITHUB_WORKSPACE}/workdir/kwok.yaml" << EOF
kind: KwokctlConfiguration
apiVersion: config.kwok.x-k8s.io/v1alpha1
options:
metricsServerBinary: "${GITHUB_WORKSPACE}/metrics-server/metrics-server"
---
EOF
- name: Build Metrics Server Binary for Windows
if: ${{ matrix.kwokctl-runtime == 'binary' && matrix.os == 'windows-latest' }}
shell: bash
run: |
export GOBIN="$(go env GOPATH)/bin"
cd "${GITHUB_WORKSPACE}/metrics-server" && go install ./cmd/metrics-server
mkdir -p "${GITHUB_WORKSPACE//\\//}/workdir" && cat >>"${GITHUB_WORKSPACE//\\//}/workdir/kwok.yaml" << EOF
kind: KwokctlConfiguration
apiVersion: config.kwok.x-k8s.io/v1alpha1
options:
metricsServerBinary: "${GOBIN//\\//}/metrics-server.exe"
---
EOF
# TODO: workaround for https://github.com/actions/runner-images/issues/7753 (caused by https://bugs.launchpad.net/ubuntu/+source/libpod/+bug/2024394).
Expand Down
1 change: 1 addition & 0 deletions kustomize/kwokctl/resource/node.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ template: |-
annotations:
kwok.x-k8s.io/node: fake
node.alpha.kubernetes.io/ttl: "0"
metrics.k8s.io/resource-metrics-path: "/metrics/nodes/{{ Name }}/metrics/resource"
labels:
beta.kubernetes.io/arch: {{ .nodeInfo.architecture }}
beta.kubernetes.io/os: {{ .nodeInfo.operatingSystem }}
Expand Down
24 changes: 24 additions & 0 deletions pkg/apis/config/v1alpha1/kwokctl_configuration_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,9 @@ type KwokctlConfigurationOptions struct {
// is the default value for env KWOK_JAEGER_VERSION
JaegerVersion string `json:"jaegerVersion,omitempty"`

// MetricsServerVersion is the version of metrics-server to use.
MetricsServerVersion string `json:"metricsServerVersion,omitempty"`

// DockerComposeVersion is the version of docker-compose to use.
// is the default value for env KWOK_DOCKER_COMPOSE_VERSION
// Deprecated: docker compose will be removed in a future release
Expand Down Expand Up @@ -160,6 +163,10 @@ type KwokctlConfigurationOptions struct {
// +default=false
DisableKubeControllerManager *bool `json:"disableKubeControllerManager,omitempty"`

// EnableMetricsServer is the flag to enable metrics-server.
// +default=false
EnableMetricsServer *bool `json:"enableMetricsServer,omitempty"`

// KubeImagePrefix is the prefix of the kubernetes image.
// is the default value for env KWOK_KUBE_IMAGE_PREFIX
//+k8s:conversion-gen=false
Expand Down Expand Up @@ -189,6 +196,10 @@ type KwokctlConfigurationOptions struct {
//+k8s:conversion-gen=false
JaegerImagePrefix string `json:"jaegerImagePrefix,omitempty"`

// MetricsServerImagePrefix is the prefix of the metrics-server image.
//+k8s:conversion-gen=false
MetricsServerImagePrefix string `json:"metricsServerImagePrefix,omitempty"`

// EtcdImage is the image of etcd.
// is the default value for flag --etcd-image and env KWOK_ETCD_IMAGE
EtcdImage string `json:"etcdImage,omitempty"`
Expand Down Expand Up @@ -220,6 +231,9 @@ type KwokctlConfigurationOptions struct {
// is the default value for flag --jaeger-image and env KWOK_JAEGER_IMAGE
JaegerImage string `json:"jaegerImage,omitempty"`

// MetricsServerImage is the image of metrics-server.
MetricsServerImage string `json:"metricsServerImage,omitempty"`

// KindNodeImagePrefix is the prefix of the kind node image.
// is the default value for env KWOK_KIND_NODE_IMAGE_PREFIX
//+k8s:conversion-gen=false
Expand Down Expand Up @@ -310,6 +324,13 @@ type KwokctlConfigurationOptions struct {
// is the default value for env KWOK_JAEGER_TAR
JaegerBinaryTar string `json:"jaegerBinaryTar,omitempty"`

// MetricsServerBinaryPrefix is the prefix of the metrics-server binary.
//+k8s:conversion-gen=false
MetricsServerBinaryPrefix string `json:"metricsServerBinaryPrefix,omitempty"`

// MetricsServerBinary is the binary of metrics-server.
MetricsServerBinary string `json:"metricsServerBinary,omitempty"`

// DockerComposeBinaryPrefix is the binary of docker-compose.
// is the default value for env KWOK_DOCKER_COMPOSE_BINARY_PREFIX
// Deprecated: docker compose will be removed in a future release
Expand Down Expand Up @@ -373,6 +394,9 @@ type KwokctlConfigurationOptions struct {
// is the default value for flag --controller-port and env KWOK_CONTROLLER_PORT
KwokControllerPort uint32 `json:"kwokControllerPort,omitempty"`

// MetricsServerPort is metrics-server port that is exposed to the host.
MetricsServerPort uint32 `json:"metricsServerPort,omitempty"`

// CacheDir is the directory of the cache.
CacheDir string `json:"cacheDir,omitempty"`

Expand Down
5 changes: 5 additions & 0 deletions pkg/apis/config/v1alpha1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions pkg/apis/config/v1alpha1/zz_generated.defaults.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 15 additions & 0 deletions pkg/apis/internalversion/kwokctl_configuration_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,9 @@ type KwokctlConfigurationOptions struct {
// JaegerVersion is the version of Jaeger to use.
JaegerVersion string

// MetricsServerVersion is the version of metrics-server to use.
MetricsServerVersion string

// DockerComposeVersion is the version of docker-compose to use.
DockerComposeVersion string

Expand All @@ -126,6 +129,9 @@ type KwokctlConfigurationOptions struct {
// DisableKubeControllerManager is the flag to disable kube-controller-manager.
DisableKubeControllerManager bool

// EnableMetricsServer is the flag to enable metrics-server.
EnableMetricsServer bool

// EtcdImage is the image of etcd.
EtcdImage string

Expand All @@ -150,6 +156,9 @@ type KwokctlConfigurationOptions struct {
// JaegerImage is the image of Jaeger
JaegerImage string

// MetricsServerImage is the image of metrics-server.
MetricsServerImage string

// KindNodeImage is the image of kind node.
KindNodeImage string

Expand Down Expand Up @@ -194,6 +203,9 @@ type KwokctlConfigurationOptions struct {
// JaegerBinaryTar is the tar of binary of Jaeger.
JaegerBinaryTar string

// MetricsServerBinary is the binary of metrics-server.
MetricsServerBinary string

// DockerComposeBinary is the binary of Docker compose.
DockerComposeBinary string

Expand Down Expand Up @@ -236,6 +248,9 @@ type KwokctlConfigurationOptions struct {
// KwokControllerPort is kwok-controller port that is exposed to the host.
KwokControllerPort uint32

// MetricsServerPort is metrics-server port that is exposed to the host.
MetricsServerPort uint32

// CacheDir is the directory of the cache.
CacheDir string

Expand Down
16 changes: 16 additions & 0 deletions pkg/apis/internalversion/zz_generated.conversion.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

30 changes: 30 additions & 0 deletions pkg/config/vars.go
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,8 @@ func setKwokctlConfigurationDefaults(config *configv1alpha1.KwokctlConfiguration

setKwokctlJaegerConfig(conf)

setMetricsServerConfig(conf)

return config
}

Expand Down Expand Up @@ -527,6 +529,34 @@ func setKwokctlJaegerConfig(conf *configv1alpha1.KwokctlConfigurationOptions) {
conf.JaegerBinaryTar = envs.GetEnvWithPrefix("JAEGER_BINARY_TAR", conf.JaegerBinaryTar)
}

func setMetricsServerConfig(conf *configv1alpha1.KwokctlConfigurationOptions) {
if conf.MetricsServerVersion == "" {
conf.MetricsServerVersion = consts.MetricsServerVersion
}
conf.MetricsServerVersion = version.AddPrefixV(envs.GetEnvWithPrefix("METRICS_SERVER_VERSION", conf.MetricsServerVersion))

if conf.MetricsServerImagePrefix == "" {
conf.MetricsServerImagePrefix = consts.MetricsServerImagePrefix
}
conf.MetricsServerImagePrefix = envs.GetEnvWithPrefix("METRICS_SERVER_IMAGE_PREFIX", conf.MetricsServerImagePrefix)

if conf.MetricsServerImage == "" {
conf.MetricsServerImage = joinImageURI(conf.MetricsServerImagePrefix, "metrics-server", version.AddPrefixV(conf.MetricsServerVersion))
}
conf.MetricsServerImage = envs.GetEnvWithPrefix("METRICS_SERVER_IMAGE", conf.MetricsServerImage)

if conf.MetricsServerBinaryPrefix == "" {
conf.MetricsServerBinaryPrefix = consts.MetricsServerBinaryPrefix + "/" + conf.MetricsServerVersion
}
conf.MetricsServerBinaryPrefix = envs.GetEnvWithPrefix("METRICS_SERVER_BINARY_PREFIX", conf.MetricsServerBinaryPrefix)

if conf.MetricsServerBinaryPrefix != "" &&
conf.MetricsServerBinary == "" {
conf.MetricsServerBinary = conf.MetricsServerBinaryPrefix + "/metrics-server-" + GOOS + "-" + GOARCH + conf.BinSuffix
}
conf.MetricsServerBinary = envs.GetEnvWithPrefix("METRICS_SERVER_BINARY", conf.MetricsServerBinary)
}

// joinImageURI joins the image URI.
func joinImageURI(prefix, name, version string) string {
return prefix + "/" + name + ":" + version
Expand Down
4 changes: 4 additions & 0 deletions pkg/consts/consts.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,10 @@ var (
JaegerBinaryPrefix = "https://github.com/jaegertracing/jaeger/releases/download"
JaegerImagePrefix = "docker.io/jaegertracing"

MetricsServerVersion = "0.6.3"
MetricsServerBinaryPrefix = "https://github.com/kubernetes-sigs/metrics-server/releases/download"
MetricsServerImagePrefix = "registry.k8s.io/metrics-server"

DefaultUnlimitedQPS = 5000.0
DefaultUnlimitedBurst = 10000
)
Expand Down
9 changes: 9 additions & 0 deletions pkg/kwokctl/cmd/create/cluster/cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ func NewCommand(ctx context.Context) *cobra.Command {
cmd.Flags().StringVar(&flags.Options.KubeSchedulerConfig, "kube-scheduler-config", flags.Options.KubeSchedulerConfig, `Path to a kube-scheduler configuration file`)
cmd.Flags().BoolVar(&flags.Options.DisableKubeScheduler, "disable-kube-scheduler", flags.Options.DisableKubeScheduler, `Disable the kube-scheduler`)
cmd.Flags().BoolVar(&flags.Options.DisableKubeControllerManager, "disable-kube-controller-manager", flags.Options.DisableKubeControllerManager, `Disable the kube-controller-manager`)
cmd.Flags().BoolVar(&flags.Options.EnableMetricsServer, "enable-metrics-server", flags.Options.EnableMetricsServer, `Enable the metrics-server`)
cmd.Flags().StringVar(&flags.Options.EtcdImage, "etcd-image", flags.Options.EtcdImage, `Image of etcd, only for docker/podman/nerdctl runtime
'${KWOK_KUBE_IMAGE_PREFIX}/etcd:${KWOK_ETCD_VERSION}'
`)
Expand All @@ -85,6 +86,9 @@ func NewCommand(ctx context.Context) *cobra.Command {
cmd.Flags().Uint32Var(&flags.Options.KubeSchedulerPort, "kube-scheduler-port", flags.Options.KubeSchedulerPort, `Port of kube-scheduler given to the host, only for binary and docker/podman/nerdctl runtime`)
cmd.Flags().StringVar(&flags.Options.KwokControllerImage, "kwok-controller-image", flags.Options.KwokControllerImage, `Image of kwok-controller, only for docker/podman/nerdctl/kind/kind-podman runtime
'${KWOK_IMAGE_PREFIX}/kwok:${KWOK_VERSION}'
`)
cmd.Flags().StringVar(&flags.Options.MetricsServerImage, "metrics-server-image", flags.Options.MetricsServerImage, `Image of metrics-server, only for docker/podman/nerdctl/kind/kind-podman runtime
'${KWOK_METRICS_SERVER_IMAGE_PREFIX}/metrics-server:${KWOK_METRICS_SERVER_VERSION}'
`)
cmd.Flags().StringVar(&flags.Options.PrometheusImage, "prometheus-image", flags.Options.PrometheusImage, `Image of Prometheus, only for docker/podman/nerdctl/kind/kind-podman runtime
'${KWOK_PROMETHEUS_IMAGE_PREFIX}/prometheus:${KWOK_PROMETHEUS_VERSION}'
Expand All @@ -111,6 +115,7 @@ func NewCommand(ctx context.Context) *cobra.Command {
cmd.Flags().StringVar(&flags.Options.EtcdBinary, "etcd-binary", flags.Options.EtcdBinary, `Binary of etcd, only for binary runtime`)
cmd.Flags().StringVar(&flags.Options.EtcdBinaryTar, "etcd-binary-tar", flags.Options.EtcdBinaryTar, `Tar of etcd, if --etcd-binary is set, this is ignored, only for binary runtime
`)
cmd.Flags().StringVar(&flags.Options.MetricsServerBinary, "metrics-server-binary", flags.Options.MetricsServerBinary, `Binary of metrics-server, only for binary runtime`)
cmd.Flags().StringVar(&flags.Options.PrometheusBinary, "prometheus-binary", flags.Options.PrometheusBinary, `Binary of Prometheus, only for binary runtime`)
cmd.Flags().StringVar(&flags.Options.PrometheusBinaryTar, "prometheus-binary-tar", flags.Options.PrometheusBinaryTar, `Tar of Prometheus, if --prometheus-binary is set, this is ignored, only for binary runtime
`)
Expand Down Expand Up @@ -283,6 +288,10 @@ func runE(ctx context.Context, flags *flagpole) error {
if err != nil {
return fmt.Errorf("failed to init crds %q: %w", name, err)
}
err = rt.InitCRs(ctx)
if err != nil {
return fmt.Errorf("failed to init crs %q: %w", name, err)
}

// Wait for cluster to be ready
if flags.Wait > 0 {
Expand Down
Loading

0 comments on commit 4daa82a

Please sign in to comment.