A sidecar app which clones a git repo and keeps it in sync with the upstream.
Go to file
Kubernetes Prow Robot 8ef40b88e5
Merge pull request #121 from thockin/fix-hugo-demo
Fix hugo demo and docs
2018-12-19 08:31:59 -08:00
Godeps Clean up logging using glogr 2016-09-16 08:35:27 -07:00
build Build a manifest list 2018-11-09 14:20:23 -08:00
cmd/git-sync Switch to rev-parse 2018-11-09 10:16:36 -08:00
demo Fix hugo demo and docs 2018-12-17 11:44:50 -08:00
docs Fix hugo demo and docs 2018-12-17 11:44:50 -08:00
pkg/version Use the go-build-template 2016-10-30 17:09:06 -07:00
vendor/github.com Clean up logging using glogr 2016-09-16 08:35:27 -07:00
.gitignore Use the go-build-template 2016-10-30 17:09:06 -07:00
CONTRIBUTING.md Create CONTRIBUTING.md 2016-08-22 16:18:11 -07:00
Dockerfile.in Build a manifest list 2018-11-09 14:20:23 -08:00
LICENSE Initial commit 2016-08-20 14:09:57 -07:00
Makefile Build a manifest list 2018-11-09 14:20:23 -08:00
OWNERS Update OWNERS to latest state 2017-03-22 03:52:17 +00:00
README.md Update example volume mount 2018-12-17 10:57:06 -08:00
RELEASING.md Use k8s GCR vanity URL 2018-04-06 13:15:46 -04:00
SECURITY_CONTACTS Add security contacts 2018-05-24 08:57:57 -07:00
code-of-conduct.md Update code-of-conduct.md 2017-12-20 13:32:20 -05:00
test_e2e.sh Build a manifest list 2018-11-09 14:20:23 -08:00

README.md

git-sync

git-sync is a simple command that pulls a git repository into a local directory. It is a perfect "sidecar" container in Kubernetes - it can periodically pull files down from a repository so that an application can consume them.

git-sync can pull one time, or on a regular interval. It can pull from the HEAD of a branch, or from a git tag, or from a specific git hash. It will only re-pull if the target of the run has changed in the upstream repository. When it re-pulls, it updates the destination directory atomically. In order to do this, it uses a git worktree in a subdirectory of the --root and flips a symlink.

Usage

# build the container
make container REGISTRY=registry VERSION=tag

# run the container
docker run -d \
    -v /tmp/git-data:/tmp/git \
    registry/git-sync:tag \
        --repo=https://github.com/kubernetes/git-sync
        --branch=master
        --wait=30

# run an nginx container to serve the content
docker run -d \
    -p 8080:80 \
    -v /tmp/git-data:/usr/share/nginx/html \
    nginx

Analytics