Skip to content

Commit

Permalink
use distroless for base image (#605)
Browse files Browse the repository at this point in the history
* 🐳 ♻️ use distroless for agent-ngt image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for agent-sidecar image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for discoverer-k8s image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for gateway-vald image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for meta-redis image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for meta-cassandra image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for manager-backup-mysql image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for manager-backup-cassandra image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for manager-compressor image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for manager-index image

Signed-off-by: Rintaro Okamura <[email protected]>

* ♻️ add UPX_OPTIONS

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless for manager-replication-* image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 ♻️ use distroless/static:nonroot image

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 💚 add daily trivy scan

Signed-off-by: Rintaro Okamura <[email protected]>

* 🐳 💚 add release-time trivy scan

Signed-off-by: Rintaro Okamura <[email protected]>

* 💚 build binaries and publish them to release page

Signed-off-by: Rintaro Okamura <[email protected]>

* 🔧 show version ad 'pr-xxx' when pr builds

Signed-off-by: Rintaro Okamura <[email protected]>

* Revert "🔧 show version ad 'pr-xxx' when pr builds"

This reverts commit 4cd9f3b.

* 🔧 show version as 'pr-xxx' when PR builds

Signed-off-by: Rintaro Okamura <[email protected]>

* 🔧 fix info.BuildTime

Signed-off-by: Rintaro Okamura <[email protected]>

* 🔧 update go.mod.default

Signed-off-by: Rintaro Okamura <[email protected]>
  • Loading branch information
rinx authored Aug 11, 2020
1 parent 4a499fb commit 57d657e
Show file tree
Hide file tree
Showing 35 changed files with 1,660 additions and 528 deletions.
74 changes: 74 additions & 0 deletions .github/workflows/build-binaries.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
name: 'Upload artifacts to release'
on:
release:
types:
- created

jobs:
build-linux:
runs-on: ubuntu-latest
container:
image: vdaas/vald-ci-container:nightly
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 10
- name: Fetch golang version
run: |
GO_VERSION=`make version/go`
echo "::set-output name=version::${GO_VERSION}"
id: golang_version
- uses: actions/setup-go@v1
with:
go-version: ${{ steps.golang_version.outputs.version }}
- name: Build and zip
run: |
make binary/build/zip
- name: Upload artifact
uses: actions/upload-artifact@v2
with:
name: artifacts-linux
path: ./artifacts/
# build-macos: ## or using cross-compiler?
# runs-on: macos-latest
# steps:
# - uses: actions/checkout@v2
# with:
# fetch-depth: 10
# - name: Fetch golang version
# run: |
# GO_VERSION=`make version/go`
# echo "::set-output name=version::${GO_VERSION}"
# id: golang_version
# - uses: actions/setup-go@v1
# with:
# go-version: ${{ steps.golang_version.outputs.version }}
# - name: Build and zip
# run: |
# export PATH=$PATH:$(go env GOPATH)/bin
# brew install llvm libomp protobuf ngt
# make CXXFLAGS="-I/usr/local/opt/llvm/include -mno-avx512f -mno-avx512dq -mno-avx512cd -mno-avx512bw -mno-avx512vl" binary/build/zip
# - name: Upload artifact
# uses: actions/upload-artifact@v2
# with:
# name: artifacts-macos
# path: ./artifacts
publish:
runs-on: ubuntu-latest
needs:
- build-linux
# - build-macos
# - build-windows
steps:
- uses: actions/download-artifact@v2
with:
name: artifacts-linux
path: tmp/linux
# - uses: actions/download-artifact@v2
# with:
# name: artifacts-macos
# path: tmp/macos
- uses: shogo82148/actions-upload-release-asset@v1
with:
upload_url: ${{ github.event.release.upload_url }}
asset_path: tmp/linux/vald-*.zip
2 changes: 1 addition & 1 deletion .github/workflows/codeql-analysis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ on:
- '.github/workflows/codeql-analysis.yml'
- '**.go'
schedule:
- cron: '0 1 * * 2'
- cron: '0 1 * * *'

jobs:
CodeQL-Build:
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-agent-ngt-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/agent-ngt
Expand All @@ -65,6 +70,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/agent-ngt`
docker push ${imagename}:latest
Expand All @@ -73,6 +79,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-agent-sidecar-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/agent-sidecar
Expand All @@ -65,6 +70,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/agent-sidecar`
docker push ${imagename}:latest
Expand All @@ -73,6 +79,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-backup-manager-cassandra-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/backup-manager-cassandra
Expand All @@ -67,6 +72,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/backup-manager-cassandra`
docker push ${imagename}:latest
Expand All @@ -75,6 +81,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-backup-manager-mysql-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/backup-manager-mysql
Expand All @@ -65,6 +70,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/backup-manager-mysql`
docker push ${imagename}:latest
Expand All @@ -73,6 +79,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-discoverer-k8s-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/discoverer-k8s
Expand All @@ -61,6 +66,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/discoverer-k8s`
docker push ${imagename}:latest
Expand All @@ -69,6 +75,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
30 changes: 30 additions & 0 deletions .github/workflows/dockers-gateway-vald-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,11 @@ jobs:
- uses: actions/checkout@v1
with:
fetch-depth: 10
- name: Overwrite version name
if: github.event_name == 'pull_request'
run: |
pr_num=`cat $GITHUB_EVENT_PATH | jq -r ".number"`
echo "PR-${pr_num}" > versions/VALD_VERSION
- name: Build the Docker image
run: |
make docker/build/gateway-vald
Expand All @@ -63,6 +68,7 @@ jobs:
docker push ${imagename}:pr-${pr_num}
- name: push to DockerHub (tags)
if: startsWith( github.ref, 'refs/tags/')
id: push_to_dockerhub_tags
run: |
imagename=`make docker/name/gateway-vald`
docker push ${imagename}:latest
Expand All @@ -71,6 +77,30 @@ jobs:
docker push ${imagename}:${tag_name}
docker tag ${imagename} ${imagename}:nightly
docker push ${imagename}:nightly
echo "::set-output name=IMAGE_NAME::${imagename}"
echo "::set-output name=TAG_NAME::${tag_name}"
- name: Initialize CodeQL
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/init@v1
- name: Run vulnerability scanner (table)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'table'
- name: Run vulnerability scanner (sarif)
if: startsWith( github.ref, 'refs/tags/')
uses: aquasecurity/trivy-action@master
with:
image-ref: "${{ steps.push_to_dockerhub_tags.outputs.IMAGE_NAME }}:${{ steps.push_to_dockerhub_tags.outputs.TAG_NAME }}"
format: 'template'
template: '@/contrib/sarif.tpl'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to Security tab
if: startsWith( github.ref, 'refs/tags/')
uses: github/codeql-action/upload-sarif@v1
with:
sarif_file: 'trivy-results.sarif'
slack:
name: Slack notification
needs: build
Expand Down
Loading

0 comments on commit 57d657e

Please sign in to comment.