On 31/01/2013 9:13 PM, Ryan Schmidt wrote:
On Jan 31, 2013, at 20:05, Jason Keltz wrote:

On 31/01/2013 6:06 PM, Bob Archer wrote:
What you need to do could work. I assume this "software" in order to run can 
build built or whatever during your nightly update on each client?

You keep saying "rsyncing" ... you wouldn't use that. You wouldn't use that of 
course, you would use the svn client binary.
Actually, maybe I wasn't clear..
The software includes various packages like say, Matlab, or Maple, or whatever else, already installed...  
imagine a directory on the fileserver.. say, /local/software which includes "bin", "lib", 
etc...    I'm not "installing" the software.   it's already been installed..  I'm just syncing a 
directory between machines..
As for rsyncing.. I would rsync the software from the "file server" to the "software 
distribution" server, and then use svn from there to check in all the changes.

For you initial load... if the software is on the server where you will house 
your repository you can just import the data into the repository from that 
file... there is no need to send the data twice. In other words, you can have 
both a working copy and a repository on your central server.
Yes.  Initially I would do an import, but the problem is... the next day, the software gets updated 
on the "real" file server... say, new version of Matlab or something...  in the evening, 
I want the process to run that would rsync the data (with all the changes) from the file server to 
the software distribution server,  do something to commit the changes, then the 100 clients would 
eventually each "svn update".     However, to be able to commit the changes, I need to 
have a working copy on the software distribution server....

However, after the rsync happens, I now need to run a command that would
update the repository with the state of the working directory.  However, it's 
not
exactly clear how this would work?  Running an "svn update"
"svn update" brings any changes in the repository to your working copy. "svn 
commit" does the opposite... it puts any changes in a working directory into the repository.
See, this is where I'm confused... I created a few directories including "bin" and 
"pkg" for a test.  All committed fine... erased them from the working copy, did a commit 
then a status and I see:

!       bin
!       pkg

but when I go into a different directory and check out the current state..

A    pkg
A    bin
Checked out revision 2.

they're still there...
Correct. Subversion does not track your movements. You must tell Subversion what you are moving and 
deleting by doing the moves and deletes using "svn mv" and "svn rm", not using 
regular OS commands.


Hth...

That said, if this is actual software, wouldn't using one of the many package 
management tools available in Linux be a better fit?
The thing is, I'm moving around already installed software, and there's nothing that 
great, as far as I can see, for doing that. The twitter guys are using something they 
wrote called "murder" which uses torrent to do this kind of thing...  excellent 
idea, but it uses Ruby and several other tools ...   and I don't want to get into that at 
the moment...
Subversion is not going to be a satisfactory solution for this use case. Besides all the 
issues you're describing with setting up the server-side infrastructure for this, and as 
was already mentioned, when you check out a working copy of this on your clients, there 
will be a "duplicate" pristine copy of everything. So if you have 60GB of 
software, it'll take up 120GB of space on the client machine.
I'm glad you brought that up :)

Subversion is not a software distribution tool; it is a document and revision 
management system. Use a different tool. As someone else said, rsync seems like 
a good tool for this job; I didn't understand why you think using rsync 
directly between your file server and your clients won't work.


See my email to Les... If only the rsync server could save a copy of the file checksums when it runs, it would probably decrease the sync time by half and save a whole lot of disk activity...


--
Jason Keltz
Manager of Development
Department of Computer Science and Engineering
York University, Toronto, Canada
Tel: 416-736-2100 x. 33570
Fax: 416-736-5872

Reply via email to