Skip to content

Commit

Permalink
chore(doc): describe build strategies
Browse files Browse the repository at this point in the history
Closes #3336
  • Loading branch information
squakez committed Sep 15, 2023
1 parent 73f5b5d commit 770ee7d
Show file tree
Hide file tree
Showing 6 changed files with 51 additions and 10 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/builder.yml
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ jobs:
strategy:
fail-fast: false
matrix:
publisher: ["Spectrum", Jib"]
publisher: ["Spectrum", "Jib"]

steps:
- name: Checkout code
Expand Down
4 changes: 2 additions & 2 deletions docs/modules/ROOT/nav-end.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,7 @@
** xref:traits:toleration.adoc[Toleration]
** xref:traits:tracing.adoc[Tracing]
// End of autogenerated code - DO NOT EDIT! (trait-nav)
* Pipelines
** xref:pipeline/pipeline.adoc[Basic]
* xref:pipeline/pipeline.adoc[Pipelines]
** xref:pipeline/tekton.adoc[Tekton]
* Scaling
** xref:scaling/integration.adoc[Integrations]
Expand All @@ -84,6 +83,7 @@
*** xref:architecture/cr/camel-catalog.adoc[CamelCatalog]
** xref:architecture/runtime.adoc[Runtime]
** xref:architecture/traits.adoc[Traits]
** xref:architecture/incremental-image.adoc[Incremental Image]
* API
** xref:apis/camel-k.adoc[Camel K API]
** xref:apis/kamelets.adoc[Kamelets API]
Expand Down
9 changes: 4 additions & 5 deletions docs/modules/ROOT/nav.adoc
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
* xref:installation/installation.adoc[Installation]
** xref:installation/advanced/maven.adoc[Configuring Maven]
** xref:installation/registry/registry.adoc[Configuring Registry]
** xref:contributing/upgrade.adoc[Upgrade]
** xref:contributing/uninstalling.adoc[Uninstalling]
** xref:installation/advanced/advanced.adoc[Advanced]
*** xref:installation/advanced/build-config.adoc[Build tuning]
*** xref:installation/advanced/kustomize.adoc[Install Using Kustomize]
*** xref:installation/advanced/network.adoc[Network architecture]
*** xref:installation/advanced/resources.adoc[Resource management]
*** xref:installation/advanced/multi.adoc[Multiple Operators]
*** xref:installation/advanced/http-proxy.adoc[HTTP Proxy]
*** xref:installation/advanced/multi-architecture.adoc[Multi Architecture]
*** xref:installation/advanced/offline.adoc[Offline]
** xref:contributing/upgrade.adoc[Upgrade]
** xref:contributing/uninstalling.adoc[Uninstalling]
* Command Line Interface
** xref:cli/cli.adoc[Kamel CLI]
* xref:cli/cli.adoc[Command Line Interface]
** xref:cli/file-based-config.adoc[File-based Config]
** xref:cli/modeline.adoc[Modeline]
* xref:running/running.adoc[Run an Integration]
Expand All @@ -23,4 +23,3 @@
** xref:running/run-from-github.adoc[Run from GitHub]
** xref:running/promoting.adoc[Promote an Integration]
** xref:running/knative-sink.adoc[Knative Sinks]
9 changes: 9 additions & 0 deletions docs/modules/ROOT/pages/architecture/incremental-image.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
= Incremental image

One of the goal of Camel K is to provide a Cloud Native experience for Camel developers. It means basically to have a quick build of the application based on the Camel route you provide and an execution that should be as fast as possible.

In order to reduce the time to build and execute an application we adopt various strategies. If an application has a container with all the dependencies required, then, we just reuse such container, having an immediate start of your application. And then we have the concept of **incremental image**.

If you're familiar with Camel K architecture, you know that an Integration uses an IntegrationKit, which is, a reusable resource containing all the dependencies and capabilities required to run a certain "class" of Camel applications. The IntegrationKit is bound to a container image stored in a registry.

When the IntegrationKit is created, it uses as a base image a JDK based container and add certain applications layers on top of it. However, instead of using always the same root base image, we check if an IntegrationKit with a subset of dependencies already exists, sparing quite some time on the generation of the new container image.
33 changes: 33 additions & 0 deletions docs/modules/ROOT/pages/installation/advanced/build-config.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
= Build configuration

The default installation provides some default configuration in order to perform a build and the publishing of the application in the container registry. In order to provide a more customized user experience, we provide two build configuration which you can use: **Build Strategy** and **Publish Strategy**.

[[build-strategy]]
== Build strategy

The build strategy is used to control the behavior of the application build from the Integration source. This is equivalent to the Maven process building a Java application. You can configure the operator to run this operation either as a routine (or thread) in the same operator application, or to spin off a Kubernetes Pod and execute the build in a new separate application.

The `routine` strategy (default) is in general faster as it does not require Kubernetes to create any new resource, however it consumes a high amount of memory and may slow down any other process run in the same Camel K operator Pod. In general is a good strategy, but you need to consider the trade off if you have multiple concurrent builds at the same time.

The `pod` strategy is **always** used when running a Quarkus native build (as it requires certain tools not available in the operator container). You can also use this strategy when you want to have a higher level of concurrency. Although a bit slower (it requires Kubernetes to spin off a new Pod), this strategy will guarantee the execution of each parallel build in a timely manner.

NOTE: the `pod` strategy was also required when using the now deprecated Buildah or Kaniko publishing strategy.

Beside the build strategy, there are other configuration you can fine tune for each single build (via builder trait) or in the `.spec.build.buildConfiguration` of the IntegrationPlatform if you want to apply such configuration to all your builds. See the Builder trait page for more information.

The most relevant are the `resource` and `limit` parameters which can be used to control how much resources to give to builder Pods. Then you can configure the `orderStrategy`, setting a `sequential` (single build), `fifo` (parallel build started in FIFO order) or `dependencies` (parallel build holding those applications which may depends on other because of ** xref:architecture/incremental-image.adoc[incremental image]). Finally you can include any `mavenProfile` to the build in order to influence the behavior of the build (ie, adding any plugin or configuration you can use when xref:pipeline/pipeline.adoc[running a pipeline]).

[[publish-strategy]]
== Publish strategy

The publish strategy is used to control the behavior of the creation of the container after a build. Basically it create a container image from the application built in the previous step and store as a container in the xref:installation/registry/registry.adoc[registry] configured.

The operator has 3 different strategy which you can adopt: Spectrum (default in plain Kubernetes profile), S2I (default in Openshift profile) and Jib.

Each configuration provides a set of technologies which are supporting the creation of a container image and the storage into a container registry. https://github.com/container-tools/spectrum[Spectrum] is a lightweight technology based on https://github.com/google/go-containerregistry[go-containerregistry]. It creates a raw image on top of a base image and push very quickly to a registry.

https://access.redhat.com/documentation/es-es/openshift_container_platform/4.2/html/builds/understanding-image-builds#build-strategy-s2i_understanding-image-builds[S2I] is an efficient technology integrated in Openshift, reason why it is enabled by default in such a profile.

https://cloud.google.com/java/getting-started/jib[Jib] is a technology that transform a Java project into a container image and is configurable directly in Maven.

NOTE: you may define your own publishing technology by using xref:pipeline/pipeline.adoc[pipelines].
4 changes: 2 additions & 2 deletions pkg/apis/camel/v1/integrationplatform_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -154,11 +154,11 @@ type IntegrationPlatformBuildPublishStrategy string
const (
// IntegrationPlatformBuildPublishStrategyBuildah uses Buildah project (https://buildah.io/)
// in order to push the incremental images to the image repository. It can be used with `pod` BuildStrategy.
// Deprecated: use Spectrum, Jib or S2I instead
// Deprecated: use Spectrum, Jib or S2I instead.
IntegrationPlatformBuildPublishStrategyBuildah IntegrationPlatformBuildPublishStrategy = "Buildah"
// IntegrationPlatformBuildPublishStrategyKaniko uses Kaniko project (https://github.com/GoogleContainerTools/kaniko)
// in order to push the incremental images to the image repository. It can be used with `pod` BuildStrategy.
// Deprecated: use Spectrum, Jib or S2I instead
// Deprecated: use Spectrum, Jib or S2I instead.
IntegrationPlatformBuildPublishStrategyKaniko IntegrationPlatformBuildPublishStrategy = "Kaniko"
// IntegrationPlatformBuildPublishStrategyS2I uses the Source to Images (S2I) feature
// (https://docs.openshift.com/container-platform/4.9/openshift_images/create-images.html#images-create-s2i_create-images)
Expand Down

0 comments on commit 770ee7d

Please sign in to comment.