General Purpose App Server

Hardware

| Type | Make | Model | Connector | Specs | || | Motherboard |   | Xeon | Dual Xeon Slot |   | | CPU | Intel | Pentium III Xeon | Slot | 550MHz | | CPU | Intel | Pentium III Xeon | Slot | 550MHz | | RAM | Kingston |   |   | 256MB ECC | | HDD | IBM |   | SCSI | 9GB | | HDD | IBM |   | SCSI | 9GB | | Graphics Adapter | Diamond | [FireGL][1][?][1] 1000 Pro 8MB AGP | AGP | 8MB 100MHz SGRAM 8ns | | SCSI Controller | Adaptec | AIC-7880 | PCI? |   | | SCSI Raid Adapter | Adaptec | ARO-1130C | PCI? | 16MB | | CD-ROM | NEC |   | SCSI |

Plan

  • Create jails for mail, www and (probably) dns

[ToDo][2][?][2]

  • Get fan for [CPUs][3][?][3]
  • http://memberwebs.com/nielsen/freebsd/jails/docs/jail_security.html
  • create CA and sign certs
  • create proper file permission hierarchy for cert access
  • set soft_bounce in main.cf to NO
  • add local net back to mynetworks in main.cf
  • remove ALL unused accounts
  • run dovecot-auth as user dovecot-auth instead of root
  • set dovecot first_valid_uid & last_valid_uid to dovecot user UID
  • set dovecot listen to localhost only. disallow remote non-SSL imap

Log

Earlier

Check Adaptec RAID support
create generic kernel
serial console

/etc/ttys
    options  CONSPEED=115200

boot console

/boot.config: -P
    /boot/loader.conf: console="comconsole"

create custom kernel

build custom boot blocks

setup panic debugging

minor change: KDB_UNATTENDED
    set dumpdev
    set savecore_flags="-z"

jail config

reconfigure daemons

add dual PIII 550

breaking off heatsink fins

build SMP kernel

options SMP
    device apic

2006-04-12

Updated to [FreeBSD][4][?][4] 6-STABLE branch. http://www.freebsd.org/doc/en/books/handbook/makeworld.html

Fill in: [CVSup][5][?][5] config, make.conf

# cd /usr/src
# make -j4 buildworld && make buildkernel

Ran buildworld overnight.

2006-04-13

Powered itself off overnight. Don't know why.
Finished upgrade to 6-STABLE
Rebooted, SMP working
Started creation of jails
http://www.onlamp.com/pub/a/bsd/2003/09/04/jails.html

# export JAILDIR=/chroot/test
# cd /chroot
# mkdir test mail
# cd /usr/src
# make -j6 buildworld
# make installworld DESTDIR=$JAILDIR

http://www.section6.net/wiki/index.php/Creating_a_FreeBSD_Jail

# make world DESTDIR=/chroot/test
# sockstat|grep "\*:[0-9]"
# vim /etc/rc.conf
syslogd_flags="-s -s"
syslogd_flags="-a $local_ip"

Beeped lots then powered off
Burnt finger on CPU heatsinks. OK. I get it now.
No CPU fan, dual PIII definitely needs one.

2006-04-14

http://www.section6.net/wiki/index.php/Creating_a_FreeBSD_Jail

Created minimal make.conf.jail

# cd /usr/local/etc
# cp /etc/make.conf make.conf.jail
# vim make.conf.jail
...disable lots of things...

I disabled everything except for:

CRYPT
DYNAMICROOT
INET6
LIBC_R
LIBPTHREAD
LIBTHR
OPENSSL
SHARE
SHARED

This is a production jail, so no toolchain, no docs. Only the bare essentials.

Backup host make.conf and copy the jail one over it.

# cp /etc/make.conf /etc/make.conf.bak
# cp /usr/local/etc/make.conf.jail /etc/make.conf

Remember to copy it back afterwards.

Clean, then buildworld:

# cd /usr/obj
# chflags -R noschg *
# rm -rf *
# cd /usr/src
# make -j4 buildworld

Meanwhile, still following section6wiki:

