
Security News
New Website “Is It Really FOSS?” Tracks Transparency in Open Source Distribution Models
A new site reviews software projects to reveal if they’re truly FOSS, making complex licensing and distribution models easy to understand.
![Gem version][gem-badge] [gem-badge]: https://badge.fury.io/rb/capistrano-rsync.png
Deploy with Rsync to your server from any local (or remote) repository when using Capistrano. Saves you from having to install Git on your production machine and allows you to customize which files you want to deploy. Also allows you to easily precompile things on your local machine before deploying.
>= 3.0.0pre14
and
< 4
.--exclude
options.Using Mina instead of Capistrano? I've built Mina::Rsync as well.
Install with:
gem install capistrano-rsync
Require it at the top of your Capfile
(or config/deploy.rb
):
require "capistrano/rsync"
Set some rsync_options
to your liking:
set :rsync_options, %w[--recursive --delete --delete-excluded --exclude .git*]
And after setting regular Capistrano options, deploy as usual!
cap deploy
rsync_stage
(defaults to
tmp/deploy
) on your local machine.branch
variable (defaults to master
).rsync_cache
set (defaults to shared/deploy
), rsyncs to that directory
on the server.rsync_cache
set, copies the content of that directory to a new release
directory.rsync_cache
is nil
, rsyncs straight to a new release directory.After that, Capistrano takes over and runs its usual tasks and symlinking.
If you don't want to deploy everything you've committed to your repository, pass
some --exclude
options to Rsync:
set :rsync_options, %w[
--recursive --delete --delete-excluded
--exclude .git*
--exclude /config/database.yml
--exclude /test/***
]
Capistrano::Rsync runs rsync:stage
before rsyncing. Hook to that like this:
task :precompile do
Dir.chdir fetch(:rsync_stage) do
system "rake", "assets:precompile"
end
end
after "rsync:stage", "precompile"
cap rsync:release
Set Capistrano variables with set name, value
.
Name | Default | Description |
---|---|---|
repo_url | . | The path or URL to a Git repository to clone from. |
branch | master | The Git branch to checkout. |
rsync_stage | tmp/deploy | Path where to clone your repository for staging, checkouting and rsyncing. Can be both relative or absolute. |
rsync_cache | shared/deploy | Path where to cache your repository on the server to avoid rsyncing from scratch each time. Can be both relative or absolute. Set to nil if you want to disable the cache. |
rsync_options | [] | Array of options to pass to rsync . |
Capistrano::Rsync is released under a Lesser GNU Affero General Public License, which in summary means:
For more convoluted language, see the LICENSE
file.
Andri Möll made this happen.
Monday Calendar was the reason I needed this.
If you find Capistrano::Rsync needs improving, please don't hesitate to type to me now at andri@dot.ee or create an issue online.
FAQs
Unknown package
We found that capistrano-rsync demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
A new site reviews software projects to reveal if they’re truly FOSS, making complex licensing and distribution models easy to understand.
Security News
Astral unveils pyx, a Python-native package registry in beta, designed to speed installs, enhance security, and integrate deeply with uv.
Security News
The Latio podcast explores how static and runtime reachability help teams prioritize exploitable vulnerabilities and streamline AppSec workflows.