This extension helps you sync files/directories from your container back to your local FS. Under the hood, it uses rsync
to be smart about what files to transfer. For details on implementation, gotchas, etc., see MORE_INFO.md.
This extension provides a function syncback
which creates a manually-triggered local resource to sync files from a Kubernetes container back to your local filesystem. You can configure the source pod/container/directory/files+directories, and the destination location, as well as some other settings.
Whenever you want to sync files back from the pod to your local filesystem, invoke the local resource from the Web UI:
You can also use the tilt trigger
CLI; e.g. for the example above, you would run:
tilt trigger syncback-js
First, make sure you have an up-to-date rsync
on your local machine (version >= 3.0.0).
Import this extension by putting the following at the top of your Tiltfile:
load('ext://syncback', 'syncback')
For every syncback resource you want to create, invoke syncback
with the following parameters:
- name (str): name of the created local resource
- k8s_object (str): a Kubernetes object identifier (e.g.
deploy/my-deploy
,job/my-job
, or a pod ID) that Tilt can use to select a pod. As per the behavior ofkubectl exec
, we will act on the first pod of the specified object, using the first container by default - src_dir (str): directory in the remote container to sync from. Any
paths
, if specified, should be relative to this dir. This path must be a directory and must contain a trailing slash (e.g./app/
is acceptable;/app
is not)
You may also pass the following optional parameters:
- ignore (List[str], optional): files to ignore when syncing (relative to src_dir).
- delete (bool, optional): run
rsync
with the--delete
flag, i.e. delete files locally if not present in the container. By default, False. This option risks wiping out files that exist locally but not in the container. Tilt will protect some files automatically, but we recommend syncing specific paths (viapaths
) and/or using theignore
parameter to explicitly protect local files from deletion. - paths (List[str]): paths in the remote container to sync, relative to
src_dir
. May be files or directories. Note that these must not begin with./
or/
. If this arg is not passed, sync all of src_dir. - target_dir (str, optional): directory on the local filesystem to sync to. Defaults to
'.'
- container (str, optional): name of the container to sync from (by default, the first container)
- namespace (str, optiona): namespace of the desired
k8s_object
, if notdefault
. - verbose (bool, optional): if true, print additional rsync information.
-
Create a local resource called "syncback-js" which connects to the first pod of "deploy/frontend" (and the default container) and syncs "/app/package.json" and "/app/yarn.lock" to local directory "./frontend":
syncback('syncback-js', 'deploy/frontend', ['package.json', 'yarn.lock'], '/app/', target_dir='./frontend', )
-
Create a local resource called "syncback-portal" which connects to the first pod of "deploy/portal-app" (to container "app") in namespace $(whoami), and syncs the entire contents of "src/node_modules" to local directory "./portal/node_modules":
ns = str(local('whoami')).strip() syncback('syncback-portal', 'deploy/portal-app', [], '/src/node_modules/', target_dir='./portal/node_modules', container='app', namespace=ns )
-
Create a local resource called "syncback-data" which connects to the first pod of "job/data-cron" syncs the contents of "/data" to the local cwd. Protect several files ("k8s.yaml", "config.json") that exist locally but not in the container (otherwise they would be deleted locally on sync):
syncback('syncback-data', 'job/data-cron', [], '/data/', ignore=['k8s.yaml', 'config.json'] )
You can create as many syncback resources as you like; you'll need at minimum one syncback resource for every remote container you want to copy from, but you might choose to have different syncback resources for different sets of files, e.g. one to copy back node_modules
and one to copy back your data/
directory.
This is expected behavior; if you're using Live Update, we expect the update that runs after syncback to be a no-op, and super fast. For more on how to how to make this extra update as painless as possible, see MORE_INFO.md.
Kubernetes might have connected you to the wrong pod. We recommend waiting a few seconds/waiting until kubectl get pods
shows only the pods you expect to, and trying again. For details, see MORE_INFO.md.
If you're running syncback with delete=True
, BEWARE: syncback will delete any files locally that don't exist in src_dir
, so if there are some local files you don't add to your Docker image, they're at risk of being blown away. Consider using the paths
and/or ignore
parameters to be very specific about the files rsync
should care about.
(Need this functionality? Need something else not listed here? Let us know!)
rsync
-specific syntax:rsync
has its own semantics, e.g. specific meanings for directories with and without a trailing slash, or for*
vs.**
vs.***
. This extension converts your arguments into our best guess of theirrsync
translation, butrsync
experts might want more fine-grained control- running on a Windows local machine: this extension relies heavily on bash, sorry :-/
- running on Windows containers: our pre-built Linux
rsync
binary definitely won't run on Windows containers - running automatically in response to file/resource changes: it would be neat if Tilt knew when syncbacks were needed (because
fileX
changed locally, because Resource Y updated, or even iffileZ
changed in the container), but currently this isn't supported
tk