# cd $JAILDIR
# mkdir etc dev usr
# cp /etc/resolv.conf etc/resolv.conf
# cp /etc/rc.conf etc/rc.conf
# vim rc.conf
...edit stuff, hostname, ip...
# mount_devfs devfs $JAILDIR/dev # a bit preemptive perhaps?
# devfs -m $JAILDIR/dev rule -s 4 applyset
# ln -s dev/null kernel

Build finished so install:

# cd /usr/src
# make installworld DESTDIR=$JAILDIR
# cd etc
# make distribution DESTDIR=$JAILDIR NO_OPENSSH=YES
# cd $JAILDIR
# touch etc/fstab

Create alias manually for now. It's added to rc.conf further on.

# ifconfig xl0 $jail_ip netmask 255.255.255.0 alias

Restore make.conf, append jail config to rc.conf:

# cd /etc
# cp make.conf.bak make.conf
# cat >> rc.conf
jail_enable="YES"
jail_list="test"
jail_set_hostname_allow="NO"
jail_socket_unixiproute_only="YES"
jail_test_rootdir="/chroot/test"
jail_test_hostname="test.niggurath.local"
jail_test_ip="$jail_ip"
jail_test_exec_start="/bin/sh /etc/rc"
jail_test_devfs_enable="YES"
jail_test_devfs_ruleset="devfsrules_jail"
ifconfig_xl0_alias0="inet $jail_ip netmask 255.255.255.0"
^D
#

Quick test run:

# jail $JAILDIR test.niggurath.local $jail_ip /bin/sh /etc/rc
# jexec $JID /bin/sh

2006-04-16

Create postfix and dependent packages (See Mail):

http://www.onlamp.com/pub/a/bsd/2003/08/07/FreeBSD_Basics.html

# cd /usr/ports/mail/postfix
# make
... select options...
(enabled BerkeleyDB (latest), TLS, LDAP, SPF)
# mkdir /usr/ports/packages
# make package-recursive
...answer questions...

I *might* use LDAP to store user accounts and authentication details on the network. We'll see.

For some reason I can't mount nullfs or unionfs on Niggurath. Perhaps something to do with gmirror? Haha, retard. securelevel of host was 1, so the nullfs kernel module couldn't be loaded.

Change Niggurath host securelevel to -1 AND autoload nullfs.ko:

# cat >> /etc/rc.conf
kern_securelevel="-1"
kern_securelevel_enable="YES"
^D
# echo 'nullfs_load="YES"' >> /boot/loader.conf

Reboot, or shutdown/exit or whatever in order to change the securelevel

Now load ports over the jail ports directory and install postfix:

