|
|
|
Ask HN: how to push to a live site?
|
|
9 points
by iphpdonthitme
6481 days ago
|
|
So I've read a fair amount of books and links on the internet describing how to scale stuff. Something I haven't come across are general strategies on pushing to a live CRUD site without taking it down. Can anyone point me to resources that I've missed, or perhaps just tell me? |
|
We wrote a little custom code (we call it "bake") for deploying Cappuccino applications:
"bake": http://github.com/280north/cappuccino/tree/master/Tools/bake...
sample "bakefile": http://github.com/280north/cappuccino/tree/master/Tools/bake...
It pulls your code from git (but could easily do local files, scp, rsync, svn, etc), runs an optional build command (like "ant"), copies source paths to destination paths in a deployment directory, gzips the deployment directory, scp's the code to your server(s), ungzips it, and does a little magic...
Each version is placed in it's entirety in a uniquely named (unix timestamp) subdirectory. We could just redirect from "/" to "/1221268756/" (for example) but that's incredibly ugly, so we use the little known HTML <base> tag to trick it. The index.html file in "/" is identical to the one in "/1221268756/" except it has a <base> tag which tells the app all URLs are relative to "/1221268756/" instead of the default containing directory ("/").
And it actually seems to work really well. The big advantage of this is you can set your cache expire date arbitrarily far in the future, and your entire app will be cached until you change index.html to point to a new <base>. 280 Slides, which is ~2.6MB uncompressed, loads on my computer in about 1.5 seconds if it's cached. The only problem with this approach is when you deploy, all clients will have to re-download every resource, even ones that don't change. A more granular system would be ideal, but significantly more complex.
I looked at Capistrano briefly but decided against it for some reason I can't remember. Perhaps that would have been better, but c'est la vie...