index: better intro
[openafs-wiki.git] / KerberosAFSInstall.mdwn
1 # <a name="Installing Kerberos  AFS"></a> Installing Kerberos &amp; AFS
2
3 <div>
4   <ul>
5     <li><a href="#Installing Kerberos  AFS"> Installing Kerberos &amp; AFS</a><ul>
6         <li><a href="#Basics"> Basics</a></li>
7         <li><a href="#OpenAFS"> OpenAFS</a><ul>
8             <li><a href="#Starting the Install"> Starting the Install</a></li>
9             <li><a href="#Create AFS Keys and Administrato"> Create AFS Keys and Administrators</a><ul>
10                 <li><a href="#KerberosVMIT"> KerberosVMIT</a></li>
11                 <li><a href="#HeimdalKTH"> HeimdalKTH</a></li>
12                 <li><a href="#KTH Kerberos4"> KTH Kerberos4</a></li>
13               </ul>
14             </li>
15             <li><a href="#Finishing _OpenAFS installation"> Finishing OpenAFS installation</a></li>
16           </ul>
17         </li>
18         <li><a href="#Setting up Transparent Login"> Setting up Transparent Login</a></li>
19       </ul>
20     </li>
21   </ul>
22 </div>
23
24 AFS includes its own implementation of Kerberos, the KAServer. However, new installs of KAServer are not recommended as it is based on a draft version of the obsolete Kerberos 4 protocol. Even though AFS doesn't support [[KerberosV]] directly, it is highly recommended that you set up a [[KerberosV]] realm for your AFS cell and **not** install the KAServer. See [[KerberosV]] for the many advantages of using the latest Kerberos for your network authentication.
25
26 Note that this document is under development. Also, I don't try to explain the [[OpenAFS]] specific parts of the install -- This document describes only the changes that have to be made to create a new [[OpenAFS]] cell with [[KerberosV]] authentication. If you have followed these instructions and are still having problems please email the openafs-info mailing list.
27
28 Derrick wrote nice pages at: <http://www.cs.cmu.edu/afs/andrew.cmu.edu/usr/shadow/www/afs/afs-with-kerberos.html> <http://www.contrib.andrew.cmu.edu/~shadow/afs/afs-with-kerberos.html>
29
30 Deniz Kanca [posted](https://lists.openafs.org/pipermail/openafs-info/2003-January/007799.html) her notes at [http://www.arayan.com/da/yazi/OpenAFS\_Kerberos\_5.html](http://www.arayan.com/da/yazi/OpenAFS_Kerberos_5.html).
31
32 Jeffrey Hutzelman posted a good [summary](https://lists.openafs.org/pipermail/openafs-info/2003-July/010159.html) of all these component to [[OpenAFS]]-info on 25-Jul-2003. Be sure to check to follow-ups for some minor clarifications.
33
34 ## <a name="Basics"></a> Basics
35
36 To continue, you need a working Kerberos realm. See [[SettingUpAuthentication]] for the implementation options, and refer to the documentation that comes with your particular version of Kerberos to establish your realm. It is easiest if your realm name is the caps version of your cell name, which in turn is the same as your site's domain name. For example if your site's domain is 'greekmythology.com', your Kerberos realm name should be 'GREEKMYTHOLOGY.COM' and your AFS cell name should be 'greekmythology.com'. See [[KerberosTerms]] if you are confused on what a "realm" is.
37
38 Once you have a working Kerberos realm, ie. you can "kinit" as yourself and receive valid Kerberos tickets, you are ready to continue on installing [[OpenAFS]]. (NOTE: If you are working on the Red Hat Linux platform, there is an RPM available that may ease your pain considerably. See [[LinuxAFSInstall]].)
39
40 ## <a name="OpenAFS"></a> [[OpenAFS]]
41
42 ### <a name="Starting the Install"></a> Starting the Install
43
44 Now we will begin the [[OpenAFS]] installation. The relevant part of the [[OpenAFS]] documentation can be found at [OpenAFS installation documentation](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ17). Follow the instructions in [Creating AFS Directories](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#Header_32) and begin the [Platform Specific Procedures](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ20) as appropriate for your operating system. **SKIP** the "Enabling AFS Login" section of your operating system's instructions. Also note that you may need to reboot during this procedure (particularly on Solaris).
45
46 Now you are ready to continue on to [Starting the BOS Server](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ50) (... someone want to chime in here and explain how one can use pt\_util etc to do this part without running in -noauth??). Proceed to [Defining Cell Name](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ51). During the [Starting Database Servers](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ52) section, **do not** issue the <code>**bos create**</code> command to add the kaserver.
47
48 ### <a name="Create AFS Keys and Administrato"></a> Create AFS Keys and Administrators
49
50 First you will need to create a principal "afs" or "afs/greekmythology.com" in your [[KerberosV]] database. The latter is the preferred alternative, especially if you will support more than one [[AFSCell]] with a single [[KerberosRealm]]. In case you have [[KerberosIV]], create afs or afs.greekmythology.com respectively.
51
52 Your [[KerberosV]] realm must support krb524 for aklog to work, typically. In other words, it has to be able to respond to your version 4 requests (as AFS is based on [[KerberosIV]] protocol).
53
54 Next we will create an AFS [[KeyFile]] and an administrator principal in the Kerberos database. The procedure for creating an AFS [[KeyFile]] depends on which Kerberos implementation you have chosen to use, but the logic is the same.
55
56 Things to remember about AFS [[KeyFile]]: they must contain a key using the des-cbc-crc encryption type and the key must have exactly same kvno as the afs/greekmythology.com@GREEKMYTHOLOGY.COM in the Kerberos database. If cell is same as lowercased GREEKMYTHOLOGY.COM name, you can create <afs@GREEKMYTHOLOGY.COM> instead of afs/cell@GREEKMYTHOLOGY.COM.
57
58 #### <a name="KerberosVMIT"></a> [[KerberosVMIT]]
59
60 - set up krb524d. You will need to make sure your krb524d server host includes something like this in krb5.conf. Only one of the 2 entries should be needed for a realm, depending on how you did the setup in your [[KerberosV]] database.
61
62     [appdefaults]
63     afs_krb5 = {
64           REALM.NAME = {
65                     afs = false
66                     afs/cell.name = false
67           }
68     }
69
70 - use <code>**kadmin get**</code> command and <code>**ktutil copy**</code> similarly as described in section Heimdal to create afs key in a database or use for the last step instead of ktutil <code>**asetkey**</code> as below
71
72 - The AFS-Kerberos5 migration kit includes a program <code>**asetkey**</code>
73
74 Save the AFS key from kerberos KDC to a file, possibly using kadmin(see KTH [[KerberosIV]] section above), and the use either <code>**asetkey**</code> or use <code>**ktutil**</code> (see [[HeimdalKTH]] section below) to convert the format and save into [[KeyFile]].
75
76            asetkey add 0 /etc/srvtab.afskey afs.cell@REALM
77
78 The \`0' above means kvno (key version number 0). Use ktutils list or similar like <code>**kadmin get**</code> command to see, what kvno has the afs key in Kerberos database. Use exactly same number when running <code>**asetkey**</code>. There's
79
80 #### <a name="HeimdalKTH"></a> [[HeimdalKTH]]
81
82 - <http://www.pdc.kth.se/heimdal>
83 - kdc will service krb524 requests
84 - edit /etc/krb5.conf similar to the example below
85
86     [logging]
87     default = FILE:/var/log/krb5libs.log
88     kdc = FILE:/var/log/krb5kdc.log
89     admin_server = FILE:/var/log/kadmind.log
90
91     [ktutil]
92             dns_lookup_realm = false
93             dns_lookup_kdc = false
94
95     [libdefaults]
96             dns_lookup_realm = false
97             dns_lookup_kdc = false
98             ktype_is_etype = true
99             encrypt = yes
100             forward = yes
101             srv_lookup = no
102             srv_try_txt = no
103             srv_try_rfc2052 = no
104             default_realm = GREEKMYTHOLOGY.COM
105             clockskew = 300
106             kdc = 127.0.0.1
107             v4_instance_resolve = true
108             krb4_get_tickets = yes
109             forwardable = true
110             v4_name_convert = {
111                     host = {
112                             rcmd = host
113                             ftp = ftp
114                     }
115                     plain = {
116                             something = something-else
117                     }
118             }
119
120     [realms]
121             GSF.DE = {
122                     kdc = 127.0.0.1
123                     admin_server = 127.0.0.1
124                     krb525_server = 127.0.0.1
125                     v4_name_convert = {
126                             ftp = ftp
127                             pop = pop
128                             rcmd = host
129                     }
130                     v4_instance_convert = true
131                     default_domain = greekmythology.com
132             }
133
134     [domain_realm]
135             .greekmythology.com = GREEKMYTHOLOGY.COM
136             greekmythology.com = GREEKMYTHOLOGY.COM
137
138     [kadmin]
139     kdc =
140     # you can disable fallback DNS queries, if don't have registered name like kerberos.yourdomain
141     dns_lookup_realm = false
142     dns_lookup_kdc = false
143     default_keys = v4 v5 afs3
144     afs-cell = greekmythology.com
145     v4-realm = GREEKMYTHOLOGY.COM
146
147     [kdc]
148             enable-kerberos4 = true
149             afs-cell =
150             enable-524 = true
151             v4-realm = GREEKMYTHOLOGY.COM
152
153 The [[HeimdalKTH]] distribution's <code>**ktutil**</code> can copy directly into an AFS [[KeyFile]] and removes salt from keys
154
155            kadmin --admin-server=my_kdc_server
156            kadmin> add --random-key afs/cell
157            kadmin> del_enctype afs/cell@REALM des3-cbc-sha1
158            kadmin> get afs/cell@REALM
159            kadmin> list *
160            kadmin> ext -k /etc/afskeytabfile.krb5
161            kadmin> quit
162            ktutil -k /etc/afskeytabfile.krb5 list
163            ktutil copy FILE:/etc/afskeytabfile.krb5 AFSKEYFILE:/usr/afs/etc/KeyFile
164
165 After you have a working [[KeyFile]] installed in the appropriate directory (/usr/afs/etc/KeyFile for transarc-paths, ???? otherwise) and with the appropriate permissions (0600, owner root), we can create administrative users for AFS. This is a two step process as we first create an authentication principal in the Kerberos database then add the admin user in the authorization ("protection") database in the AFS server.
166
167 Create a user ("joe/admin" in this example) using the appropriate kadmin utility with your [[KerberosV]] distribution. Set a secure password, and note that setting Kerberos admin rights for this user does **not** affect his AFS rights. Please note, that "joe/admin@REALM" is [[KerberosV]] notation and that [[KerberosIV]] is using "joe.admin@REALM". As AFS is based on [[KerberosIV]], you should specify "joe.admin@REALM" or just "joe.admin". (I did this mistake recently and for days was hunting for an explanation, why while having valid tickets, valid AFS tokens with proper kvno (key version number as the one in Kerberos KDC) fileserver, ptserver and bosserver complain about my AFS token being invalid. Yes, I had in the /usr/(afs|vice)/etc/UserList file "joe/admin@REALM"). In [[OpenAFS]]-1.2.8, you can possibly enable Kerbero5 syntax for usernames (See [this message](https://lists.openafs.org/pipermail/openafs-devel/2002-December/003632.html) to openafs-devel)
168
169 #### <a name="KTH Kerberos4"></a> KTH Kerberos4
170
171 - <http://www.pdc.kth.se/kth-krb> :
172
173 You can create afs key using "kadmin add", you had to specify password on interactively. That's quite weak password. Much better is to do <code>**kadmin get**</code>. <code>**kadmin**</code> will try to download the key from KDC, and if it's not present, it will create one, using random key. That's what we want.
174
175 ksrvutil(1) does similar and doesn't require from you to have kadmind(1) running on your machine. The "get" command does same: downloads or (in our case) creates new afs principal using random password. The next example expects that joe.admin is you and you know the proper password to get full access to you kerberos database:
176
177         mv /etc/srvtab /etc/srvtab.orig
178         /usr/athena/sbin/ksrvutil -p joe.admin get
179         Name [rcmd]: afs
180         Instance [hostname]: greekmythology.com
181         Realm [GREEKMYTHOLOGY.COM]: GREEKMYTHOLOGY.COM
182         Is this correct? (y,n) [y]
183         Add more keys? (y,n) [n]
184         Password for joe.admin@GREEKMYTHOLOGY.COM
185         # list keys in /etc/srvtab, look for the AFS key and it's kvno
186         ksrvutil list
187         mv /etc/srvtab /etc/srvtab.afskey
188         mv /etc/srvtab.orig /etc/srvtab
189
190 If you want to make the above more complicated, you will need <code>**/usr/athena/sbin/ext\_srvtab**</code> utility to extract already existing key from Kerberos KDC and save it into /etc/srvtab. It will ask you for your master kerberos password (but if you installed kerberos in the "proper" way, you've used random password which you don't know at all), so better use <code>**ksrvutil**</code> as described above and forget <code>**ext\_srvtab**</code>.
191
192 Now you should have the afs key in /etc/srvtab.afskey.
193
194 Import this AFS key from Kerberos keyfile (/etc/srvtab format) into AFS /usr/afs/etc/KeyFile using <code>**asetkey**</code> utility, which is I think from /afs/transarc.com/public/afs-contrib
195
196         asetkey add 0 /etc/srvtab.afskey afs.greekmythology\.com@GREEKMYTHOLOGY.COM
197
198 This [[KeyFile]] with the AFS-key you can just always re-copy to new AFS machines. Be sure that the key version number KVNO is always same in this [[KeyFile]] and in Kerberos database. On all these machines you of course need afs.hostname.REALM key loaded into their <code>**/etc/srvtab**</code> (create them with <code>**'/ust/athena/bin/ksrvutil get'**</code>).
199
200 You can test if you have same keys in kerberos and AFS like this:
201
202         kauth username
203         tokens
204
205 If you have some tokens now, then it works and you can now shutdown kaserver. Users, which you have created under kaserver are stored in /usr/afs/db/kaserver.\*, but you can just forget them. Create these users again in Kerberos. With [[KerberosIV]] from KTH they get stored under /var/kerberos, when using Heimdal under /var/heimdal/.
206
207 ### <a name="Finishing _OpenAFS installation"></a> Finishing [[OpenAFS]] installation
208
209 Now we will use the <code>**pts**</code> command in [[OpenAFS]] to add this joe.admin user to the AFS administrators group named system:administrators. The username could be just "joe" or "admin", but it's a good habit to have .admin appended to it (it is called instance). Please note the notation "joe.admin", not "joe/admin" as would be typical in Kerberos5 style:
210
211         pts createuser -name joe.admin -cell greekmythology.com -noauth
212         pts adduser joe.admin system:administrators -cell  -noauth
213
214 where greekmythology.com is the name of your local cell. After your complete this step, you can continue on to...
215
216 Activate the new AFS [[KeyFile]] by executing:
217
218         bos restart <machine name> -all -cell <cell name> -noauth
219
220 After this restart, try using kinit to get Kerberos tickets for admin then (if necessary) use aklog to get an AFS token or use afslog if afsd client cache is already running. Basically ensure that the AFS [[KeyFile]] is valid:
221
222         /usr/heimdal/sbin/ktutil copy AFSKEYFILE:/usr/afs/etc/KeyFile FILE:/etc/afskeytabfile.krb5
223         /usr/heimdal/bin/kinit -k -t /etc/afskeytabfile.krb5 afs/greekmythology.com
224         # you should be able to autenticate against KDC using the /etc/afskeytabfile.krb5
225         #    where is saved your afs key in keytab form recognizable by Kerberos5
226         /usr/heimdal/klist
227         # you should see you have afs/greekmythology.com ticket having some expiration time etc.
228
229 Proceed to the [Starting File Server](http://www.openafs.org/pages/doc/QuickStartUnix/auqbg005.htm#HDRWQ60) section of the [[OpenAFS]] documentation. The rest of the documentation can be completed without any changes. (What about replacing NTP with something recent, though...? See FAQ [[3.22|AdminFAQ#NTP]] and [[[NTP|FurtherReading#NTP]]])
230
231 ## <a name="Setting up Transparent Login"></a> Setting up Transparent Login
232
233 In its current state, you have to manually log into your AFS cell through kinit and possibly aklog (explain aklog..., debugging using "tokens" etc). There are several methods to enable transparent login to both local resources (the machine itself) and AFS through a single password. See [[KerberosV]] and [[SettingUpAuthentication]] for some information. The best option if you are using pam is probably the [pam\_krb5 project on sourceforge](http://sourceforge.net/projects/pam-krb5/).
234
235 -- Jason Garman - 05 Feb 2002 -- Derrick Brashear - 26 Nov 2002