Bind

Aus Linupedia.org
Wechseln zu: Navigation, Suche

Als Vorgabe habe ich folgenden Link benutzt: http://www.ag-intra.net/linux-kl-dns8.html

Mit dem Thread an dem nbrk und baumpaul stark beteiligt waren, sind weitere Infos hier mit eingeflossen:


Buchtipp: DNS und Bind aus dem O'Reilly Verlag. ISBN: 3897212900 http://www.amazon.de/exec/obidos/ASIN/3897212900/303-0322939-0892207

und Auszug aus der Wikipedia: http://de.wikipedia.org/wiki/Domain_Name_System


Die Installation

Folgende Pakete habe ich über apt installiert:

bind bind-chrootenv bind-libs bind-utils bind-debuginfo bind-devel bind-doc bind-lwresd Es handelt sich um die Version 9.3.1-8

Die Konfiguration funktioniert so bei SuSE 10.0, weitere können hier eingefügt werden; wenn es genauso funktioniert, oder insbesondere bei anderen Distributionen die Ergänzungen eingefügt werden.

Unter SuSE sollte zur Konfiguration des Namensservers YAST nicht eingesetzt werden, bis auf den Runleveleditor. Für die Konfiguration wird der Umgang mit Konsole und Editoren vorrausgesetzt. An der Daraus ergeben sich für Suse 10.0 folgende Konfigurationen in meinem Fall:

1. Szenario PC-Client: G4 Name: apple IP:192.168.3.8

PC-Server: AMD 1,8GHz Suse 10.0 Name: linux IP: 192.168.3.1

2. Zonefile (Forward Mapping)

/var/lib/named/db.heim.netz Code:

; Zonefile (Forward Mapping) für heim.netz. 
; 
$TTL 3h 
@         IN  SOA linux.heim.netz. root.linux.heim.netz. ( 
  200207241  ; Seriennummer 
  10800      ; Refresh Zeit 
  3600       ; Retry Zeit 
  604800     ; Expire 
  38400 )    ; negative Caching TTL 
; 
; Nameserver 
; 
         IN  NS linux.heim.netz. 
; 
; Hosts (kanonisch) 
; 
localhost IN  A     127.0.0.1 
apple     IN  A     192.168.3.8 
         IN  LOC   52 31 0.12 N 13 24 0.36 E 34m 
         IN  HINFO "Power MAC AGP-Grafik 1,4GHz" "OSX 10.4" 
         IN  RP    root.apple.heim.netz.    linux.heim.netz. 
         IN  TXT   "Apple G4" "Standort: Studio" 
linux     IN  A     192.168.3.1 
         IN  LOC   52 31 0.12 N 13 24 0.36 E 34m 
         IN  HINFO "AMD 1,8GHz" "SuSE Linux 10.0" 
         IN  RP    root.linux.heim.netz.    linux.heim.netz. 
         IN  TXT   "Server und Router" "Standort: Arbeitszimmer" 
; 
; Aliase 
; 
www       IN  CNAME linux 
irc       IN  CNAME linux

--Yehudi 13:10, 16. Aug 2006 (CEST) 3. Zonefile (Reverse Lookup) /var/lib/named/db.192.168.3

Code:

; Zonefile für heim.netz. (Reverse Mapping) 
; 
$TTL 3h 
@    IN SOA linux.heim.netz. root.linux.heim.netz. ( 
  200207241  ; Seriennummer 
  10800      ; Refresh Zeit 
  3600       ; Retry Zeit 
  604800     ; Expire 
  38400 )    ; negative Caching TTL 
; 
; Nameserver 
; 
    IN NS linux.heim.netz. 
; 
; Hosts Adressen zeigen auf kanonische Namen 
; 
8  IN PTR apple.heim.netz. 
1  IN PTR linux.heim.netz.

wechseln in das Verzeichnis: Code:

cd /var/lib/named


root.hint ist eine Datei. Da stehen die IP Adressen der Rootnameserver im Internet drin. Die sind die Wurzel (deshalb ja auch root) des DNS. Ohne die gibt es dauerhaft keine DNS. Eine root.hint wird normalerweise mitgeliefert. Die muss ab und an mal aktualisiert werden. Dafür wird der dig Befehl genutzt:.

Code: dig @a.root-servers.net . ns > root.hint


4. Konfigurationsdatei /etc/named.conf

Die named.conf sollte ganz am Ende den Eintrag "Include /etc/named.conf.local" haben. Damit wird eine weitere Configdatei geladen. Die named.conf braucht man nicht bearbeiten, dort passt in aller Regel alles: Code:

options {
  directory "/var/lib/named";
  dump-file "/var/log/named_dump.db";
  statistics-file "/var/log/named.stats";
       forwarders { 213.191.92.87; 213.191.74.19; };
  listen-on-v6 { any; };
       cleaning intervall 120;
       statistics-interval 0;
  notify no;
  include "/etc/named.d/forwarders.conf";
};


zone "." in {
  type hint;
  file "root.hint";
};
zone "localhost" in {
  type master;
  file "localhost.zone";
};
zone "0.0.127.in-addr.arpa" in {
  type master;
  file "127.0.0.zone";
};
include "/etc/named.conf.local";


In der /etc/named.conf.local sollte dann dies drinstehen.

Code:

zone heim.netz in {
 type master;
 file "/var/named/db.heim.netz";
};

5. DNS starten

Nun in YaST2 System, den Runlevel Editor im Expertenmodus wählen, und in der Liste den Dienst named 3 und 5 einschalten. Darauf hin folgend im Klappmenü "Anwenden/Zurücksetzen" Dienst aktivieren, und in "Starten/Anhalten/Aktualisieren" entweder starten, oder aktualisieren.

Nach der Anleitung sollte der nameserver nun laufen, und beim nächsten reboots automatisch starten.


Wenn die Konfigurationsdateien geändert werden und der Nameserver die neu eingelesen werden soll, gibt man am Prompt ein:

Code:

linux:rndc reload


Muss der ganze Nameserver neu gestartet werden, gibt man folgenden Befehl ein:

Code:

linux: rndc stop
linux: /usr/sbin/named -u named -g named


Damit läuft der named korrekt unter dem Kennungnamen.

6. Resolver und Clients konfigurieren

Die Angabe nameserver <ipadresse> in der /etc/resolv.conf gibt an welche Nameserver der Rechner abfragt. Da sollte die IP des Rechners auf dem der Bind9 läuft drin stehen. Code:

nameserver 192.168.3.1
search heim.netz


Und in /etc/sysconfig/network/config sollte die Zeile so aussehen:

Code:

MODIFY_RESOLV_CONF_DYNAMICALLY="no"



Bei meinem Mac kann ich in meiner jetzigen Configuration folgendes eingeben:

IP-Adresse: 192.168.3.8
Teilnetzmaske: 255.255.255.0
Router: 192.168.3.1
DNS-Server: 192.168.3.1
Domain-Name: search heim.netz 

7. Fehlermeldung, Fehlersuche und Fehlerbehebung

Code:

linux:/var/log # grep -ilr named ./*


In meinem Fall musste in der Code:

/etc/named.d/forwarders.conf


die IP's des Provider ausdokumentiert werden, da bei mir die Clients die DNS und IP des Routers in ihrer Konfiguration haben, damit bind korrekt startet. --Yehudi 17:14, 16. Aug 2006 (CEST)