Documentation ¶
Index ¶
- Constants
- func NewSkaffoldPipeline() util.VersionedConfig
- type Activation
- type Artifact
- type ArtifactType
- type BazelArtifact
- type BuildConfig
- type BuildType
- type BuilderPlugin
- type DateTimeTagger
- type DeployConfig
- type DeployType
- type DockerArtifact
- type DockerConfig
- type EnvTemplateTagger
- type ExecEnvironment
- type ExecutionEnvironment
- type GitTagger
- type GoogleCloudBuild
- type HelmConventionConfig
- type HelmDeploy
- type HelmFQNConfig
- type HelmImageConfig
- type HelmImageStrategy
- type HelmPackaged
- type HelmRelease
- type JibGradleArtifact
- type JibMavenArtifact
- type KanikoBuild
- type KanikoBuildContext
- type KanikoCache
- type KubectlDeploy
- type KubectlFlags
- type KustomizeDeploy
- type LocalBuild
- type LocalDir
- type Profile
- type ShaTagger
- type SkaffoldPipeline
- type TagPolicy
- type TestCase
- type TestConfig
Constants ¶
const Version string = "skaffold/v1beta5"
Variables ¶
This section is empty.
Functions ¶
func NewSkaffoldPipeline ¶
func NewSkaffoldPipeline() util.VersionedConfig
NewSkaffoldPipeline creates a SkaffoldPipeline
Types ¶
type Activation ¶ added in v0.23.0
type Activation struct { // Env holds a key=value pair. The profile is auto-activated if an Environment // Variable `key` has value `value`. // For example: `ENV=production`. Env string `yaml:"env,omitempty"` // KubeContext is a Kubernetes context for which a profile is auto-activated. // For example: `minikube`. KubeContext string `yaml:"kubeContext,omitempty"` // Command is a Skaffold command for which a profile is auto-activated. // For example: `dev`. Command string `yaml:"command,omitempty"` }
Activation criteria by which a profile is auto-activated.
type Artifact ¶
type Artifact struct { // ImageName is the name of the image to be built. ImageName string `yaml:"image,omitempty" yamltags:"required"` // Workspace is the directory where the artifact's sources are to be found. // Defaults to `.`. Workspace string `yaml:"context,omitempty"` // Sync lists local files that can be synced to remote pods (alpha) instead // of triggering an image build when modified. // This is a mapping of local files to sync to remote folders. // For example: `{'*.py': .}`. Sync map[string]string `yaml:"sync,omitempty"` ArtifactType `yaml:",inline"` // The plugin used to build this artifact BuilderPlugin *BuilderPlugin `yaml:"plugin,omitempty"` }
Artifact are the items that need to be built, along with the context in which they should be built.
type ArtifactType ¶
type ArtifactType struct { // DockerArtifact describes an artifact built from a Dockerfile, // usually using `docker build`. DockerArtifact *DockerArtifact `yaml:"docker,omitempty" yamltags:"oneOf=artifact"` // BazelArtifact requires bazel CLI to be installed and the artifacts sources to // contain [Bazel](https://bazel.build/) configuration files. BazelArtifact *BazelArtifact `yaml:"bazel,omitempty" yamltags:"oneOf=artifact"` // JibMavenArtifact builds images using the // [Jib plugin for Maven](https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin). JibMavenArtifact *JibMavenArtifact `yaml:"jibMaven,omitempty" yamltags:"oneOf=artifact"` // JibGradleArtifact builds images using the // [Jib plugin for Gradle](https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin). JibGradleArtifact *JibGradleArtifact `yaml:"jibGradle,omitempty" yamltags:"oneOf=artifact"` }
type BazelArtifact ¶
type BazelArtifact struct { // BuildTarget is the `bazel build` target to run. // For example: `//:skaffold_example.tar`. BuildTarget string `yaml:"target,omitempty" yamltags:"required"` // BuildArgs are additional args to pass to `bazel build`. // For example: `["arg1", "arg2"]`. BuildArgs []string `yaml:"args,omitempty"` }
BazelArtifact describes an artifact built with [Bazel](https://bazel.build/).
type BuildConfig ¶
type BuildConfig struct { // Artifacts lists the images you're going to be building. Artifacts []*Artifact `yaml:"artifacts,omitempty"` // TagPolicy (beta) determines how images are tagged. // A few strategies are provided here, although you most likely won't need to care! // The policy can be `gitCommit` (beta), `sha256` (beta), `envTemplate` (beta) or `dateTime` (beta). // If not specified, it defaults to `gitCommit: {}`. TagPolicy TagPolicy `yaml:"tagPolicy,omitempty"` ExecutionEnvironment *ExecutionEnvironment `yaml:"executionEnvironment,omitempty"` BuildType `yaml:",inline"` }
BuildConfig contains all the configuration for the build steps.
type BuildType ¶
type BuildType struct { // LocalBuild describes how to do a build on the local docker daemon // and optionally push to a repository. LocalBuild *LocalBuild `yaml:"local,omitempty" yamltags:"oneOf=build"` // GoogleCloudBuild describes how to do a remote build on // [Google Cloud Build](https://cloud.google.com/cloud-build/). GoogleCloudBuild *GoogleCloudBuild `yaml:"googleCloudBuild,omitempty" yamltags:"oneOf=build"` // KanikoBuild describes how to do an on-cluster build using // [Kaniko](https://github.com/GoogleContainerTools/kaniko). KanikoBuild *KanikoBuild `yaml:"kaniko,omitempty" yamltags:"oneOf=build"` }
BuildType contains the specific implementation and parameters needed for the build step. Only one field should be populated.
type BuilderPlugin ¶ added in v0.23.0
type BuilderPlugin struct { // Name of the build plugin Name string `yaml:"name,omitempty"` // Properties associated with the plugin Properties map[string]interface{} `yaml:"properties,omitempty"` Contents []byte `yaml:",omitempty"` }
BuilderPlugin contains all fields necessary for specifying a build plugin
type DateTimeTagger ¶
type DateTimeTagger struct { // Format formats the date and time. // See [#Time.Format](https://golang.org/pkg/time/#Time.Format). // Defaults to `2006-01-02_15-04-05.999_MST`. Format string `yaml:"format,omitempty"` // TimeZone sets the timezone for the date and time. // See [Time.LoadLocation](https://golang.org/pkg/time/#Time.LoadLocation). // Defaults to the local timezone. TimeZone string `yaml:"timezone,omitempty"` }
DateTimeTagger tags images with the build timestamp.
type DeployConfig ¶
type DeployConfig struct {
DeployType `yaml:",inline"`
}
DeployConfig contains all the configuration needed by the deploy steps.
type DeployType ¶
type DeployType struct { HelmDeploy *HelmDeploy `yaml:"helm,omitempty" yamltags:"oneOf=deploy"` // KubectlDeploy uses a client side `kubectl apply` to apply the manifests to the cluster. // You'll need a kubectl CLI version installed that's compatible with your cluster. KubectlDeploy *KubectlDeploy `yaml:"kubectl,omitempty" yamltags:"oneOf=deploy"` // KustomizeDeploy uses the `kustomize` CLI to "patch" a deployment for a target environment. KustomizeDeploy *KustomizeDeploy `yaml:"kustomize,omitempty" yamltags:"oneOf=deploy"` }
DeployType contains the specific implementation and parameters needed for the deploy step. Only one field should be populated.
type DockerArtifact ¶
type DockerArtifact struct { // DockerfilePath locates the Dockerfile relative to workspace. // Defaults to `Dockerfile`. DockerfilePath string `yaml:"dockerfile,omitempty"` // BuildArgs are arguments passed to the docker build. // For example: `{key1: "value1", key2: "value2"}`. BuildArgs map[string]*string `yaml:"buildArgs,omitempty"` // CacheFrom lists the Docker images to consider as cache sources. // For example: `["golang:1.10.1-alpine3.7", "alpine:3.7"]`. CacheFrom []string `yaml:"cacheFrom,omitempty"` // Target is the Dockerfile target name to build. Target string `yaml:"target,omitempty"` }
DockerArtifact describes an artifact built from a Dockerfile, usually using `docker build`.
type DockerConfig ¶ added in v0.21.0
type DockerConfig struct { // Path is the path to the docker `config.json`. Path string `yaml:"path,omitempty"` // SecretName is the Kubernetes secret that will hold the Docker configuration. SecretName string `yaml:"secretName,omitempty"` }
DockerConfig contains information about the docker `config.json` to mount.
type EnvTemplateTagger ¶
type EnvTemplateTagger struct { // Template used to produce the image name and tag. // See golang [text/template](https://golang.org/pkg/text/template/) syntax. // The template is compiled and executed against the current environment, // with those variables injected: // IMAGE_NAME | Name of the image being built, as supplied in the artifacts section. // For example: `{{.RELEASE}}-{{.IMAGE_NAME}}`. Template string `yaml:"template,omitempty" yamltags:"required"` }
EnvTemplateTagger tags images with a configurable template string.
type ExecEnvironment ¶ added in v0.23.0
type ExecEnvironment string
type ExecutionEnvironment ¶ added in v0.23.0
type ExecutionEnvironment struct { Name ExecEnvironment `yaml:"name,omitempty"` Properties map[string]interface{} `yaml:"properties,omitempty"` }
ExecutionEnvironment is the environment in which the build should run (ex. local or in-cluster, etc.)
type GoogleCloudBuild ¶
type GoogleCloudBuild struct { // ProjectID is the ID of your Cloud Platform Project. // If it is not provided, Skaffold will guess it from the image name. // For example, given the artifact image name `gcr.io/myproject/image`, Skaffold // will use the `myproject` GCP project. ProjectID string `yaml:"projectId,omitempty"` // DiskSizeGb is the disk size of the VM that runs the build. // See [Cloud Build Reference](https://cloud.google.com/cloud-build/docs/api/reference/rest/v1/projects.builds#buildoptions). DiskSizeGb int64 `yaml:"diskSizeGb,omitempty"` // MachineType is the type of the VM that runs the build. // See [Cloud Build Reference](https://cloud.google.com/cloud-build/docs/api/reference/rest/v1/projects.builds#buildoptions). MachineType string `yaml:"machineType,omitempty"` // Timeout is the amount of time (in seconds) that this build should be allowed to run. // See [Cloud Build Reference](https://cloud.google.com/cloud-build/docs/api/reference/rest/v1/projects.builds#resource-build). Timeout string `yaml:"timeout,omitempty"` // DockerImage is the image that runs a Docker build. // See [Cloud Builders](https://cloud.google.com/cloud-build/docs/cloud-builders). // Defaults to `gcr.io/cloud-builders/docker`. DockerImage string `yaml:"dockerImage,omitempty"` // MavenImage is the image that runs a Maven build. // See [Cloud Builders](https://cloud.google.com/cloud-build/docs/cloud-builders). // Defaults to `gcr.io/cloud-builders/mvn`. MavenImage string `yaml:"mavenImage,omitempty"` // GradleImage is the image that runs a Gradle build. // See [Cloud Builders](https://cloud.google.com/cloud-build/docs/cloud-builders). // Defaults to `gcr.io/cloud-builders/gradle`. GradleImage string `yaml:"gradleImage,omitempty"` }
GoogleCloudBuild describes how to do a remote build on [Google Cloud Build](https://cloud.google.com/cloud-build/docs/). Docker and Jib artifacts can be built on Cloud Build. The `projectId` needs to be provided and the currently logged in user should be given permissions to trigger new builds.
type HelmConventionConfig ¶
type HelmConventionConfig struct { }
HelmConventionConfig is the image config in the syntax of image.repository and image.tag.
type HelmDeploy ¶
type HelmDeploy struct { // Releases is a list of Helm releases. Releases []HelmRelease `yaml:"releases,omitempty" yamltags:"required"` }
HelmDeploy contains the configuration needed for deploying with `helm`.
type HelmFQNConfig ¶
type HelmFQNConfig struct {
Property string `yaml:"property,omitempty"`
}
HelmFQNConfig is the image config to use the FullyQualifiedImageName as param to set.
type HelmImageConfig ¶
type HelmImageConfig struct { // HelmFQNConfig is the image configuration uses the syntax `IMAGE-NAME=IMAGE-REPOSITORY:IMAGE-TAG`. HelmFQNConfig *HelmFQNConfig `yaml:"fqn,omitempty"` // HelmConventionConfig is the image configuration uses the syntax `IMAGE-NAME.repository=IMAGE-REPOSITORY, IMAGE-NAME.tag=IMAGE-TAG`. HelmConventionConfig *HelmConventionConfig `yaml:"helm,omitempty"` }
type HelmImageStrategy ¶
type HelmImageStrategy struct {
HelmImageConfig `yaml:",inline"`
}
HelmImageStrategy adds image configurations to the Helm `values` file.
type HelmPackaged ¶
type HelmPackaged struct { // Version sets the `version` on the chart to this semver version. Version string `yaml:"version,omitempty"` // AppVersion sets the `appVersion` on the chart to this version. AppVersion string `yaml:"appVersion,omitempty"` }
HelmPackaged parameters for packaging helm chart (`helm package`).
type HelmRelease ¶
type HelmRelease struct { // Name is the name of the Helm release. Name string `yaml:"name,omitempty" yamltags:"required"` // ChartPath is the path to the Helm chart. ChartPath string `yaml:"chartPath,omitempty" yamltags:"required"` // ValuesFiles are the paths to the Helm `values` files". ValuesFiles []string `yaml:"valuesFiles,omitempty"` // Values are key-value pairs supplementing the Helm `values` file". Values map[string]string `yaml:"values,omitempty,omitempty"` // Namespace is the Kubernetes namespace. Namespace string `yaml:"namespace,omitempty"` // Version is the version of the chart. Version string `yaml:"version,omitempty"` // SetValues are key-value pairs. // If present, Skaffold will send `--set` flag to Helm CLI and append all pairs after the flag. SetValues map[string]string `yaml:"setValues,omitempty"` // SetValueTemplates are key-value pairs. // If present, Skaffold will try to parse the value part of each key-value pair using // environment variables in the system, then send `--set` flag to Helm CLI and append // all parsed pairs after the flag. SetValueTemplates map[string]string `yaml:"setValueTemplates,omitempty"` // Wait if `true`, Skaffold will send `--wait` flag to Helm CLI. // Defaults to `false`. Wait bool `yaml:"wait,omitempty"` // RecreatePods if `true`, Skaffold will send `--recreate-pods` flag to Helm CLI. // Defaults to `false`. RecreatePods bool `yaml:"recreatePods,omitempty"` SkipBuildDependencies bool `yaml:"skipBuildDependencies,omitempty"` // Overrides are key-value pairs. // If present, Skaffold will build a Helm `values` file that overrides // the original and use it to call Helm CLI (`--f` flag). Overrides map[string]interface{} `yaml:"overrides,omitempty"` // Packaged parameters for packaging helm chart (`helm package`). Packaged *HelmPackaged `yaml:"packaged,omitempty"` // ImageStrategy adds image configurations to the Helm `values` file. ImageStrategy HelmImageStrategy `yaml:"imageStrategy,omitempty"` }
type JibGradleArtifact ¶
type JibGradleArtifact struct { // Project selects which Gradle project to build. Project string `yaml:"project"` // Flags are additional build flags passed to Gradle. Flags []string `yaml:"args,omitempty"` }
JibGradleArtifact builds images using the [Jib plugin for Gradle](https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin).
type JibMavenArtifact ¶
type JibMavenArtifact struct { // Module selects which Maven module to build, for a multi module project. Module string `yaml:"module"` // Profile selects which Maven profile to activate. Profile string `yaml:"profile"` // Flags are additional build flags passed to Maven. Flags []string `yaml:"args,omitempty"` }
JibMavenArtifact builds images using the [Jib plugin for Maven](https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin).
type KanikoBuild ¶
type KanikoBuild struct { // BuildContext defines where Kaniko gets the sources from. BuildContext *KanikoBuildContext `yaml:"buildContext,omitempty"` // Cache configures Kaniko caching. If a cache is specified, Kaniko will // use a remote cache which will speed up builds. Cache *KanikoCache `yaml:"cache,omitempty"` // AdditionalFlags are additional flags to be passed to Kaniko command line. // See [Kaniko Additional Flags](https://github.com/GoogleContainerTools/kaniko#additional-flags). AdditionalFlags []string `yaml:"flags,omitempty"` // PullSecret is the path to the secret key file. // See [Kaniko Documentation](https://github.com/GoogleContainerTools/kaniko#running-kaniko-in-a-kubernetes-cluster). PullSecret string `yaml:"pullSecret,omitempty"` // PullSecretName is the name of the Kubernetes secret for pulling the files // from the build context and pushing the final image. // Defaults to `kaniko-secret`. PullSecretName string `yaml:"pullSecretName,omitempty"` // Namespace is the Kubernetes namespace. // Defaults to current namespace in Kubernetes configuration. Namespace string `yaml:"namespace,omitempty"` // Timeout is the amount of time (in seconds) that this build is allowed to run. // Defaults to 20 minutes (`20m`). Timeout string `yaml:"timeout,omitempty"` // Image is the Docker image used by the Kaniko pod. // Defaults to the latest released version of `gcr.io/kaniko-project/executor`. Image string `yaml:"image,omitempty"` // DockerConfig describes how to mount the local Docker configuration into the // Kaniko pod. DockerConfig *DockerConfig `yaml:"dockerConfig,omitempty"` }
KanikoBuild describes how to do an on-cluster build using [Kaniko](https://github.com/GoogleContainerTools/kaniko).
type KanikoBuildContext ¶
type KanikoBuildContext struct { // GCSBucket is the CGS bucket to which sources are uploaded by Skaffold. // Kaniko will need access to that bucket to download the sources. GCSBucket string `yaml:"gcsBucket,omitempty" yamltags:"oneOf=buildContext"` // LocalDir configures how Kaniko mounts sources directly via an `emptyDir` volume. LocalDir *LocalDir `yaml:"localDir,omitempty" yamltags:"oneOf=buildContext"` }
KanikoBuildContext contains the different fields available to specify a Kaniko build context.
type KanikoCache ¶ added in v0.19.0
type KanikoCache struct { // Repo is a remote repository to store cached layers. If none is specified, one will be // inferred from the image name. See [Kaniko Caching](https://github.com/GoogleContainerTools/kaniko#caching). Repo string `yaml:"repo,omitempty"` }
KanikoCache configures Kaniko caching. If a cache is specified, Kaniko will use a remote cache which will speed up builds.
type KubectlDeploy ¶
type KubectlDeploy struct { // Manifests lists the Kubernetes yaml or json manifests. // Defaults to `["k8s/*.yaml"]`. Manifests []string `yaml:"manifests,omitempty"` // RemoteManifests lists Kubernetes manifests in remote clusters. RemoteManifests []string `yaml:"remoteManifests,omitempty"` // Flags are additional flags to pass to `kubectl`. Flags KubectlFlags `yaml:"flags,omitempty"` }
KubectlDeploy contains the configuration needed for deploying with `kubectl apply`.
type KubectlFlags ¶
type KubectlFlags struct { // Global are additional flags passed on every command. Global []string `yaml:"global,omitempty"` // Apply are additional flags passed on creations (`kubectl apply`). Apply []string `yaml:"apply,omitempty"` // Delete are additional flags passed on deletions (`kubectl delete`). Delete []string `yaml:"delete,omitempty"` }
KubectlFlags are additional flags passed on the command line to kubectl either on every command (Global), on creations (Apply) or deletions (Delete).
type KustomizeDeploy ¶
type KustomizeDeploy struct { // KustomizePath is the path to Kustomization files. // Defaults to `.`. KustomizePath string `yaml:"path,omitempty"` // Flags are additional flags to pass to `kubectl`. Flags KubectlFlags `yaml:"flags,omitempty"` }
KustomizeDeploy contains the configuration needed for deploying with `kustomize`.
type LocalBuild ¶
type LocalBuild struct { // Push should images be pushed to a registry. // If not specified, images are pushed only if the current Kubernetes context // connects to a remote cluster. Push *bool `yaml:"push,omitempty"` // UseDockerCLI use `docker` command-line interface instead of Docker Engine APIs. UseDockerCLI bool `yaml:"useDockerCLI,omitempty"` // UseBuildkit use BuildKit to build Docker images. UseBuildkit bool `yaml:"useBuildkit,omitempty"` }
LocalBuild describes how to do a build on the local docker daemon and optionally push to a repository.
type LocalDir ¶
type LocalDir struct{}
LocalDir configures how Kaniko mounts sources directly via an `emptyDir` volume.
type Profile ¶
type Profile struct { // Name is a unique profile name. Name string `yaml:"name,omitempty" yamltags:"required"` // Build replaces the main `build` configuration. Build BuildConfig `yaml:"build,omitempty"` // Test replaces the main `test` configuration. Test TestConfig `yaml:"test,omitempty"` // Deploy replaces the main `deploy` configuration. Deploy DeployConfig `yaml:"deploy,omitempty"` // Patches is a list of patches that will modify the default configuration. // This is used to not replace a whole configuration section but change a few values. // Each patch uses the JSON patch notation. // For example, this profile will replace the `dockerfile` value of the first artifact by `Dockerfile.DEV`. // For example: `[{path: /build/artifacts/0/docker/dockerfile, value: Dockerfile.DEV}]`. Patches yamlpatch.Patch `yaml:"patches,omitempty"` // Activation criteria by which a profile can be auto-activated. // This can be based on Environment Variables, the current Kubernetes // context name, or depending on which Skaffold command is running. Activation []Activation `yaml:"activation,omitempty"` }
Profile (beta) profiles are used to override any `build`, `test` or `deploy` configuration.
type SkaffoldPipeline ¶
type SkaffoldPipeline struct { APIVersion string `yaml:"apiVersion"` Kind string `yaml:"kind"` // Build describes how images are built. Build BuildConfig `yaml:"build,omitempty"` // Test describes how images are tested. Test TestConfig `yaml:"test,omitempty"` // Deploy describes how images are deployed. Deploy DeployConfig `yaml:"deploy,omitempty"` // Profiles (beta) can override be used to `build`, `test` or `deploy` configuration. Profiles []Profile `yaml:"profiles,omitempty"` }
func (*SkaffoldPipeline) GetVersion ¶
func (c *SkaffoldPipeline) GetVersion() string
func (*SkaffoldPipeline) Upgrade ¶
func (config *SkaffoldPipeline) Upgrade() (util.VersionedConfig, error)
Upgrade upgrades a configuration to the next version.
type TagPolicy ¶
type TagPolicy struct { // GitTagger tags images with the git tag or git commit of the artifact workspace directory. GitTagger *GitTagger `yaml:"gitCommit,omitempty" yamltags:"oneOf=tag"` // ShaTagger tags images with their sha256 digest. ShaTagger *ShaTagger `yaml:"sha256,omitempty" yamltags:"oneOf=tag"` // EnvTemplateTagger tags images with a configurable template string. EnvTemplateTagger *EnvTemplateTagger `yaml:"envTemplate,omitempty" yamltags:"oneOf=tag"` // DateTimeTagger tags images with the build timestamp. DateTimeTagger *DateTimeTagger `yaml:"dateTime,omitempty" yamltags:"oneOf=tag"` }
TagPolicy contains all the configuration for the tagging step.
type TestCase ¶
type TestCase struct { // ImageName is the artifact on which to run those tests. ImageName string `yaml:"image" yamltags:"required"` // StructureTests lists the [Container Structure Tests](https://github.com/GoogleContainerTools/container-structure-test) // to run on that artifact. // For example: `["./test/*"]`. StructureTests []string `yaml:"structureTests,omitempty"` }
TestCase is a list of structure tests to run on images that Skaffold builds.
type TestConfig ¶ added in v0.18.0
type TestConfig []*TestCase