2008-07-20 23:13:01 -04:00
|
|
|
Using OpenAFS in an OpenBSD environment
|
|
|
|
|
|
|
|
Some knob twiddling you may find useful:
|
|
|
|
|
|
|
|
1. Increase the default maximum number of open files in /etc/login.conf
|
|
|
|
for daemon to at least a few thousand.
|
|
|
|
|
|
|
|
:openfiles-cur=infinity:\
|
|
|
|
|
2008-10-11 20:12:07 -04:00
|
|
|
2. If you increase #1 above the default then consider also updating
|
2008-07-20 23:13:01 -04:00
|
|
|
kern.maxfiles in /etc/sysctl.conf:
|
|
|
|
|
|
|
|
kern.maxfiles=102400 # increase maximum files
|
|
|
|
|
|
|
|
3. Setting up kerberos authentication for users is accomplished by modifying
|
|
|
|
/etc/login.conf's auth-defaults line:
|
|
|
|
|
|
|
|
auth-defaults:auth=krb5-or-pwd,passwd,skey:
|
|
|
|
|
|
|
|
Please note if you have a local password and wish to login using that
|
|
|
|
instead of kerberos, you'll need to use 'username:passwd' to login.
|
|
|
|
|
|
|
|
To setup OpenAFS, you must first have a KerberosV realm setup. Below
|
|
|
|
are brief instructions to do so. See 'info heimdal' for further details.
|
|
|
|
|
2008-10-12 13:31:17 -04:00
|
|
|
Once the KerberosV realm is setup, run '${PREFIX}/sbin/openafs-setup'
|
2008-10-08 11:45:55 -04:00
|
|
|
to setup your first OpenAFS server in your cell.
|
2008-07-20 23:13:01 -04:00
|
|
|
|
2008-10-24 15:59:18 -04:00
|
|
|
Add the below to /etc/rc.local:
|
2008-10-08 11:45:55 -04:00
|
|
|
|
2008-10-12 13:31:17 -04:00
|
|
|
if [ -x ${PREFIX}/sbin/bosserver ]; then
|
2008-10-08 11:45:55 -04:00
|
|
|
echo -n " openafs"
|
2008-10-12 13:31:17 -04:00
|
|
|
PATH=${PREFIX}/bin:${PREFIX}/sbin:$PATH
|
2008-10-08 11:45:55 -04:00
|
|
|
|
2008-10-24 15:59:18 -04:00
|
|
|
# help this detach from console, proper fix is to properly daemonize!
|
|
|
|
sh -c "bosserver -log -syslog > /dev/null 2>&1 &"
|
|
|
|
|
|
|
|
# give the servers started by bosserver time to settle
|
|
|
|
# before attacking it with salvaging activity
|
|
|
|
sleep 10
|
|
|
|
|
2008-10-08 11:45:55 -04:00
|
|
|
# to salvage automatically on startup, for the paranoid
|
2008-10-24 15:59:18 -04:00
|
|
|
echo -n "(salvaging"
|
|
|
|
set -A volumes $(
|
|
|
|
vos listvol localhost -noauth 2> /dev/null| \
|
|
|
|
awk '
|
|
|
|
/ partition / { sub(":","",$9); part=$9; next; }
|
|
|
|
/R[OW].* K .*-line/ { printf "%s %s\n",part,$2; }'
|
|
|
|
)
|
|
|
|
|
|
|
|
# 20 dots total, adjust based on volume count
|
|
|
|
freq=$((${#volumes[*]}/20))
|
|
|
|
i=0
|
|
|
|
while [ i -lt ${#volumes[*]} ]
|
|
|
|
do
|
|
|
|
# progress by volume count
|
|
|
|
if [ $(((i/2)%freq)) -eq 0 ]; then
|
|
|
|
echo -n .
|
|
|
|
fi
|
|
|
|
part=${volumes[$i]}
|
|
|
|
let i=i+1
|
|
|
|
vid=${volumes[$i]}
|
|
|
|
let i=i+1
|
|
|
|
bos salvage localhost $part $vid -localauth > /var/tmp/$vid.log 2>&1
|
|
|
|
done
|
|
|
|
|
|
|
|
echo -n ")"
|
2008-10-08 11:45:55 -04:00
|
|
|
fi
|
|
|
|
|
2008-10-24 15:59:18 -04:00
|
|
|
Add the following to /etc/rc.shutdown:
|
2008-10-08 11:45:55 -04:00
|
|
|
|
2008-10-12 13:31:17 -04:00
|
|
|
if [ -x ${PREFIX}/bin/bos ]; then
|
|
|
|
${PREFIX}/bin/bos shutdown localhost -localauth -wait
|
2008-10-08 11:45:55 -04:00
|
|
|
sleep 1
|
|
|
|
pkill bosserver
|
|
|
|
fi
|
2008-07-20 23:13:01 -04:00
|
|
|
|
|
|
|
|
|
|
|
Quick Start Guide to KerberosV as needed by OpenAFS
|
|
|
|
---------------------------------------------------
|
|
|
|
|
|
|
|
For KerberosV setup, it is highly recommended to have some entries
|
|
|
|
in the DNS domain that you will use that is the lowercase equivalent
|
|
|
|
of your KerberosV realm name. If, for example, you had the domain
|
|
|
|
'example.com' you would have a realm of 'EXAMPLE.COM' and add the
|
|
|
|
following to the 'example.com' zone file:
|
|
|
|
|
|
|
|
_kerberos._udp SRV 0 0 88 kdc0
|
|
|
|
_kerberos._tcp SRV 0 0 88 kdc0
|
|
|
|
_kpasswd._udp SRV 0 0 464 kdc0
|
|
|
|
_kerberos-adm._tcp SRV 0 0 749 kdc0
|
|
|
|
_kerberos TXT "EXAMPLE.COM"
|
|
|
|
|
|
|
|
Setting a default krb5.conf is useful on all AFS clients and servers.
|
|
|
|
|
|
|
|
cd /etc/kerberosV
|
|
|
|
REALM=EXAMPLE.COM
|
|
|
|
cell=example.com
|
|
|
|
host=kdc0
|
|
|
|
sed 's/%host%/'$host'/g;s/%cell%/'$cell'/g;s/%REALM%/'$REALM'/g' \
|
2008-10-12 13:31:17 -04:00
|
|
|
< ${PREFIX}/share/examples/openafs/krb5.conf > krb5.conf
|
2008-07-20 23:13:01 -04:00
|
|
|
|
|
|
|
Create the heimdal directory:
|
|
|
|
|
|
|
|
mkdir -p 700 /var/heimdal
|
|
|
|
|
|
|
|
Initialize the basic key:
|
|
|
|
|
|
|
|
kstash --random-key
|
|
|
|
|
|
|
|
Initialize the Kerberos realm:
|
|
|
|
|
|
|
|
kadmin -l
|
|
|
|
kadmin> init EXAMPLE.COM
|
|
|
|
Max ticket life [1 day]:unlimited
|
|
|
|
Max renewable life [1 week]:unlimited
|
|
|
|
Principal expiration time [never]:
|
|
|
|
Password expiration time [never]:
|
|
|
|
Attributes []:
|
|
|
|
todd@EXAMPLE.COM's Password:
|
|
|
|
Verifying - todd@EXAMPLE.COM's Password:
|
|
|
|
kadmin> add todd/admin
|
|
|
|
Max ticket life [1 day]:
|
|
|
|
Max renewable life [1 week]:
|
|
|
|
Principal expiration time [never]:
|
|
|
|
Password expiration time [never]:
|
|
|
|
Attributes []:
|
|
|
|
todd/admin@EXAMPLE.COM's Password:
|
|
|
|
Verifying - todd/admin@EXAMPLE.COM's Password:
|
|
|
|
|
|
|
|
.. do this last part per KerberosV client and server:
|
|
|
|
|
|
|
|
kadmin> add --random-key host/kdc0.example.com
|
|
|
|
Max ticket life [1 day]:unlimited
|
|
|
|
Max renewable life [1 week]:unlimited
|
|
|
|
Principal expiration time [never]:
|
|
|
|
Password expiration time [never]:
|
|
|
|
Attributes []:
|
|
|
|
kadmin> ext host/kdc0.example.com
|
|
|
|
kadmin> quit
|
|
|
|
|
|
|
|
On the server run:
|
|
|
|
|
|
|
|
/usr/libexec/kdc &
|
|
|
|
|
|
|
|
Verify authentication works:
|
|
|
|
|
|
|
|
kinit todd
|
|
|
|
todd@EXAMPLE.COM's Password:
|
|
|
|
klist
|
|
|
|
Credentials cache: FILE:/tmp/krb5cc_1000
|
|
|
|
Principal: todd@EXAMPLE.COM
|
|
|
|
|
|
|
|
Issued Expires Principal
|
|
|
|
Jul 20 22:10:41 Aug 30 22:10:41 krbtgt/EXAMPLE.COM@EXAMPLE.COM
|
|
|
|
|
|
|
|
Permit network based kerberos administration:
|
|
|
|
|
|
|
|
/usr/libexec/kadmind &
|
|
|
|
|
|
|
|
Setup the acl file:
|
|
|
|
|
|
|
|
Put the following into /var/heimdal/kadmind.acl:
|
|
|
|
|
|
|
|
todd/admin@EXAMPLE.COM all
|
|
|
|
|
|
|
|
Make sure things startup properly upon reboot:
|
|
|
|
|
|
|
|
Put the following into /etc/rc.conf.local:
|
|
|
|
|
|
|
|
krb5_master_kdc=YES
|