# mount_nullfs /usr/ports $JAILDIR/usr/ports
# jexec 1 /usr/local/bin/bash
[#] cd /usr/ports/packages/mail
[#] pkg_add ./postfix-2.2.5,1.tbz
You need user "postfix" added to group "mail".
Would you like me to add it [y]? y
Would you like to activate Postfix in /etc/mail/mailer.conf [n]? y

http://www.csua.berkeley.edu/~ranga/notes/freebsd_postfix.html

Set in $JAILDIR/etc/rc.conf:

sendmail_enable="YES"
sendmail_flags="-bd"
sendmail_pidfile="/var/spool/postfix/pid/master.pid"
sendmail_procname="/usr/local/libexec/postfix/master"
sendmail_outbound_enable="NO"
sendmail_submit_enable="NO"
sendmail_msp_queue_enable="NO"

2006-04-17

http://www.postfix.org/INSTALL.html#replace
(Note that config is in $JAILDIR/usr/local/etc/postfix)

Set domain names for all servers to *.phase1 to make it easy to grep.

# vim $JAILDIR/etc/rc.conf
jail_test2_hostname="mail.phase1"

Other files changed: /etc/hosts /etc/resolv.conf

Change the jail ip address.
Fix interface alias:

# jexec $JAIL_ID kill -TERM -1
# ifconfig xl0 -alias $jail_ip
# ifconfig xl0 alias $new_jail_ip netmask 255.255.255.0
# export jail_ip=$new_jail_ip

Restart the jail:

#jail $JAILDIR mail.phase1 $jail_ip /bin/sh /etc/rc

Now back to postfix configuration.
The original configuration didn't start postfix. New rc config options are here:
http://www.freebsddiary.org/postfix.php

Set in $JAILDIR/etc/rc.conf:

postfix_enable="YES"
sendmail_enable="NO"
sendmail_outbound_enable="NO"
sendmail_submit_enable="NO"
sendmail_msp_queue_enable="NO"

Created and updated periodic.conf

# cat >> $JAILDIR/etc/periodic.conf
daily_clean_hoststat_enable="NO"
daily_status_mail_rejects_enable="NO"
daily_status_include_submit_mailq="NO"
daily_submit_queuerun="NO"
^D

No mailwrapper, so fix the sendmail link and link the startup script
http://www.csua.berkeley.edu/~ranga/notes/freebsd_postfix.html

# cd $JAILDIR/usr/sbin
# ln -s ../local/sbin/sendmail sendmail
# cd $JAILDIR/usr/local/etc/rc.d
# ln -s ../../sbin/postfix postfix.sh

Forgot to generate /etc/aliases.db:

[#] /usr/local/bin/newaliases

2006-04-19

Gah. Ok, I should have built Postfix with SASL. (Not much point in having encryption (TLS) without no authentication (SASL) to protect.

No special build steps should be necessary. Maaaybe cyrus-sasl2-ldapdb. But that can be installed later. To rebuild the Postfix port, including SASL this time:

# cd /usr/ports/mail/postfix
# make clean
# make
...this time select
SASL2
TLS
DB43 (just in case. so I have a fallback if LDAP is too much of a pain)
OpenLDAP
VDA (it has quotas)

Once compiled you may have to uninstall existing packages with pkg_delete.

Build the updated packages:

# cd /usr/ports/mail/postfix
# make package-recursive
# cd /usr/ports/security/cyrus-sasl2-saslauthd/
# make package-recursive

Install in the jail:

# jexec $JID /bin/sh
[#] pkg_delete postfix-2.2.5,1
[#] cd /usr/ports/packages/All
[#] pkg_add postfix-2.2.5,1.tbz
[#] pkg_add cyrus-sasl2-saslauthd

Back to configuration.
http://wanderingbarque.com/howtos/mailserver/mailserver.html

Create the vmail user, with home at /vmail and no login shell

[#] pw useradd vmail -m -d /vmail -s /usr/sbin/nologin
[#] cd /vmail
[#] rm -rf .*
[#] mkdir domains
[#] chown vmail:vmail domains

No particular reason for choosing /vmail. It's just simple.

http://yocum.org/faqs/postfix-tls-sasl.html

# cd $JAILDIR/usr/local/lib/sasl2/
# echo "pwcheck_method: saslauthd" > smtpd.conf
# mkdir deactivated
# mv *ntlm* *crammd5* deactivated

Create cert for mail.phase1
http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/openssl.html

# mkdir $JAILDIR/etc/certs
# cd $JAILDIR/etc/certs
# openssl req -new -x509 -nodes -out mailkey.pem -keyout mailcert.pem -days 3650
# cd ..
# chmod -R 700 certs




# cat >> $JAILDIR/usr/local/etc/postfix/main.cf

# SASL authentication - added by root - 2006/04/19
broken_sasl_auth_clients = yes
smtpd_sasl_auth_enable = yes
smtpd_sasl_local_domain =

smtpd_sender_restrictions = permit_sasl_authenticated, permit_mynetworks, reject_unauth_destination

# tls config
smtp_use_tls = yes
smtpd_use_tls = yes
smtp_tls_note_starttls_offer = yes
smtpd_tls_key_file = /etc/certs/keycert.pem
smtpd_tls_cert_file = /etc/certs/keycert.pem
smtpd_tls_CAfile = /etc/certs/keycert.pem
smtpd_tls_loglevel = 1
smtpd_tls_received_header = yes
smtpd_tls_session_cache_timeout = 3600s
tls_random_source = dev:/dev/urandom

saslauthd failed with unable to dlopen /usr/local/lib/sasl2/libgssapiv2.so: Shared object "libgssapi.so.8" not found, required by "libgssapiv2.so"

Have to rebuild without Kerberos this time.

# jexec $JID /usr/sbin/pkg_delete cyrus-sasl2-saslauthd-2.1.21
# cd /usr/ports/security/cyrus-sasl2-saslauthd/
# make WITH_OPENLDAP_VER=22 WITHOUT_GSSAPI= package
# jexec $JID /bin/sh
[#] /usr/sbin/pkg_add cyrus-sasl2-saslauthd-2.1.21
[#] saslauthd -a getpwent
[#] postfix reload

getpwent will be replaced with LDAP once implemented.

# vim $JAILDIR/usr/local/etc/postfix/master.cf
...uncomment...
submission   inet    n       -       n       -       -       smtpd
    -o smtpd_etrn_restrictions=reject
    -o smtpd_enforce_tls=yes -o smtpd_sasl_auth_enable=yes@@

2006-04-20

I updated ports with cvsup and updated postfix:

# cd /usr/ports/mail/postfix
# make package
# make deinstall && make reinstall
# jexec $JID /bin/sh
[#] cd /usr/ports/packages/All
[#] pkg_delete postfix-2.2.5,1
[#] pkg_add postfix-2.2.10_1,1.tbz

Installing Dovecot (1.0.beta3):

# cd /usr/ports/mail/dovecot
# make package-recursive
...select
KQUEUE
SASL2
LDAP

[GnuTLS][8][?][8] was removed from Dovecot as it was broken. Falls back to [OpenSSL][9][?][9] instead. Fine by me. Auto-creates user and group dovecot.

Then it broke. I think because older versions of libiconv and cyrus-sasl were already installed (by postfix). So build just the dovecot package:

# make package

Then it worked.

[#] pkg_add /usr/ports/packages/All/dovecot-1.0.b3_1.tbz

Add dovecot-auth user and group

[#] pw useradd dovecot-auth -n "Dovecot Auth" -m -d /usr/local/libexec/dovecot -s /usr/sbin/nologin

Actually this produced the error: pw: invalid character ` ' at position 7 in userid/group name, so I added the user with sysinstall...

Configure Dovecot. Enable imap and imaps. imap accepts connections from the local network, imaps from anywhere. The firewall must protect from outside access to imap.

# cd $JAILDIR/usr/local/etc
# cp dovecot-example.conf dovecot.conf
# vim dovecot.conf

dovecot.conf:

protocols = imap imaps
# must be guarded by firewall!
listen = *
ssl_listen = *
ssl_disable = no
ssl_cert_file = /etc/certs/mailcert.pem
ssl_key_file = /etc/certs/mailkey.pem
login_user = dovecot
login_process_size = 64
login_max_processes_count = 32
login_greeting = Welcome.
max_mail_processes = 128
verbose_proctitle = yes
# allow test user and dovecot
first_valid_uid = 1002
last_valid_uid = 1003
# allow test user group and dovecot group
first_valid_gid = 1002
last_valid_gid = 1003
mail_extra_groups = mail
valid_chroot_dirs = /vmail/domains
default_mail_env = maildir:/vmail/domains/%d/%n
# no mbox (thunderbird), no OSX Mail or Outlook Express
protocol imap {
  imap_client_workarounds = outlook-idle netscape-eoh
}
auth default {
  # plain for testing only. can't use digest-md5 with pam
  mechanisms = plain
  # for testing purposes, until LDAP is working
  passdb pam {
  }
  userdb passwd {
  }
  user = root
}

Enable dovecot at boot:

# cat > $JAILDIR/etc/rc.conf
dovecot_enable="YES"
^D

OK. Well, no quota support. Perhaps dump dovecot in favour of Courier...


2006-04-22

Now on to the DNS/LDAP server!

Create new jail (I'm so lazy):

# export JD=/chroot/dns
# export JIP=$jail_ip
# cp -Rp /chroot/mail $JD
# rm -rf $JD/dev  # oops!
# vim $JD/etc/rc.conf
...leave the sendmail disable stuff there
# mount_nullfs /usr/ports $JD/usr/ports
# mount_devfs devfs $JD/dev
# devfs -m $JD/dev rule -s 4 applyset
# ifconfig xl0 alias $JIP netmask 255.255.255.0
# jail $JD dns.phase1 $JIP /bin/sh /etc/rc
# jexec $JID pkg_delete -a   # delete all
#   # clean up the rest manually

Now install djbdns:

# cd /usr/ports/dns/djbdns
# vim Makefile
...comment out the NO_PACKAGE line...
# vim /usr/ports/sysutils/ucspi-tcp/Makefile
...comment out the NO_PACKAGE line...
# vim /usr/ports/sysutils/daemontools/Makefile

This is just an annoyance, we're creating packes to install in our own damn jail, ffs!

# make config-recursive
# make package-recursive
...select options
IPV6 # sugar-coating to make IPv6 records easier to specify

I always prefer to run the config step separately.

2006-04-24

Back to dovecot for a moment. Forgot to enable it on boot:

# export JD=/chroot/mail
# cat >> $JD/etc/rc.conf
dovecot_enable="YES"
saslauthd_enable="YES"
^D

Now on with djbdns. Install and configure.
http://www.lifewithdjbdns.com/#Setting%20up%20tinydns

[#] jexec $JID /bin/sh
[#] pkg_add /usr/ports/packages/All/djbdns-ipv6-1.05.b14_10.tbz
[#] pw useradd tinydns -s /usr/sbin/nologin -c "TinyDNS Owner"
[#] pw useradd dnslog -s /usr/sbin/nologin -c "DNS Log owner"
[#] tinydns-conf tinydns dnslog /usr/local/etc/tinydns $JIP
[#] mkdir -p /var/log/tinydns
[#] chown dnslog:dnslog /var/log/tinydns

Set the log directory in /usr/local/etc/tinydns/log/run

# vim $JD/usr/local/etc/tinydns/log/run
:s%./main%/var/log/tinydns%
:wq

Configure DNS data and start tinydns

# cat > $JD/usr/local/etc/tinydns/root/data

#define the authoritative nameserver
.phase1::ns1.phase1
#mail exchanger
@phase1::mail.phase1
=mail.phase1:192.168.1.203
#dns1 is also known as ns1
=dns1.phase1:192.168.1.204
+ns1.phase1:192.168.1.204
=www.phase1:192.168.1.205
^D

Compile data and start tinydns

[#] cd /usr/local/etc/tinydns/root
[#] make
[#] mkdir -p /var/service
[#] ln -s ../../usr/local/etc/tinydns /var/service

Use relative links so they work in and outside the jail.

Start daemontools at boot:
http://matt.simerson.net/computing/dns/djbdns-freebsd.shtml

# cat >> $JD/etc/rc.conf
svscan_enable="YES"

2006-04-25

Configure tinydns so prevent lame DNS lookups. This is very important!

# cat > $JD/usr/local/etc/tinydns/root/data
# RFC1918 - prevent pollution
.local::ns1.phase1   # not RFC1918, but useful anyway
.10.in-addr.arpa::ns1.phase1
.168.192.in-addr.arpa::ns1.phase1
.16.172.in-addr.arpa::ns1.phase1
.17.172.in-addr.arpa::ns1.phase1
.18.172.in-addr.arpa::ns1.phase1
.19.172.in-addr.arpa::ns1.phase1
.20.172.in-addr.arpa::ns1.phase1
.21.172.in-addr.arpa::ns1.phase1
.22.172.in-addr.arpa::ns1.phase1
.23.172.in-addr.arpa::ns1.phase1
.24.172.in-addr.arpa::ns1.phase1
.25.172.in-addr.arpa::ns1.phase1
.26.172.in-addr.arpa::ns1.phase1
.27.172.in-addr.arpa::ns1.phase1
.28.172.in-addr.arpa::ns1.phase1
.29.172.in-addr.arpa::ns1.phase1
.30.172.in-addr.arpa::ns1.phase1
.31.172.in-addr.arpa::ns1.phase1
^D

This makes tinydns authoritative for all [RFC1918][10][?][10] addresses (private IP blocks). Setting up dnscache to consult tinydns for these IP blocks then prevents reverse-lookups being leaked to the internet.

It's fine to have these globally visible because there shouldn't be any DNS records (A, AAAA, MX or whatever) for these [IPs][11][?][11] in a public auth DNS. If there are, remote clients can get information about hidden hosts.

Setting up dnscach to consult the auth DNS for [RFC1918][10][?][10] addresses:
Creating a file containing the IP of the auth DNS for each block:

# cd /var/service/dnscache/root/servers
# echo "192.168.1.204" > local
# cp local 168.192.in-addr.arpa
# cp local 10.in-addr.arpa::ns1.phase1
# for i in 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
> do cp 168.192.in-addr.arpa $i.172.in-addr.arpa
> done
#