* Index
-------------------------
INTRODUCTION
Perhaps you want to test the latest bleeding-edge release of the
Apache [1] webserver. Or maybe you would like to let some friends host
a website on your production system without letting them near your
pristine configuration. Maybe you are paranoid and like to keep each
application seperate from each other to minimise potential security
problems. Whatever your intentions for setting up a _chroot jail_, the
last thing you need is to spend hours configuring each jailed
environment. Enter Debian [2] installed in a chroot jail - all the
power and ease of Debian [3] in the secure jail you demand!
-------------------------
PLANNING
You need to have a clear idea of what you intend on achieving before
you begin. This example will focus on running a webserver from the
Debian [4] distribution, to be administered by a friend who we don't
trust enough to have an account on the host system.
GOALS
Our goals for the purpose of this example will be to:
* Install and configure a webserver with supporting software (PHP
[5], MySQL [6])
* Install supporting services to allow maintenance by our friend
(SSH [7], WebDav [8]).
LAYOUT
Layout on the host system is non-consequental for operation of the
jail, but careful planning will save you effort in the long-term. It
makes sense to keep things laid out in a logical manner by keeping
like things together. The basic purpose of chroot is to provide a
filesystem sandbox, that is to remap one directory to be the root
directory (/) for the chroot'ed program.
To this end, I suggest you keep all chroot'ed jail directories in a
common location. I like to use /CHROOT/__/ where _systemname_ is a
basic description of what the chroot jail is for.
-------------------------
STARTING OUT
CREATE THE HOST DIRECTORY
mkdir /chroot/webserver
INSTALL DEBOOTSTRAP
apt-get install debootstrap / up2date install debootstrap / ...
INSTALL THE BASE SYSTEM
debootstrap --arch i386 woody /chroot/webserver
-------------------------
USING YOUR CHROOT JAIL
ROOT SHELL
chroot /chroot/webserver /bin/bash chroot /chroot/webserver su -
-------------------------
UPGRADING TO DEBIAN TESTING
APT-GET FOR BEGINNERS
vi /etc/apt/sources.list apt-get update apt-get dist-upgrade
-------------------------
INSTALLING SOFTWARE
WEBSERVER
apt-get install apache php4 mysql-server
SYSTEM ADMINISTRATION
apt-get install ssh vi /etc/ssh/sshd_config /etc/init.d/ssh restart
ADDING USER ACCOUNTS
vi /etc/adduser.conf adduser bob su - bob usermod -G www-data bob
adduser sally usermod -G www-data sally ...
-------------------------
Bother! I'm due to go out 30 minutes ago, and this is nowhere near
finished! Check back soon to see the rest of the howto... untill then,
adios! -- TysonClugg [9].
Links:
------
[1] http://melbournewireless.org.au/?Apache
[2] http://melbournewireless.org.au/?Debian
[3] http://melbournewireless.org.au/?Debian
[4] http://melbournewireless.org.au/?Debian
[5] http://melbournewireless.org.au/?PHP
[6] http://melbournewireless.org.au/?MySQL
[7] http://melbournewireless.org.au/?SSH
[8] http://melbournewireless.org.au/?WebDav
[9] http://melbournewireless.org.au/?TysonClugg
[EditText] [Spelling] [Current] [Raw] [Code] [Diff] [Subscribe] [VersionHistory] [Revert] [Delete] [RecentChanges]
Node Statistics | |
---|---|
building | 132 |
gathering | 193 |
interested | 515 |
operational | 233 |
testing | 214 |