Untuntu-Install-Kerberos-Server
准备
修改主机名为 krb.example.com
/etc/hosts配置:
127.0.0.1 localhost
10.1.25.31 krb.example.com krb
安装服务
sudo apt install krb5-{admin-server,kdc}
安装过程选项如下:
Default Kerberos version 5 realm? EXAMPLE.COM
Kerberos servers for your realm: krb1.example.com
Administrative server for your Kerberos realm: krb1.example.com
安装配置
设置REALM
执行sudo krb5_newrealm,设置REALM。
选项如下:
This script should be run on the master KDC/admin server to initialize
a Kerberos realm. It will ask you to type in a master key password.
This password will be used to generate a key that is stored in
/etc/krb5kdc/stash. You should try to remember this password, but it
is much more important that it be a strong password than that it be
remembered. However, if you lose the password and /etc/krb5kdc/stash,
you cannot decrypt your Kerberos database.
Loading random data
Initializing database '/var/lib/krb5kdc/principal' for realm 'EXAMPLE.COM',
master key name 'K/M@EXAMPLE.COM'
You will be prompted for the database Master Password.
It is important that you NOT FORGET this password.
Enter KDC database master key: PASSWORD
Re-enter KDC database master key to verify: PASSWORD
配置
编辑/etc/krb5.conf
[domain_realm]
...
.example.com = EXAMPLE.COM
example.com = EXAMPLE.COM
...
[logging]
kdc = FILE:/var/log/kerberos/krb5kdc.log
admin_server = FILE:/var/log/kerberos/kadmin.log
default = FILE:/var/log/kerberos/krb5lib.log
创建目录文件:
sudo mkdir /var/log/kerberos
sudo touch /var/log/kerberos/{krb5kdc,kadmin,krb5lib}.log
sudo chmod -R 750 /var/log/kerberos
重启服务:
sudo systemctl restart krb5-kdc
sudo systemctl restart krb5-admin-server
安装测试
执行sudo kadmin.local,进入本地管理员交互程序。
如下:(listprincs命令列出所有主体;quit命令退出交互程序)
sudo kadmin.local
Authenticating as principal root/admin@EXAMPLE.COM with password.
kadmin.local: listprincs
K/M@EXAMPLE.COM
kadmin/admin@EXAMPLE.COM
kadmin/changepw@EXAMPLE.COM
kadmin/krb1.EXAMPLE.COM@EXAMPLE.COM
krbtgt/EXAMPLE.COM@EXAMPLE.COM
kadmin.local: quit
访问权利
启用管理员用户的所有访问权利。
编辑/etc/krb5kdc/kadm5.acl,添加:
*/admin *
重启服务:
sudo systemctl restart krb5-admin-server
Kerberos策略(policies)
增加4个策略,规定最小密码长度和最少包含几种字符类型
sudo kadmin.local
Authenticating as principal root/admin@EXAMPLE.COM with password.
kadmin.local: add_policy -minlength 8 -minclasses 3 admin
kadmin.local: add_policy -minlength 8 -minclasses 4 host
kadmin.local: add_policy -minlength 8 -minclasses 4 service
kadmin.local: add_policy -minlength 8 -minclasses 2 user
kadmin.local: quit