On Wed, Nov 2, 2011 at 2:23 PM, Trevor Cordes trevor@tecnopolis.ca wrote:
Here's the copies I currently have that I'd like to git-itize:
- Raw dev copy on my box
- Testing copy on production server
- Live copy on production server
- 2nd dev copy on some other guy's server
- git "master" copy somewhere on production server
You'll want to set up what's called a "bare repo" somewhere. A bare repo is basically the contents of the .git directory with none of the working files. git init --bare does it, or you can set up a git server. Gitosis-lite is easy to use and only takes a bit of time to set up. Or pay a few bucks and use github.com or another service. This is what you will think of as your master copy. No one ever touches it directly.
Everyone will clone the repository locally with something like
git clone git@git.yourdomain.com:yourapp.git
This will create a local copy of the repo with a remote called "origin". Everyone works locally, commits, then pushes stuff to origin.
(make local changes) git add . git commit -m "fixed bug #71" # now it's committed to my local repo git push origin master # now it's committed to the master
other guys can git pull origin master # now I have your changes
Git doesn't have "different copies". Everyone has the same thing, and you use branches to figure out what your working copy looks like.
For your different users, you have to decide which branches mean what. I follow the continuous deployment model which means that master is always in a "ready to push" state. I usually create "topic branches" to do work and merge them back in to master when I'm happy. Usually these topic branches stay local, but if I want to share changes with other developers I can push the branch itself (which is just a pointer) to the origin server and the other devs can see what I've got.
So if I'm a developer, my procedure would be
git pull origin master # update to the latest code git branch myfeature # change to a new feature (implement myfeature) git add . git commit -m "implemented myfeature" git checkout master # get back on to master, my changes disappear git merge myfeature # merge the changes from myfeature onto master git push origin master # on to the server
(it seems verbose, yes)
So for your staging and production servers, you would update master from origin as needed (first staging, verify, then prod) in two separate clones of the repo.
None of this requires post-commit hooks. People only log in as git to update their local repos, never interactively.
(feel free to talk to me off list if you need more details)
Sean
I'd love some help with confirming this structure will work with git
and maybe some tips on actual git commands to get it going. The 2 developers have full shell access on the production server. I've setup a "git" user on it too, which both users can access if required.
From what I've learned, the testing and live copies can be done with a special push or pull or clone, maybe with post-hooks. I don't think those will be a big problem.
The main stumbling block is where/what/how I make the "git master copy" (#5) and how I'm supposed to integrate that with the #1 & #4 dev copies.
Thanks!!
Roundtable mailing list Roundtable@muug.mb.ca http://www.muug.mb.ca/mailman/listinfo/roundtable