[CentOS] Re: Why is yum not liked by some? -- CVS analogy (and why you're not getting it)

Fri Sep 9 04:30:04 UTC 2005
David Johnston <david at littlebald.com>

Les,
I think this discussion has gotten lost in the weeds.  What you want to
do is easy to accomplish using Yum, but you have to use Yum the way it
was intended to be used.  First, you must have your own repository
server, which will host as many repositories as your change control
policies require (eg, untested, test, qa, production).  Using the Centos
repositories directly means that you're rolling out on Centos' change-
control schedule, not yours.  Set up your own repository and you can
control it.


The rest of this message is just a summary of things that others on this
list have already said.

1. You need your own repository server.  This machine needs good
Internet connectivity, Apache, and about 100GB of disk space.

2. On your repository server, you need to host three repositories.
	#1 is a copy of the Centos repositories you use, call it "untested"
	#2 is a subset of #1, call it "qa"
	#3 is a subset of #2, call it "production"

3. #1 gets updated nightly with a simple yum update.  In other words, it
just copies the binary packages from the Centos repositories.

4. Keep in mind that #2 and #3 won't take up much disk space because the
files in these repositories are actually just links to the real files in
#1.

5. "createrepo" will create the Yum headers for all of the packages in a
given directory.

6. If you want to promote a set of packages from #1 to #2, you first add
links
(eg, "ln -s /var/spool/repo/untested/somepkg.rpm /var/spool/repo/qa/").
As you do this, any machine attempting to run "yum update" against the
qa repository will see no change.

7. Here's where the repo gets its atomicity: once all of the packages
are linked, you re-run createrepo.  Until createrepo finishes, the repo
will appear unchanged.

8.  All of your QA machines use your "qa" repository, and run yum update
nightly.

9.  All of your production machines use your "production" repository and
run yum update nightly.

10.  YOU control when createrepo is run on your QA and Production
repositories, thus controlling when things roll out.