Youry's Blog

Youry's Blog

Multiple SVN repositories discussion

leave a comment »

From: http://stackoverflow.com/questions/1761513/multiple-svn-repositories-or-single-company-repository

Personally I would definitely prefer separate repository per project. There are several reasons:

  1. Revision numbers. Each project repository will have separate revisions sequence.
  2. Granularity. With repository per project you just can’t make a commit into different projects having the same revision number. I assume this more as advantage, while someone would say that it is a flaw.
  3. Repository size. How large is your project? Does it have binaries under source control? I bet it has. Therefore, size is important – each revision of binary file increases size of the repository. Eventually it becomes clumsy and it’s hard to support. Fine-grained policy of binary files storage should be supported, and additional administration provided. As for me, I still can’t find how could I completely delete binary file (committed by some stupid user) and its contents history from repository. With repository per project it would be easier.
  4. Inner repository organization. I prefer fine-grained, very organized, self contained, structured repositories. There is a diagram illustrating general (ideal) approach of repository maintenance process. I think you would agree that it is just NOT POSSIBLE to use ‘all projects in one repo’ approach. For example, my initial structure of repository (every project repository should have) is:
    /project
        /trunk
        /tags
            /builds
                /PA
                /A
                /B
            /releases
                /AR
                /BR
                /RC
                /ST
        /branches
            /experimental
            /maintenance
                /versions
                /platforms
            /releases
    
  5. Repo administration. ‘Repository per project’ has more possibilities in users access configuration. It is more complex though. But there is also helpful feature: you can configure repositories to use the same config file
  6. Repo Support. I prefer backing up repositories separately. Somebody says that in this case it is not possible to merge info from one repo into the other. Why on earth you would need that? The case when such merge is required shows that initial approach to source control is wrong. Evolution of the project assumes subsequent project separation into submodules, not the other way. And I know that there is approach to do that.
  7. svn:externals. ‘Repository per project’ approach encourages svn:externals usage. That is a healthy situation when dependencies between project and submodules is established via soft links, which svn:externals is.Conclusion. If you want to keep source control simple, use one repository. If you want to make software configuration management RIGHT:
    1. Use ‘repository per project’ approach
    2. Introduce separate role of software configuration manager and assign team member to it
    3. Hire good administrator, who can cope with all subversion tricks 🙂

PS. By the way, in spite I work with SVN all the time and I like it, ‘repository per project’ approach is why I see DCVS systems more attractive from the repository organization point of view. In DCVS repo is the project by default. There is even no question ‘single vs multiple’ possible, it would be just nonsense.

(see some related posts: http://wordaligned.org/articles/how-to-mirror-a-subversion-repository

http://www.aliaspooryorik.com/blog/index.cfm/e/posts.details/post/clone-a-svn-repository-258

http://stackoverflow.com/questions/143130/how-to-synchronize-two-subversion-repositories

http://svnbook.red-bean.com/en/1.7/svn.ref.svnsync.c.sync.html

http://blogs.collab.net/subversion/mirroring-repos#.UuxtMPa6p4E)

Advertisements

Written by youryblog

January 31, 2014 at 10:35 PM

Posted in IT, SW Eng./Dev.

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s

%d bloggers like this: