Samenvatting:
Enige weken geleden had ik een stroomstoring. Sindsdien kan mijn werkmachine, hierna te noemen W, niet meer via mijn server, hierna te noemen S, bij het interne netwerk van dit studentencomplex.
Lange versie:
In mijn kamer staan 2 computers: S en W. Samen vormen ze een netwerkje in de 192.168.0.0\24 range en zijn middels een UTP kabeltje en twee ethernetkaarten met elkaar verbonden. Beiden draaien Linux (Debian testing, S draait een 2.4.21 kernel, W draait 2.6.0-test9).
S is verbonden met een lokaal netwerk in de 172.20.40.0\22 range. Daarnaast heeft S een PPPoe verbinding met het internet. S draait het standaard 'ipmasq' iptables script, lichtjes door mij aangepast (zie verderop voor details). Vroeger, toen alles beter was, kon W via S zowel bij het lokale netwerk als bij het internet. Als nameservers stonden in de resolv.conf van zowel S als W twee servers in het 172.20.40.0 netwerk. Toen kwam de stroomstoring.
Nadat beide computers herstart waren, bleek W niet meer op internet of bij het lokale netwerk te kunnen. Ik constateerde dat W niet bij de nameservers op het lokale netwerk kon en daarom de weg kwijt was. Ik vulde een externe nameserver in de resolv.conf van W in en W kon weer op het internet. Het is me echter nog steeds niet gelukt om W weer contact te laten leggen met het lokale 172.20.40.0 netwerk.
Hieronder volgen de routing tabellen van respectievelijk S en W. Ik heb Metric, Ref en Use uit beide verwijderd voor de overzichtelijkheid (zijn allen 0). Ik vermoed dat ze juist zijn, maar het is naar mijn idee de eerste mogelijke bron van problemen. Een tweede mogelijk
probleem zijn de iptable rules, die ik onder de routing tabellen heb weergegeven. Ik heb datahoeveelheden verwijderd; die lijken me niet relevant.
Als iemand een idee heeft hou ik me aanbevolen, want ik heb geen flauw idee waar het probleem zit. Ik heb het enige tijd geleden al in N&T gevraagd, maar daar kreeg ik geen respons. Misschien dat hier mensen zitten die zo zien 'Ach, je moet zus en zo even doen'. Ik heb zo'n beetje alles gelezen over routing dat los en vast zit en begrijp het volgens mij nu aardig... alleen zou de huidige configuratie dan volgens mij moeten werken. Bovendien is er volgens mij niet verandert aan onderstaande tabellen en het is me een volstrekt raadsel waarom ik het 172.20.40.0\22 netwerk niet eens meer kan pingen vanaf W. Vanaf S gaat alles prima en ook alle contact tussen S en W gaat prima.
Alles dat ik niet heb vermeld (nat PREROUTING, mangle table, etc.) is er ook niet.
Edit: Ohja, de kleine wijzigingen betreffende de standaard ipmasq configuratie betreft het niet functioneren als gateway voor het 172.20.40 netwerk: er stond een ACCEPT in plaats van een DROP in:
en er was een MASQUERADING rule voor 172.20.40.0 naar buiten over ppp0, die ik heb verwijderd.
Enige weken geleden had ik een stroomstoring. Sindsdien kan mijn werkmachine, hierna te noemen W, niet meer via mijn server, hierna te noemen S, bij het interne netwerk van dit studentencomplex.
Lange versie:
In mijn kamer staan 2 computers: S en W. Samen vormen ze een netwerkje in de 192.168.0.0\24 range en zijn middels een UTP kabeltje en twee ethernetkaarten met elkaar verbonden. Beiden draaien Linux (Debian testing, S draait een 2.4.21 kernel, W draait 2.6.0-test9).
S is verbonden met een lokaal netwerk in de 172.20.40.0\22 range. Daarnaast heeft S een PPPoe verbinding met het internet. S draait het standaard 'ipmasq' iptables script, lichtjes door mij aangepast (zie verderop voor details). Vroeger, toen alles beter was, kon W via S zowel bij het lokale netwerk als bij het internet. Als nameservers stonden in de resolv.conf van zowel S als W twee servers in het 172.20.40.0 netwerk. Toen kwam de stroomstoring.
Nadat beide computers herstart waren, bleek W niet meer op internet of bij het lokale netwerk te kunnen. Ik constateerde dat W niet bij de nameservers op het lokale netwerk kon en daarom de weg kwijt was. Ik vulde een externe nameserver in de resolv.conf van W in en W kon weer op het internet. Het is me echter nog steeds niet gelukt om W weer contact te laten leggen met het lokale 172.20.40.0 netwerk.
Hieronder volgen de routing tabellen van respectievelijk S en W. Ik heb Metric, Ref en Use uit beide verwijderd voor de overzichtelijkheid (zijn allen 0). Ik vermoed dat ze juist zijn, maar het is naar mijn idee de eerste mogelijke bron van problemen. Een tweede mogelijk
probleem zijn de iptable rules, die ik onder de routing tabellen heb weergegeven. Ik heb datahoeveelheden verwijderd; die lijken me niet relevant.
Als iemand een idee heeft hou ik me aanbevolen, want ik heb geen flauw idee waar het probleem zit. Ik heb het enige tijd geleden al in N&T gevraagd, maar daar kreeg ik geen respons. Misschien dat hier mensen zitten die zo zien 'Ach, je moet zus en zo even doen'. Ik heb zo'n beetje alles gelezen over routing dat los en vast zit en begrijp het volgens mij nu aardig... alleen zou de huidige configuratie dan volgens mij moeten werken. Bovendien is er volgens mij niet verandert aan onderstaande tabellen en het is me een volstrekt raadsel waarom ik het 172.20.40.0\22 netwerk niet eens meer kan pingen vanaf W. Vanaf S gaat alles prima en ook alle contact tussen S en W gaat prima.
code:
1
2
3
4
5
6
7
| S:/# route Kernel IP routing table Destination Gateway Genmask Flags Iface depoort.tudelft * 255.255.255.255 UH ppp0 192.168.0.0 * 255.255.255.0 U eth1 172.20.40.0 * 255.255.252.0 U eth0 default depoort.tudelft 0.0.0.0 UG ppp0 |
code:
1
2
3
4
5
| W:/# route Kernel IP routing table Destination Gateway Genmask Flags Iface 192.168.0.0 * 255.255.255.0 U eth0 default 192.168.0.1 0.0.0.0 UG eth0 |
code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
| S:/# iptables -t filter -L -v Chain INPUT (policy DROP 3 packets, 332 bytes) target prot opt in out source destination ACCEPT all -- lo any anywhere anywhere LOG all -- !lo any 127.0.0.0/8 anywhere DROP all -- !lo any 127.0.0.0/8 anywhere ACCEPT all -- eth0 any anywhere 255.255.255.255 ACCEPT all -- eth1 any anywhere 255.255.255.255 ACCEPT all -- eth0 any 172.20.40.0/22 anywhere ACCEPT all -- eth1 any 192.168.0.0/24 anywhere ACCEPT !tcp -- eth0 any anywhere BASE-ADDRESS.MCAST.NET/4 ACCEPT !tcp -- eth1 any anywhere BASE-ADDRESS.MCAST.NET/4 LOG all -- ppp0 any 172.20.40.0/22 anywhere DROP all -- ppp0 any 172.20.40.0/22 anywhere LOG all -- ppp0 any 192.168.0.0/24 anywhere DROP all -- ppp0 any 192.168.0.0/24 anywhere ACCEPT all -- ppp0 any anywhere 255.255.255.255 ACCEPT all -- ppp0 any anywhere <privé IP> LOG all -- any any anywhere anywhere DROP all -- any any anywhere anywhere Chain FORWARD (policy DROP 0 packets, 0 bytes) target prot opt in out source destination ACCEPT all -- any any 192.168.0.0/24 172.20.40.0/22 ACCEPT all -- any any 172.20.40.0/22 192.168.0.0/24 DROP all -- eth0 ppp0 172.20.40.0/22 anywhere ACCEPT all -- eth1 ppp0 192.168.0.0/24 anywhere ACCEPT all -- any any anywhere, anywhere, state RELATED,ESTABLISHED LOG all -- any ppp0 anywhere 172.20.40.0/22 DROP all -- any ppp0 anywhere 172.20.40.0/22 LOG all -- any ppp0 anywhere 192.168.0.0/24 DROP all -- any ppp0 anywhere 192.168.0.0/24 LOG all -- any any anywhere anywhere DROP all -- any any anywhere anywhere Chain OUTPUT (policy DROP 41 packets, 47076 bytes) target prot opt in out source destination ACCEPT all -- any lo anywhere anywhere ACCEPT all -- any eth0 anywhere 255.255.255.255 ACCEPT all -- any eth1 anywhere 255.255.255.255 ACCEPT all -- any eth0 anywhere 172.20.40.0/22 ACCEPT all -- any eth1 anywhere 192.168.0.0/24 ACCEPT !tcp -- any eth0 anywhere BASE-ADDRESS.MCAST.NET/4 ACCEPT !tcp -- any eth1 anywhere BASE-ADDRESS.MCAST.NET/4 LOG all -- any ppp0 anywhere 172.20.40.0/22 DROP all -- any ppp0 anywhere 172.20.40.0/22 LOG all -- any ppp0 anywhere 192.168.0.0/24 DROP all -- any ppp0 anywhere 192.168.0.0/24 ACCEPT all -- any ppp0 anywhere 255.255.255.255 ACCEPT all -- any ppp0 <privé IP> anywhere LOG all -- any any anywhere anywhere DROP all -- any any anywhere anywhere S:/# iptables -t nat -L -v Chain POSTROUTING (policy ACCEPT 139 packets, 10174 bytes) target prot opt in out source destination MASQUERADE all -- any ppp0 192.168.0.0/24 anywhere |
Alles dat ik niet heb vermeld (nat PREROUTING, mangle table, etc.) is er ook niet.
Edit: Ohja, de kleine wijzigingen betreffende de standaard ipmasq configuratie betreft het niet functioneren als gateway voor het 172.20.40 netwerk: er stond een ACCEPT in plaats van een DROP in:
code:
1
| DROP all -- eth0 ppp0 172.20.40.0/22 anywhere |
en er was een MASQUERADING rule voor 172.20.40.0 naar buiten over ppp0, die ik heb verwijderd.
[ Voor 11% gewijzigd door Confusion op 04-02-2004 21:56 . Reden: Layout vernaggeling opgeheven ]
Wie trösten wir uns, die Mörder aller Mörder?