cvsup-mirror rewrite

João Carlos Mendes Luís jonny at jonny.eng.br
Thu Dec 9 06:27:42 PST 2004



Jeremie Le Hen wrote:
> First, thanks replying and sharing your opinion.
> 
> 
>>>>>  o I would also like to move etc/cvsup/update.sh to something like
>>>>>    /usr/local/libexec/cvsup-mirror.sh, following the example of the
>>>>>    atrun command executed from cron(8) [1].
>>
>>I'd expect more work on customizing update.sh to allow it's 
>>configuration to come from /etc/rc.conf or some other place not touched 
>>during upgrades.  As jdp stated, an upgrade is not easy right now.
> 
> 
> Yes, this is indeed a great goal.  The configuration variables would
> roughly use the config.sh ones and a another one which specifies where
> "bookkeeping files" are stored (which is /var/db for the base system).

     That's not true for every port.  Let take squid, for example.  It 
creates a ${PREFIX}/squid directory, under which it puts cache and log 
files.  Also, arpwatch uses ${PREFIX}/arpwatch to store constant and 
varying databases.  PostgreSQL is another example, which uses 
${PREFIX}/pgsql as home dir to the user pgsql, and under which it stores 
all config and database files.  Last but not least, every version of 
java I've used in FreeBSD creates a complete hierarchy under its own 
directory below ${PREFIX}/foo.

     I do agree that it breaks hier(7), but some packages are just to 
complex or tight to spread over lots of directories.  In my own servers, 
for example, I simply don't use the default squid port because of this 
spreading.  I personally prefer the original squid layout, with 
/usr/local/squid/{bin,sbin,lib,cache,log,etc.}.  It makes easier for me 
to find what I need quickier.

> I understand your point of view but there is no var/ directory under
> ${DESTDIR}.  It's also worth noting that usually logs from Apache or
> Postfix - which are installed from ports - are stored in /var/log and
> not in ${DESTDIR}/var/log.

     Well, postfix is a full replacement for a "system package" 
(sendmail), so it's reasonable to make its changes transparent, just 
like those that have been made recently with perl, until it has been 
taken off the base system.  I even would agree to completely remove 
sendmail and use a "slot" structure for mail ports.

     Also Apache is fully configurable in this aspect, and my hosts have 
NEVER written logs to /var/log.  I use a subdirectory for each virtual 
host, each one with its individual data and log directories.  And this 
is what most provider do, since they have to allow access for different 
users for each virtual host.

     The defaults for apache are just that: defaults.  But I don't know 
a single realworld server running on defaul.

 >   Furthermore, I can't think of any directory
> under ${DESTDIR} which would achieve the same purposes as /var/db.
> IMHO ${DESTDIR}/etc/cvsup is definitely not an option, according to
> hier(7).
> 
> However, I would be glad to adopt any proposition which succeeds in
> merging benefits of both solutions without the drawbacks :-).

     ${PREFIX}/cvsup-mirror

     ;-)

     I would put no file related to cvsup-mirror outside this directory, 
except maybe the config rules in /etc/rc.conf and rc_subr startup 
routines if any (I don't think so).

     Even the crontab files should not be touched by the port.  The best 
way is to teach the user what to do, and let him chose which parameters 
to put there.  For example, some places may want to sync just once a 
day, at night.  Others may want to sync every hour or so.  And even 
others may want to do a quick sync (cvsup -s) every hour and a full sync 
once a day.

>>With this and above changes a upgrade would be simply a matter of 
>>changing the scripts and keeping the site config files.
> 
> I'm wondering if it's better to keep backward compatibility and thus
> avoid all changes concerning the files storage location discussed above,
> or simply to fork cvs-mirror (and call it "cvsup-hubs" for example) to
> be able to be more hier(7) compliant.  It seems indeed that changing
> files location in cvsup-mirror is not an option since there would be no
> way to do a proper upgrade.  

     Indeed, upgrade is already a PITA.  I'd vote for a last big change 
in cvsup-mirror to make futures upgrades easier, even if it completely 
breaks the current install format.

     cvsup-mirror is a good name, there's no need to change it, IMHO. 
But it's functionality is definitly not good.

     Please, feel free to contact me in private to discuss more ideas 
and/or beta testing when you start coding.

     Cheers,

		Jonny



More information about the freebsd-hubs mailing list