drone-kaniko/README.md

128 lines
6.6 KiB
Markdown

<p align="center">
<a href="https://odit.services" target="blank"><img src="https://odit.services/img/profile-pic-no_bg.webp" width="200" alt="ODIT Logo" /></a>
</p>
<h1 align="center">Drone Kaniko</h1>
![](https://img.shields.io/badge/renovate-enabled-brightgreen?style=for-the-badge&logo=) ![Drone (self-hosted) with branch](https://img.shields.io/drone/build/odit/drone-kaniko/main?server=https%3A%2F%2Fci.odit.services&style=for-the-badge&logo=drone)
A thin shim-wrapper around the official [Google Kaniko](https://cloud.google.com/blog/products/gcp/introducing-kaniko-build-container-images-in-kubernetes-and-google-container-builder-even-without-root-access) Docker image to make it behave like the [Drone Docker plugin](http://plugins.drone.io/drone-plugins/drone-docker/).
Based on the original [drone-kaniko](https://github.com/banzaicloud/drone-kaniko) by [Banzai Cloud](https://github.com/banzaicloud)
Modified by [ODIT.Services](https://odit.services) to enable local builds to tar.
## Settings 🛠️
* `registry`: Your registry (defaults to docker hub)
* `repo`: The image repository
* `tags`: The image tags (as a simple string or an array)
* `username`: Username for the chosen docker registry
* `password`: Password for the chosen docker registry
* `nopush`: Disable Pushing to registry (boolean)
* `tarpath`: Export the image to tar (relative path)
* `cache`: Use cached intermediate containers (boolean)
* `newrun`: Use the experimental run implementation for detecting changes without requiring file system snapshots. (boolean)
* `snapshot_mode`: Set how kaniko will snapshot the filesystem (full,redo,time).
* `skip_tls_verify`: Skip SSL/TLS certificate verification (boolean)
* `build_args`: Pass custom arguments to docker build
* `build_args_from_env`: Pass the envvars as custom arguments to docker build
* `json_key`: Provide registry auth data via json_key (mostly for gcr)
* `auto_tag`: generate tag names automatically based on git branch and git tag
## Examples
```yaml
kind: pipeline
name: default
steps:
- name: publish
image: registry.odit.services/library/drone-kaniko
settings:
registry: registry.example.com # if not provided index.docker.io is supposed
repo: registry.example.com/example-project
tags: ${DRONE_COMMIT_SHA}
cache: true
skip_tls_verify: false # set to true for testing registries ONLY with self-signed certs
build_args:
- COMMIT_SHA=${DRONE_COMMIT_SHA}
- COMMIT_AUTHOR_EMAIL=${DRONE_COMMIT_AUTHOR_EMAIL}
username:
from_secret: docker-username
password:
from_secret: docker-password
```
Pushing to GCR:
```yaml
kind: pipeline
name: default
steps:
- name: publish
image: registry.odit.services/library/drone-kaniko
settings:
registry: gcr.io
repo: example.com/example-project
tags: ${DRONE_COMMIT_SHA}
cache: true
json_key:
from_secret: google-application-credentials
```
## Use `.tags` file for tagging
Similarily to official
[drone-docker](https://github.com/drone-plugins/drone-docker) plugin you can use
`.tags` file to embed some custom logic for creating tags for an image.
```yaml
kind: pipeline
name: default
steps:
- name: build
image: golang
commands:
- go get
- go build
- make versiontags > .tags
- name: publish
image: registry.odit.services/library/drone-kaniko
settings:
registry: registry.example.com
repo: registry.example.com/example-project
# tags: ${DRONE_COMMIT_SHA} <= it must be left undefined
username:
from_secret: docker-username
password:
from_secret: docker-password
```
## Auto tag
Set `auto_tag: true`.
```yaml
kind: pipeline
name: default
steps:
- name: build
image: golang
commands:
- go get
- go build
- name: publish
image: registry.odit.services/library/drone-kaniko
settings:
registry: registry.example.com
repo: registry.example.com/example-project
auto_tag: true # higher priority then .tags file
# tags: ${DRONE_COMMIT_SHA} <= it must be left undefined to use auto_tag
username:
from_secret: docker-username
password:
from_secret: docker-password
```