From 5184c7809cff9541abeda37e63cb790c50c13974 Mon Sep 17 00:00:00 2001 From: RJ Sampson Date: Thu, 12 Dec 2024 10:50:14 -0700 Subject: [PATCH] feat: Add kubernetes daemonsets for fluentd 1.17 Signed-off-by: RJ Sampson --- ...3.1-fluentd-kubernetes-daemonset-1.17.yaml | 142 ++++++++++++++++++ ...3.2-fluentd-kubernetes-daemonset-1.17.yaml | 142 ++++++++++++++++++ ...3.3-fluentd-kubernetes-daemonset-1.17.yaml | 142 ++++++++++++++++++ ...3.4-fluentd-kubernetes-daemonset-1.17.yaml | 140 +++++++++++++++++ 4 files changed, 566 insertions(+) create mode 100644 ruby3.1-fluentd-kubernetes-daemonset-1.17.yaml create mode 100644 ruby3.2-fluentd-kubernetes-daemonset-1.17.yaml create mode 100644 ruby3.3-fluentd-kubernetes-daemonset-1.17.yaml create mode 100644 ruby3.4-fluentd-kubernetes-daemonset-1.17.yaml diff --git a/ruby3.1-fluentd-kubernetes-daemonset-1.17.yaml b/ruby3.1-fluentd-kubernetes-daemonset-1.17.yaml new file mode 100644 index 00000000000..805c563f799 --- /dev/null +++ b/ruby3.1-fluentd-kubernetes-daemonset-1.17.yaml @@ -0,0 +1,142 @@ +package: + # fluentd supported versions: https://github.com/fluent/fluentd/blob/master/SECURITY.md + # The kubernetes daemonset trails fluentd releases by a bit + name: ruby3.1-fluentd-kubernetes-daemonset-1.17 + version: 1.17.1.1.2 + epoch: 0 + description: Fluentd ${{vars.fluentdMM}} daemonset for Kubernetes + copyright: + - license: Apache-2.0 + +environment: + contents: + packages: + - autoconf + - automake + - bash + - build-base + - busybox + - ca-certificates-bundle + - libtool + - m4 + - ruby${{vars.rubyMM}}-bundler + - ruby-${{vars.rubyMM}}-dev + - snappy-dev + +var-transforms: + - from: ${{package.name}} + match: .*-(\d+\.\d+) + replace: $1 + to: fluentdMM + - from: ${{package.name}} + match: ^ruby(\d\.\d+)-.* + replace: $1 + to: rubyMM + - from: ${{package.version}} + match: ^(\d+\.\d+\.\d+)\.(\d+\.\d+) + replace: $1-$2 + to: mangled-package-version + +data: + - name: plugins + items: + azureblob: + cloudwatch: + elasticsearch7: + elasticsearch8: + forward: + gcs: + graylog: + kafka: + kafka2: + kinesis: + logentries: + loggly: + logzio: + opensearch: + papertrail: + s3: + syslog: + +pipeline: + - uses: git-checkout + with: + expected-commit: 6183f108748bc4ed980437d6f93cf5f990e33b36 + repository: https://github.com/fluent/fluentd-kubernetes-daemonset.git + tag: v${{vars.mangled-package-version}} + +subpackages: + - range: plugins + name: ${{package.name}}-${{range.key}} + description: Fluentd kubernetes daemonset for ${{range.key}} + options: + no-depends: true + no-provides: true + dependencies: + runtime: + - ca-certificates + - ruby-${{vars.rubyMM}} + - tini + pipeline: + - working-directory: ./docker-image/v${{vars.fluentdMM}}/debian-${{range.key}} + runs: | + # Install bundle + mkdir -p ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config silence_root_warning true + bundle config set path ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config set clean 'true' + bundle config set deployment 'true' + bundle install --gemfile ./Gemfile --jobs $(nproc) + bundle config unset path + + # Copy gemfile + mkdir -p ${{targets.contextdir}}/fluentd + cp ./Gemfile ${{targets.contextdir}}/fluentd/Gemfile + + # Copy configuration + mkdir -p ${{targets.contextdir}}/fluentd/etc + cp -r ./conf/* ${{targets.contextdir}}/fluentd/etc + touch ${{targets.contextdir}}/fluentd/etc/disable.conf + + # Create log directory + mkdir -p ${{targets.contextdir}}/fluentd/log + + # Copy plugins + mkdir -p ${{targets.contextdir}}/fluentd/plugins + cp -r ./plugins/* ${{targets.contextdir}}/fluentd/plugins + + # Copy entrypoint + cp entrypoint.sh ${{targets.contextdir}}/fluentd/entrypoint.sh + test: + environment: + environment: + FLUENTD_CONF: "fluent.conf" + FLUENTD_DISABLE_BUNDLER_INJECTION: 1 + GEM_PATH: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + GEM_HOME: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + KUBERNETES_SERVICE_HOST: "127.0.0.1" + KUBERNETES_SERVICE_PORT: 32764 + pipeline: + - uses: test/kwok/cluster + # Just make sure the config is okay, kwok doesn't get us very far + - uses: test/daemon-check-output + with: + start: | + sh -c " + export GEM_PATH="/fluentd/vendor/bundle/ruby/$(basename $(gem env home))" + export GEM_HOME="$GEM_PATH" + /fluentd/vendor/bundle/ruby/$(basename $(gem env home))/bin/fluentd -c /fluentd/etc/${FLUENTD_CONF} -p /fluentd/plugins --gemfile /fluentd/Gemfile + " + timeout: 10 + expected_output: parsing config file is succeeded + +update: + enabled: true + version-transform: + - match: '_' + replace: '.' + github: + identifier: fluent/fluentd-kubernetes-daemonset + strip-prefix: v + tag-filter: v1.17. + use-tag: true diff --git a/ruby3.2-fluentd-kubernetes-daemonset-1.17.yaml b/ruby3.2-fluentd-kubernetes-daemonset-1.17.yaml new file mode 100644 index 00000000000..7ed35a2b531 --- /dev/null +++ b/ruby3.2-fluentd-kubernetes-daemonset-1.17.yaml @@ -0,0 +1,142 @@ +package: + # fluentd supported versions: https://github.com/fluent/fluentd/blob/master/SECURITY.md + # The kubernetes daemonset trails fluentd releases by a bit + name: ruby3.2-fluentd-kubernetes-daemonset-1.17 + version: 1.17.1.1.2 + epoch: 0 + description: Fluentd ${{vars.fluentdMM}} daemonset for Kubernetes + copyright: + - license: Apache-2.0 + +environment: + contents: + packages: + - autoconf + - automake + - bash + - build-base + - busybox + - ca-certificates-bundle + - libtool + - m4 + - ruby${{vars.rubyMM}}-bundler + - ruby-${{vars.rubyMM}}-dev + - snappy-dev + +var-transforms: + - from: ${{package.name}} + match: .*-(\d+\.\d+) + replace: $1 + to: fluentdMM + - from: ${{package.name}} + match: ^ruby(\d\.\d+)-.* + replace: $1 + to: rubyMM + - from: ${{package.version}} + match: ^(\d+\.\d+\.\d+)\.(\d+\.\d+) + replace: $1-$2 + to: mangled-package-version + +data: + - name: plugins + items: + azureblob: + cloudwatch: + elasticsearch7: + elasticsearch8: + forward: + gcs: + graylog: + kafka: + kafka2: + kinesis: + logentries: + loggly: + logzio: + opensearch: + papertrail: + s3: + syslog: + +pipeline: + - uses: git-checkout + with: + expected-commit: 6183f108748bc4ed980437d6f93cf5f990e33b36 + repository: https://github.com/fluent/fluentd-kubernetes-daemonset.git + tag: v${{vars.mangled-package-version}} + +subpackages: + - range: plugins + name: ${{package.name}}-${{range.key}} + description: Fluentd kubernetes daemonset for ${{range.key}} + options: + no-depends: true + no-provides: true + dependencies: + runtime: + - ca-certificates + - ruby-${{vars.rubyMM}} + - tini + pipeline: + - working-directory: ./docker-image/v${{vars.fluentdMM}}/debian-${{range.key}} + runs: | + # Install bundle + mkdir -p ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config silence_root_warning true + bundle config set path ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config set clean 'true' + bundle config set deployment 'true' + bundle install --gemfile ./Gemfile --jobs $(nproc) + bundle config unset path + + # Copy gemfile + mkdir -p ${{targets.contextdir}}/fluentd + cp ./Gemfile ${{targets.contextdir}}/fluentd/Gemfile + + # Copy configuration + mkdir -p ${{targets.contextdir}}/fluentd/etc + cp -r ./conf/* ${{targets.contextdir}}/fluentd/etc + touch ${{targets.contextdir}}/fluentd/etc/disable.conf + + # Create log directory + mkdir -p ${{targets.contextdir}}/fluentd/log + + # Copy plugins + mkdir -p ${{targets.contextdir}}/fluentd/plugins + cp -r ./plugins/* ${{targets.contextdir}}/fluentd/plugins + + # Copy entrypoint + cp entrypoint.sh ${{targets.contextdir}}/fluentd/entrypoint.sh + test: + environment: + environment: + FLUENTD_CONF: "fluent.conf" + FLUENTD_DISABLE_BUNDLER_INJECTION: 1 + GEM_PATH: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + GEM_HOME: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + KUBERNETES_SERVICE_HOST: "127.0.0.1" + KUBERNETES_SERVICE_PORT: 32764 + pipeline: + - uses: test/kwok/cluster + # Just make sure the config is okay, kwok doesn't get us very far + - uses: test/daemon-check-output + with: + start: | + sh -c " + export GEM_PATH="/fluentd/vendor/bundle/ruby/$(basename $(gem env home))" + export GEM_HOME="$GEM_PATH" + /fluentd/vendor/bundle/ruby/$(basename $(gem env home))/bin/fluentd -c /fluentd/etc/${FLUENTD_CONF} -p /fluentd/plugins --gemfile /fluentd/Gemfile + " + timeout: 10 + expected_output: parsing config file is succeeded + +update: + enabled: true + version-transform: + - match: '_' + replace: '.' + github: + identifier: fluent/fluentd-kubernetes-daemonset + strip-prefix: v + tag-filter: v1.17. + use-tag: true diff --git a/ruby3.3-fluentd-kubernetes-daemonset-1.17.yaml b/ruby3.3-fluentd-kubernetes-daemonset-1.17.yaml new file mode 100644 index 00000000000..2457d5fbfaf --- /dev/null +++ b/ruby3.3-fluentd-kubernetes-daemonset-1.17.yaml @@ -0,0 +1,142 @@ +package: + # fluentd supported versions: https://github.com/fluent/fluentd/blob/master/SECURITY.md + # The kubernetes daemonset trails fluentd releases by a bit + name: ruby3.3-fluentd-kubernetes-daemonset-1.17 + version: 1.17.1.1.2 + epoch: 0 + description: Fluentd ${{vars.fluentdMM}} daemonset for Kubernetes + copyright: + - license: Apache-2.0 + +environment: + contents: + packages: + - autoconf + - automake + - bash + - build-base + - busybox + - ca-certificates-bundle + - libtool + - m4 + - ruby${{vars.rubyMM}}-bundler + - ruby-${{vars.rubyMM}}-dev + - snappy-dev + +var-transforms: + - from: ${{package.name}} + match: .*-(\d+\.\d+) + replace: $1 + to: fluentdMM + - from: ${{package.name}} + match: ^ruby(\d\.\d+)-.* + replace: $1 + to: rubyMM + - from: ${{package.version}} + match: ^(\d+\.\d+\.\d+)\.(\d+\.\d+) + replace: $1-$2 + to: mangled-package-version + +data: + - name: plugins + items: + azureblob: + cloudwatch: + elasticsearch7: + elasticsearch8: + forward: + gcs: + graylog: + kafka: + kafka2: + kinesis: + logentries: + loggly: + logzio: + opensearch: + papertrail: + s3: + syslog: + +pipeline: + - uses: git-checkout + with: + expected-commit: 6183f108748bc4ed980437d6f93cf5f990e33b36 + repository: https://github.com/fluent/fluentd-kubernetes-daemonset.git + tag: v${{vars.mangled-package-version}} + +subpackages: + - range: plugins + name: ${{package.name}}-${{range.key}} + description: Fluentd kubernetes daemonset for ${{range.key}} + options: + no-depends: true + no-provides: true + dependencies: + runtime: + - ca-certificates + - ruby-${{vars.rubyMM}} + - tini + pipeline: + - working-directory: ./docker-image/v${{vars.fluentdMM}}/debian-${{range.key}} + runs: | + # Install bundle + mkdir -p ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config silence_root_warning true + bundle config set path ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config set clean 'true' + bundle config set deployment 'true' + bundle install --gemfile ./Gemfile --jobs $(nproc) + bundle config unset path + + # Copy gemfile + mkdir -p ${{targets.contextdir}}/fluentd + cp ./Gemfile ${{targets.contextdir}}/fluentd/Gemfile + + # Copy configuration + mkdir -p ${{targets.contextdir}}/fluentd/etc + cp -r ./conf/* ${{targets.contextdir}}/fluentd/etc + touch ${{targets.contextdir}}/fluentd/etc/disable.conf + + # Create log directory + mkdir -p ${{targets.contextdir}}/fluentd/log + + # Copy plugins + mkdir -p ${{targets.contextdir}}/fluentd/plugins + cp -r ./plugins/* ${{targets.contextdir}}/fluentd/plugins + + # Copy entrypoint + cp entrypoint.sh ${{targets.contextdir}}/fluentd/entrypoint.sh + test: + environment: + environment: + FLUENTD_CONF: "fluent.conf" + FLUENTD_DISABLE_BUNDLER_INJECTION: 1 + GEM_PATH: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + GEM_HOME: "/fluentd/vendor/bundle/ruby/${{vars.rubyMM}}.0" + KUBERNETES_SERVICE_HOST: "127.0.0.1" + KUBERNETES_SERVICE_PORT: 32764 + pipeline: + - uses: test/kwok/cluster + # Just make sure the config is okay, kwok doesn't get us very far + - uses: test/daemon-check-output + with: + start: | + sh -c " + export GEM_PATH="/fluentd/vendor/bundle/ruby/$(basename $(gem env home))" + export GEM_HOME="$GEM_PATH" + /fluentd/vendor/bundle/ruby/$(basename $(gem env home))/bin/fluentd -c /fluentd/etc/${FLUENTD_CONF} -p /fluentd/plugins --gemfile /fluentd/Gemfile + " + timeout: 10 + expected_output: parsing config file is succeeded + +update: + enabled: true + version-transform: + - match: '_' + replace: '.' + github: + identifier: fluent/fluentd-kubernetes-daemonset + strip-prefix: v + tag-filter: v1.17. + use-tag: true diff --git a/ruby3.4-fluentd-kubernetes-daemonset-1.17.yaml b/ruby3.4-fluentd-kubernetes-daemonset-1.17.yaml new file mode 100644 index 00000000000..89830c9d076 --- /dev/null +++ b/ruby3.4-fluentd-kubernetes-daemonset-1.17.yaml @@ -0,0 +1,140 @@ +package: + # fluentd supported versions: https://github.com/fluent/fluentd/blob/master/SECURITY.md + # The kubernetes daemonset trails fluentd releases by a bit + name: ruby3.4-fluentd-kubernetes-daemonset-1.17 + version: 1.17.1.1.2 + epoch: 0 + description: Fluentd ${{vars.fluentdMM}} daemonset for Kubernetes + copyright: + - license: Apache-2.0 + +environment: + contents: + packages: + - autoconf + - automake + - bash + - build-base + - busybox + - ca-certificates-bundle + - libtool + - m4 + - ruby${{vars.rubyMM}}-bundler + - ruby-${{vars.rubyMM}}-dev + - snappy-dev + +var-transforms: + - from: ${{package.name}} + match: .*-(\d+\.\d+) + replace: $1 + to: fluentdMM + - from: ${{package.name}} + match: ^ruby(\d\.\d+)-.* + replace: $1 + to: rubyMM + - from: ${{package.version}} + match: ^(\d+\.\d+\.\d+)\.(\d+\.\d+) + replace: $1-$2 + to: mangled-package-version + +data: + - name: plugins + items: + azureblob: + cloudwatch: + elasticsearch7: + elasticsearch8: + forward: + gcs: + graylog: + kafka: + kafka2: + kinesis: + logentries: + loggly: + logzio: + opensearch: + papertrail: + s3: + syslog: + +pipeline: + - uses: git-checkout + with: + expected-commit: 6183f108748bc4ed980437d6f93cf5f990e33b36 + repository: https://github.com/fluent/fluentd-kubernetes-daemonset.git + tag: v${{vars.mangled-package-version}} + +subpackages: + - range: plugins + name: ${{package.name}}-${{range.key}} + description: Fluentd kubernetes daemonset for ${{range.key}} + options: + no-depends: true + no-provides: true + dependencies: + runtime: + - ca-certificates + - ruby-${{vars.rubyMM}} + - tini + pipeline: + - working-directory: ./docker-image/v${{vars.fluentdMM}}/debian-${{range.key}} + runs: | + # Install bundle + mkdir -p ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config silence_root_warning true + bundle config set path ${{targets.contextdir}}/fluentd/vendor/bundle + bundle config set clean 'true' + bundle config set deployment 'true' + bundle install --gemfile ./Gemfile --jobs $(nproc) + bundle config unset path + + # Copy gemfile + mkdir -p ${{targets.contextdir}}/fluentd + cp ./Gemfile ${{targets.contextdir}}/fluentd/Gemfile + + # Copy configuration + mkdir -p ${{targets.contextdir}}/fluentd/etc + cp -r ./conf/* ${{targets.contextdir}}/fluentd/etc + touch ${{targets.contextdir}}/fluentd/etc/disable.conf + + # Create log directory + mkdir -p ${{targets.contextdir}}/fluentd/log + + # Copy plugins + mkdir -p ${{targets.contextdir}}/fluentd/plugins + cp -r ./plugins/* ${{targets.contextdir}}/fluentd/plugins + + # Copy entrypoint + cp entrypoint.sh ${{targets.contextdir}}/fluentd/entrypoint.sh + test: + environment: + environment: + FLUENTD_CONF: "fluent.conf" + FLUENTD_DISABLE_BUNDLER_INJECTION: 1 + KUBERNETES_SERVICE_HOST: "127.0.0.1" + KUBERNETES_SERVICE_PORT: 32764 + pipeline: + - uses: test/kwok/cluster + # Just make sure the config is okay, kwok doesn't get us very far + - uses: test/daemon-check-output + with: + start: | + sh -c " + export GEM_PATH="/fluentd/vendor/bundle/ruby/$(basename $(gem env home))" + export GEM_HOME="$GEM_PATH" + /fluentd/vendor/bundle/ruby/$(basename $(gem env home))/bin/fluentd -c /fluentd/etc/${FLUENTD_CONF} -p /fluentd/plugins --gemfile /fluentd/Gemfile + " + timeout: 10 + expected_output: parsing config file is succeeded + +update: + enabled: true + version-transform: + - match: '_' + replace: '.' + github: + identifier: fluent/fluentd-kubernetes-daemonset + strip-prefix: v + tag-filter: v1.17. + use-tag: true