Date: Tue, 13 May 2003 11:02:50 +0100 From: Matthew Seaman <m.seaman@infracaninophile.co.uk> To: RN Hosting <hosting@reallynicehosting.com> Cc: freebsd-questions@freebsd.org Subject: Re: cvsup question Re: Re: Upgrade or Install new version of freebsd for Sendmail Message-ID: <20030513100250.GA52461@happy-idiot-talk.infracaninophile.co.uk> In-Reply-To: <3676.66.190.246.64.1052802517.squirrel@www.reallynicehosting.com> References: <20030512190043.CA76737B408@hub.freebsd.org> <3676.66.190.246.64.1052802517.squirrel@www.reallynicehosting.com>
next in thread | previous in thread | raw e-mail | index | archive | help
--EVF5PPMfhYS0aIcm Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, May 12, 2003 at 10:08:37PM -0700, RN Hosting wrote: > > From: Matthew Seaman <m.seaman@infracaninophile.co.uk> > > > > # shutdown -r now > > > > (Interrupt the reboot during the 10 second countdown, and boot to > > single user..) > > > > boot: boot -s > > # fsck -p > > # mount -a > > # swapon -a > > # cd /usr/src > > # make installworld > > # mergemaster > > # reboot > > > > With practice, you can easily do this whole single user part of the > > update in under 15 minutes. >=20 > Thank you for these instructions on how to enter single user mode. I have > read several how-tos on using cvsup and they all mention "dropping into > single user mode" yet none of them have described how to do that. I guess that's one of those things that's so obvious no one ever explains how to do it. There's actually two routes to get to single user mode: i) Just run 'shutdown' This will force all of the users to log out and close down all processes, but leaves the system with all of it's network interfaces configured and all of filesystems mounted. ii) As shown above, interrupt the reboot sequence at the countdown and run 'boot -s'. This will leave you with the kernel running, the root partition mounted read-only and not a lot else. The rest of the commands listed serve to get the system into a state where you can run 'make installworld' and 'mergemaster' successfully. For an update of the system, you need to use method two so that you've booted up your new kernel. This also gives you a chance to back out the new kernel if it fails to boot properly, before you've gone and installed the rest of the system, which would be a real pain to undo. > One question that I have is is it possible to enter single user mode as y= ou > have described over SSH or do you have to be physically at the server? No -- you can't get into single user mode via a remote login. You need to be sat at the system console. If you need to update a system at a remote site, then it gets a little tricky, but not impossible. You could manually shutdown as many of the processes running on the system as possible, kick all the users off and do whatever else you can to make the machine quiescent and then just run the 'make installworld' and 'mergemaster' steps from multiuser mode and reboot. Chances are you'll get away with that, especially if it's a relatively small jump in version numbers. However, if things go wrong, then you are up a gum tree. Your vital server has been left unbootable and you haven't got any recourse other than to get physical access to the machine and do a full disaster recovery re-install backups from scratch type exercise. The more sensible alternative is to arrange for remote console access. Some enlightened hosting companies will offer this as part of their package. Otherwise, you're going to have to make your own arrangements. Generally what you do is arrange for the system console to sit on one of the serial ports by setting the correct options in your kernel config (see the descriptions of the flags in sio(4) and the equivalent section in LINT). Then you can either invest in a console server -- for instance http://www.lantronix.com/products/cs/scs820_scs1620/index.html or if you're not made of money you can string a cable from the 2nd serial port on a neighbouring machine to the 1st (console) serial port on the machine in question. Then on the neighbouring machine, run: # tip com2 and you should get the console login for the first machine. I can't remember off hand the spec for the serial cable that you will need, but it's a pretty standard item. Searching the FreeBSD mailing list archives will help you locate the right part. Once you've got the remote access, then you can do the upgrade remotely exactly as if you were sitting in front of the machine. =20 > In the past I have upgraded using CVSUP like this: >=20 > cvs_file contents: >=20 >=20 > *default host=3Dcvsup2.FreeBSD.org > *default base=3D/usr > *default prefix=3D/usr > *default release=3Dcvs > *default tag=3DRELENG_4 > *default delete use-rel-suffix > src-all > *default tag=3D. >=20 >=20 > cvsup -g -L 2 cvs_file > cd /usr/src > make buildworld > make buildkernel > make installkernel > make installworld > reboot Yup. Like I said, that usually works, but it can leave you in a world of hurt if it doesn't go smoothly. Oh --- you do need to run mergemaster somewhere in there too. =20 > Now I upgraded from 4.7 release to 4.8 stable and everything seems to have > been running fine for the past two weeks since I did so except on two > seperate occasions the server has completely frozen and been unresponsive > until my NOC did a forced reboot for me and everything came back to normal > with no signs of the problem in any log files. >=20 > Also RAM usage has been unusally high, so I am beginning to suspect that > maybe I messed something up by not using cvsup correctly. If anyone would > like to help enlighten me as to how important it is to be in single user > mode when installing the new kernel and world (there was no other users > logged in to the machine at the time) and what all else that I might have > done wrong I would greatly appreciate it. No. If the system boots and runs for several weeks, then it's exceedingly unlikely to be due to corrupted source code, or an improper procedure used when upgrading. Those tend to have a more immediate effect. I'd say you're running cvsup(1) etc. correctly, but that you were unlucky in the sources you pulled down when you chose to run cvsup(1). RELENG_4 aka 4.8-STABLE is still a development branch, and despite the best efforts of the committers sometimes mistakes creep in or new code doesn't react in quite the intended way. A good procedure is to cvsup a day or so in advance, and monitor the freebsd-stable@... list for any reports of problems before updating. It's also possible that the problems you're seeing are not related to your having upgraded at all. It may be just a coincidence that there has been some sort of hardware problem so close to when you updated, or you might be suddenly getting a surge in traffic which is pushing your machine over the edge. Cheers, Matthew --=20 Dr Matthew J Seaman MA, D.Phil. 26 The Paddocks Savill Way PGP: http://www.infracaninophile.co.uk/pgpkey Marlow Tel: +44 1628 476614 Bucks., SL7 1TH UK --EVF5PPMfhYS0aIcm Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.2.2 (FreeBSD) iD8DBQE+wMLKdtESqEQa7a0RAglCAJ96JmJvfzb8jMmvV5CTgpMi2liH+QCdGFcm uIFwHT+kTtK075AdmQas5DU= =Zwmb -----END PGP SIGNATURE----- --EVF5PPMfhYS0aIcm--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030513100250.GA52461>