Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tongueroo/docksync
Rsync files from your macosx machine to the docker container
https://github.com/tongueroo/docksync
Last synced: about 1 month ago
JSON representation
Rsync files from your macosx machine to the docker container
- Host: GitHub
- URL: https://github.com/tongueroo/docksync
- Owner: tongueroo
- License: mit
- Created: 2015-01-05T03:47:04.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2015-01-05T07:25:42.000Z (almost 10 years ago)
- Last Synced: 2024-10-14T22:17:02.732Z (3 months ago)
- Language: Ruby
- Size: 152 KB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Docksync
[![Build Status](https://travis-ci.org/tongueroo/docksync.svg?branch=master)](https://travis-ci.org/tongueroo/docksync)
[![Code Climate](https://codeclimate.com/github/tongueroo/docksync/badges/gpa.svg)](https://codeclimate.com/github/tongueroo/docksync)Tool to rsync your files from your macosx machine to the docker container.
Sharing volumes from macosx to the docker host to the container is extremely slow. In one of our large applications a task that normally takes 15 seconds takes about 5 mins with the shared volume. This is a 20x performance hit. The issue is not docker, the issue is that the shared volume is slow. For small projects sharing volumes is fine, but for larger projects it is too slow for development. This tool is a hack to sync files from macosx to the docker container. The tool is useful until shared volumes on macosx is faster.
## How it works
* It installs and setups an rsync server on the running container.
* It then watches for any changed files on your filesystem and will sync them over as needed.
* It uses the WORKDIR configured in your Dockerfile and will rsync the project files there.
* This only works on ubuntu because it uses apt-get to install the rsync server to the running container.
* This also assumes you are using boot2docker.
* IMPORTANT: You'll need to expose port 873 so that this script works. You can put this in your Dockerfile, fig.yml or in the docker run command.
* Make sure you are not using volumes, the whole point of this gem is to avoid the volume sharing.## Installation
$ gem install docksync## Usage
$ docksync watch [CONTAINER_ID]Example:
$ cd project
$ docksync watch abcdeFor more help:
$ docksync help