]> pere.pagekite.me Git - homepage.git/blob - blog/Combining_PowerDNS_and_ISC_DHCP_LDAP_objects.html
Generated.
[homepage.git] / blog / Combining_PowerDNS_and_ISC_DHCP_LDAP_objects.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: Combining PowerDNS and ISC DHCP LDAP objects</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9 </head>
10 <body>
11 <div class="title">
12 <h1>
13 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
14
15 </h1>
16
17 </div>
18
19
20 <div class="entry">
21 <div class="title">Combining PowerDNS and ISC DHCP LDAP objects</div>
22 <div class="date">14th July 2010</div>
23 <div class="body"><p>For a while now, I have wanted to find a way to change the DNS and
24 DHCP services in Debian Edu to use the same LDAP objects for a given
25 computer, to avoid the possibility of having a inconsistent state for
26 a computer in LDAP (as in DHCP but no DNS entry or the other way
27 around) and make it easier to add computers to LDAP.</p>
28
29 <p>I've looked at how powerdns and dhcpd is using LDAP, and using this
30 information finally found a solution that seem to work.</p>
31
32 <p>The old setup required three LDAP objects for a given computer.
33 One forward DNS entry, one reverse DNS entry and one DHCP entry. If
34 we switch powerdns to use its strict LDAP method (ldap-method=strict
35 in pdns-debian-edu.conf), the forward and reverse DNS entries are
36 merged into one while making it impossible to transfer the reverse map
37 to a slave DNS server.</p>
38
39 <p>If we also replace the object class used to get the DNS related
40 attributes to one allowing these attributes to be combined with the
41 dhcphost object class, we can merge the DNS and DHCP entries into one.
42 I've written such object class in the dnsdomainaux.schema file (need
43 proper OIDs, but that is a minor issue), and tested the setup. It
44 seem to work.</p>
45
46 <p>With this test setup in place, we can get away with one LDAP object
47 for both DNS and DHCP, and even the LTSP configuration I suggested in
48 an earlier email. The combined LDAP object will look something like
49 this:</p>
50
51 <blockquote><pre>
52 dn: cn=hostname,cn=group1,cn=THINCLIENTS,cn=DHCP Config,dc=skole,dc=skolelinux,dc=no
53 cn: hostname
54 objectClass: dhcphost
55 objectclass: domainrelatedobject
56 objectclass: dnsdomainaux
57 associateddomain: hostname.intern
58 arecord: 10.11.12.13
59 dhcphwaddress: ethernet 00:00:00:00:00:00
60 dhcpstatements: fixed-address hostname
61 ldapconfigsound: Y
62 </pre></blockquote>
63
64 <p>The DNS server uses the associateddomain and arecord entries, while
65 the DHCP server uses the dhcphwaddress and dhcpstatements entries
66 before asking DNS to resolve the fixed-adddress. LTSP will use
67 dhcphwaddress or associateddomain and the ldapconfig* attributes.</p>
68
69 <p>I am not yet sure if I can get the DHCP server to look for its
70 dhcphost in a different location, to allow us to put the objects
71 outside the "DHCP Config" subtree, but hope to figure out a way to do
72 that. If I can't figure out a way to do that, we can still get rid of
73 the hosts subtree and move all its content into the DHCP Config tree
74 (which probably should be renamed to be more related to the new
75 content. I suspect cn=dnsdhcp,ou=services or something like that
76 might be a good place to put it.</p>
77
78 <p>If you want to help out with implementing this for Debian Edu,
79 please contact us on debian-edu@lists.debian.org.</p>
80 </div>
81
82 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap</a>, <a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug</a>.</div>
83
84
85 </div>
86
87
88
89
90 <div id="sidebar">
91
92
93
94 <h2>Archive</h2>
95 <ul>
96
97 <li>2013
98 <ul>
99
100 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (7)</a></li>
101
102 </ul></li>
103
104 <li>2012
105 <ul>
106
107 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
108
109 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
110
111 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
112
113 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
114
115 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
116
117 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
118
119 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
120
121 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
122
123 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
124
125 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
126
127 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
128
129 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
130
131 </ul></li>
132
133 <li>2011
134 <ul>
135
136 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
137
138 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
139
140 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
141
142 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
143
144 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
145
146 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
147
148 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
149
150 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
151
152 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
153
154 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
155
156 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
157
158 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
159
160 </ul></li>
161
162 <li>2010
163 <ul>
164
165 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
166
167 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
168
169 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
170
171 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
172
173 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
174
175 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
176
177 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
178
179 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
180
181 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
182
183 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
184
185 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
186
187 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
188
189 </ul></li>
190
191 <li>2009
192 <ul>
193
194 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
195
196 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
197
198 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
199
200 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
201
202 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
203
204 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
205
206 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
207
208 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
209
210 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
211
212 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
213
214 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
215
216 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
217
218 </ul></li>
219
220 <li>2008
221 <ul>
222
223 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
224
225 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
226
227 </ul></li>
228
229 </ul>
230
231
232
233 <h2>Tags</h2>
234 <ul>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
241
242 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
243
244 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (5)</a></li>
245
246 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (12)</a></li>
247
248 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
249
250 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (65)</a></li>
251
252 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (118)</a></li>
253
254 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (9)</a></li>
255
256 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (7)</a></li>
257
258 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
259
260 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (171)</a></li>
261
262 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (21)</a></li>
263
264 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
265
266 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (10)</a></li>
267
268 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (9)</a></li>
269
270 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (32)</a></li>
271
272 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (17)</a></li>
273
274 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (8)</a></li>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (6)</a></li>
277
278 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
279
280 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (25)</a></li>
281
282 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (219)</a></li>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (148)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (6)</a></li>
287
288 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
289
290 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (41)</a></li>
291
292 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (61)</a></li>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
297
298 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (2)</a></li>
299
300 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (6)</a></li>
301
302 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
303
304 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
305
306 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
307
308 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (28)</a></li>
309
310 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
311
312 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
313
314 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (39)</a></li>
315
316 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
317
318 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (5)</a></li>
319
320 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (12)</a></li>
321
322 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (1)</a></li>
323
324 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (7)</a></li>
325
326 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (35)</a></li>
327
328 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
329
330 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (26)</a></li>
331
332 </ul>
333
334
335 </div>
336 <p style="text-align: right">
337 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.4</a>
338 </p>
339
340 </body>
341 </html>