Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 3. On-cluster function building and deploying
Instead of building a function locally, you can build a function directly on the cluster. When using this workflow on a local development machine, you only need to work with the function source code. This is useful, for example, when you cannot install on-cluster function building tools, such as docker or podman.
3.1. Building and deploying functions on the cluster
				You can use the Knative (kn) CLI to initiate a function project build and then deploy the function directly on the cluster. To build a function project in this way, the source code for your function project must exist in a Git repository branch that is accessible to your cluster.
			
Prerequisites
- Red Hat OpenShift Pipelines must be installed on your cluster.
- 
						You have installed the OpenShift CLI (oc).
- 
						You have installed the Knative (kn) CLI.
Procedure
- In each namespace where you want to run OpenShift Pipelines and deploy a function, you must create the following resources: - Create the - s2iTekton task to be able to use Source-to-Image in the pipeline:- oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-s2i/0.1/func-s2i.yaml - $ oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-s2i/0.1/func-s2i.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - kn funcdeploy Tekton task to be able to deploy the function in the pipeline:- oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-deploy/0.1/func-deploy.yaml - $ oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-deploy/0.1/func-deploy.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a function: - kn func create <function_name> -l <runtime> - $ kn func create <function_name> -l <runtime>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
						After you have created a new function project, you must add the project to a Git repository and ensure that the repository is available to the cluster. Information about this Git repository is used to update the func.yamlfile in the next step.
- Update the configuration in the - func.yamlfile for your function project to enable on-cluster builds for the Git repository:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Implement the business logic of your function. Then, use Git to commit and push the changes.
- Deploy your function: - kn func deploy --remote - $ kn func deploy --remote- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you are not logged into the container registry referenced in your function configuration, you are prompted to provide credentials for the remote container registry that hosts the function image: - Example output and prompts - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
						To update your function, commit and push new changes by using Git, then run the kn func deploy --remotecommand again.
3.2. Specifying function revision
				When building and deploying a function on the cluster, you must specify the location of the function code by specifying the Git repository, branch, and subdirectory within the repository. You do not need to specify the branch if you use the main branch. Similarly, you do not need to specify the subdirectory if your function is at the root of the repository. You can specify these parameters in the func.yaml configuration file, or by using flags with the kn func deploy command.
			
Prerequisites
- Red Hat OpenShift Pipelines must be installed on your cluster.
- 
						You have installed the OpenShift (oc) CLI.
- 
						You have installed the Knative (kn) CLI.
Procedure
- Deploy your function: - kn func deploy --remote \ --git-url <repo-url> \ [--git-branch <branch>] \ [--git-dir <function-dir>]- $ kn func deploy --remote \- 1 - --git-url <repo-url> \- 2 - [--git-branch <branch>] \- 3 - [--git-dir <function-dir>]- 4 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- With the--remoteflag, the build runs remotely.
- 2
- Substitute<repo-url>with the URL of the Git repository.
- 3
- Substitute<branch>with the Git branch, tag, or commit. If using the latest commit on themainbranch, you can skip this flag.
- 4
- Substitute<function-dir>with the directory containing the function if it is different than the repository root directory.
 - For example: - kn func deploy --remote \ --git-url https://example.com/alice/myfunc.git \ --git-branch my-feature \ --git-dir functions/example-func/- $ kn func deploy --remote \ --git-url https://example.com/alice/myfunc.git \ --git-branch my-feature \ --git-dir functions/example-func/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow