mirror of https://github.com/fluxcd/flux2.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
4.5 KiB
Markdown
110 lines
4.5 KiB
Markdown
---
|
|
title: "flux create source git command"
|
|
---
|
|
## flux create source git
|
|
|
|
Create or update a GitRepository source
|
|
|
|
### Synopsis
|
|
|
|
The create source git command generates a GitRepository resource and waits for it to sync.
|
|
For Git over SSH, host and SSH keys are automatically generated and stored in a Kubernetes secret.
|
|
For private Git repositories, the basic authentication credentials are stored in a Kubernetes secret.
|
|
|
|
```
|
|
flux create source git [name] [flags]
|
|
```
|
|
|
|
### Examples
|
|
|
|
```
|
|
# Create a source from a public Git repository master branch
|
|
flux create source git podinfo \
|
|
--url=https://github.com/stefanprodan/podinfo \
|
|
--branch=master
|
|
|
|
# Create a source for a Git repository pinned to specific git tag
|
|
flux create source git podinfo \
|
|
--url=https://github.com/stefanprodan/podinfo \
|
|
--tag="3.2.3"
|
|
|
|
# Create a source from a public Git repository tag that matches a semver range
|
|
flux create source git podinfo \
|
|
--url=https://github.com/stefanprodan/podinfo \
|
|
--tag-semver=">=3.2.0 <3.3.0"
|
|
|
|
# Create a source for a Git repository using SSH authentication
|
|
flux create source git podinfo \
|
|
--url=ssh://git@github.com/stefanprodan/podinfo \
|
|
--branch=master
|
|
|
|
# Create a source for a Git repository using SSH authentication and an
|
|
# ECDSA P-521 curve public key
|
|
flux create source git podinfo \
|
|
--url=ssh://git@github.com/stefanprodan/podinfo \
|
|
--branch=master \
|
|
--ssh-key-algorithm=ecdsa \
|
|
--ssh-ecdsa-curve=p521
|
|
|
|
# Create a source for a Git repository using SSH authentication and a
|
|
# passwordless private key from file
|
|
# The public SSH host key will still be gathered from the host
|
|
flux create source git podinfo \
|
|
--url=ssh://git@github.com/stefanprodan/podinfo \
|
|
--branch=master \
|
|
--private-key-file=./private.key
|
|
|
|
# Create a source for a Git repository using SSH authentication and a
|
|
# private key with a password from file
|
|
# The public SSH host key will still be gathered from the host
|
|
flux create source git podinfo \
|
|
--url=ssh://git@github.com/stefanprodan/podinfo \
|
|
--branch=master \
|
|
--private-key-file=./private.key \
|
|
--password=<password>
|
|
|
|
# Create a source for a Git repository using basic authentication
|
|
flux create source git podinfo \
|
|
--url=https://github.com/stefanprodan/podinfo \
|
|
--username=username \
|
|
--password=password
|
|
```
|
|
|
|
### Options
|
|
|
|
```
|
|
--branch string git branch (default "master")
|
|
--ca-file string path to TLS CA file used for validating self-signed certificates
|
|
--git-implementation gitImplementation the Git implementation to use, available options are: (go-git, libgit2)
|
|
-h, --help help for git
|
|
-p, --password string basic authentication password
|
|
--private-key-file string path to a passwordless private key file used for authenticating to the Git SSH server
|
|
--recurse-submodules when enabled, configures the GitRepository source to initialize and include Git submodules in the artifact it produces
|
|
--secret-ref string the name of an existing secret containing SSH or basic credentials
|
|
--ssh-ecdsa-curve ecdsaCurve SSH ECDSA public key curve (p256, p384, p521) (default p384)
|
|
--ssh-key-algorithm publicKeyAlgorithm SSH public key algorithm (rsa, ecdsa, ed25519) (default rsa)
|
|
--ssh-rsa-bits rsaKeyBits SSH RSA public key bit size (multiplies of 8) (default 2048)
|
|
--tag string git tag
|
|
--tag-semver string git tag semver range
|
|
--url string git address, e.g. ssh://git@host/org/repository
|
|
-u, --username string basic authentication username
|
|
```
|
|
|
|
### Options inherited from parent commands
|
|
|
|
```
|
|
--context string kubernetes context to use
|
|
--export export in YAML format to stdout
|
|
--interval duration source sync interval (default 1m0s)
|
|
--kubeconfig string absolute path to the kubeconfig file
|
|
--label strings set labels on the resource (can specify multiple labels with commas: label1=value1,label2=value2)
|
|
-n, --namespace string the namespace scope for this operation (default "flux-system")
|
|
--timeout duration timeout for this operation (default 5m0s)
|
|
--verbose print generated objects
|
|
```
|
|
|
|
### SEE ALSO
|
|
|
|
* [flux create source](../flux_create_source/) - Create or update sources
|
|
|