Projet

Général

Profil

BGP » Historique » Version 40

Laurent GUERBY, 04/10/2012 14:29

1 20 Laurent GUERBY
{{>toc}}
2 20 Laurent GUERBY
3 1 Laurent GUERBY
h1. BGP
4 1 Laurent GUERBY
5 1 Laurent GUERBY
Nous utilisons BIRD sous Linux comme routeur BGP
6 1 Laurent GUERBY
7 1 Laurent GUERBY
http://bird.network.cz/
8 1 Laurent GUERBY
9 14 Laurent GUERBY
blog bgp http://www.renesys.com/blog/
10 15 Laurent GUERBY
flowspec http://www.slideshare.net/sfouant/an-introduction-to-bgp-flow-spec
11 16 Laurent GUERBY
DFZ = Default Free Zone archive http://archive.routeviews.org/
12 17 Laurent GUERBY
http://www.ripe.net/data-tools/stats/ris/routing-information-service
13 17 Laurent GUERBY
http://pch.net/resources/data/routing-tables/archive/
14 17 Laurent GUERBY
http://pch.net/resources/data/routing-tables/mrt-bgp-updates/
15 18 Laurent GUERBY
http://www.nanog.org/meetings/archive/
16 14 Laurent GUERBY
17 29 Laurent GUERBY
http://www.ipbcop.org/
18 29 Laurent GUERBY
IP Best Current Operational Practices Documented best practices for Engineers by Engineers
19 29 Laurent GUERBY
20 30 Laurent GUERBY
BGP best practices ANSSI
21 30 Laurent GUERBY
https://www.sstic.org/media/SSTIC2012/SSTIC-actes/influence_des_bonnes_pratiques_sur_les_incidents_b/SSTIC2012-Article-influence_des_bonnes_pratiques_sur_les_incidents_bgp-contat_valadon_nataf_2.pdf
22 30 Laurent GUERBY
23 37 Laurent GUERBY
https://www.ams-ix.net/technical/specifications-descriptions/ams-ix-route-servers
24 37 Laurent GUERBY
25 39 Laurent GUERBY
these LAAS BGP http://www.laas.fr/1-31360-Detail-Soutenance-de-these.php?id=600
26 39 Laurent GUERBY
27 40 Laurent GUERBY
http://www.net.t-labs.tu-berlin.de/papers/OMUPMO-OOSICP-11.pdf
28 40 Laurent GUERBY
29 38 Laurent GUERBY
h1. TouIX et GIX
30 38 Laurent GUERBY
31 38 Laurent GUERBY
http://touix.net
32 38 Laurent GUERBY
http://wikilulu.net/doku.php?id=articles:gix-howto
33 38 Laurent GUERBY
34 3 Laurent GUERBY
h1. Evolutions de la conf BGP
35 3 Laurent GUERBY
36 3 Laurent GUERBY
* http://lists.tetaneutral.net/pipermail/technique/2011-December/000118.html
37 3 Laurent GUERBY
38 5 Laurent GUERBY
TODO: 
39 6 Laurent GUERBY
* mise en place d'un gestionaire de version style git au moins pour documentation
40 5 Laurent GUERBY
* Comment gerer les password MD5 du fichier de conf (les garder secrets tout en publiant le reste)
41 5 Laurent GUERBY
* Atelier ?
42 7 Laurent GUERBY
** Laurent GUERBY
43 9 Raphaël Durand
** Solarus
44 10 Raphaël Durand
** Ajouter son nom...
45 4 Laurent GUERBY
46 13 Laurent GUERBY
Alternative a MP BGP
47 13 Laurent GUERBY
http://tools.ietf.org/html/draft-ietf-idr-bgp-multisession-06
48 13 Laurent GUERBY
49 31 Laurent GUERBY
Add Path
50 31 Laurent GUERBY
http://tools.ietf.org/html/draft-ietf-idr-add-paths-07
51 31 Laurent GUERBY
support in bird ? http://marc.info/?l=bird-users&m=134409996129466&w=2
52 31 Laurent GUERBY
53 2 Laurent GUERBY
h1. Liens
54 2 Laurent GUERBY
55 2 Laurent GUERBY
* http://www.cl.cam.ac.uk/~tgg22/talks/BGP_TUTORIAL_ICNP_2002.ppt
56 11 Laurent GUERBY
* http://www.menog.net/menog-meetings/menog5/presentations/smith-32bit-asn-update.pdf
57 12 Laurent GUERBY
* AS4 http://www.rfc-editor.org/rfc/rfc4893.txt
58 19 Laurent GUERBY
* bonnes pratiques incidents BGP
59 19 Laurent GUERBY
** https://www.sstic.org/media/SSTIC2012/SSTIC-actes/influence_des_bonnes_pratiques_sur_les_incidents_b/SSTIC2012-Slides-influence_des_bonnes_pratiques_sur_les_incidents_bgp-contat_valadon_nataf.pdf
60 35 Laurent GUERBY
* test ping plus UDP http://www.broadband-forum.org/technical/download/TR-143.pdf
61 2 Laurent GUERBY
62 1 Laurent GUERBY
h1. Configuration Toulouse
63 1 Laurent GUERBY
64 1 Laurent GUERBY
<pre>
65 1 Laurent GUERBY
router id 91.224.148.2;
66 1 Laurent GUERBY
define myas = 197422;
67 1 Laurent GUERBY
68 1 Laurent GUERBY
69 1 Laurent GUERBY
protocol device {
70 1 Laurent GUERBY
	scan time 10;
71 1 Laurent GUERBY
        primary "eth0" 91.224.148.3;
72 1 Laurent GUERBY
}
73 1 Laurent GUERBY
74 1 Laurent GUERBY
protocol static static_bgp {
75 1 Laurent GUERBY
	import all;
76 1 Laurent GUERBY
	route 91.224.148.0/23 reject;
77 1 Laurent GUERBY
}
78 1 Laurent GUERBY
79 1 Laurent GUERBY
80 1 Laurent GUERBY
protocol kernel{
81 1 Laurent GUERBY
	import all;
82 1 Laurent GUERBY
	export all;
83 1 Laurent GUERBY
}
84 1 Laurent GUERBY
85 1 Laurent GUERBY
86 1 Laurent GUERBY
function avoid_martians()
87 1 Laurent GUERBY
prefix set martians;
88 1 Laurent GUERBY
{
89 1 Laurent GUERBY
  martians = [ 169.254.0.0/16+, 172.16.0.0/12+, 192.168.0.0/16+, 10.0.0.0/8+, 224.0.0.0/4+, 240.0.0.0/4+ ];
90 1 Laurent GUERBY
91 1 Laurent GUERBY
  # Avoid 0.0.0.0/X
92 1 Laurent GUERBY
  if net.ip = 0.0.0.0 then return false;
93 1 Laurent GUERBY
94 1 Laurent GUERBY
  # Avoid too short and too long prefixes
95 1 Laurent GUERBY
  if (net.len < 8) || (net.len > 24) then return false;
96 1 Laurent GUERBY
97 1 Laurent GUERBY
  # Avoid RFC1918 networks
98 1 Laurent GUERBY
  if net ~ martians then return false;
99 1 Laurent GUERBY
  return true;
100 1 Laurent GUERBY
}
101 1 Laurent GUERBY
102 1 Laurent GUERBY
filter bgp_OUT {
103 1 Laurent GUERBY
	if (net ~ [91.224.148.0/23]) then accept;
104 1 Laurent GUERBY
	else reject;
105 1 Laurent GUERBY
}
106 1 Laurent GUERBY
107 1 Laurent GUERBY
108 1 Laurent GUERBY
protocol bgp TOUIX {
109 1 Laurent GUERBY
        local as myas;
110 1 Laurent GUERBY
        neighbor 91.213.236.1 as 47184;
111 1 Laurent GUERBY
        preference 200;
112 1 Laurent GUERBY
        import where avoid_martians();
113 1 Laurent GUERBY
        export filter bgp_OUT;
114 1 Laurent GUERBY
}
115 1 Laurent GUERBY
116 1 Laurent GUERBY
protocol bgp JAGUAR {
117 1 Laurent GUERBY
	 local as myas;
118 1 Laurent GUERBY
	 neighbor 31.172.233.1 as 30781;
119 1 Laurent GUERBY
	 preference 50;
120 1 Laurent GUERBY
         import where avoid_martians();
121 1 Laurent GUERBY
         export filter bgp_OUT;
122 1 Laurent GUERBY
}
123 1 Laurent GUERBY
124 1 Laurent GUERBY
protocol bgp TETANEUTRAL {
125 1 Laurent GUERBY
	local as myas;
126 1 Laurent GUERBY
	neighbor 91.224.148.2 as myas;
127 1 Laurent GUERBY
	preference 100;
128 1 Laurent GUERBY
	import where avoid_martians();
129 1 Laurent GUERBY
	export all;
130 1 Laurent GUERBY
}
131 1 Laurent GUERBY
</pre>
132 20 Laurent GUERBY
133 33 Laurent GUERBY
h1. IRR
134 33 Laurent GUERBY
135 33 Laurent GUERBY
* From nanog:
136 33 Laurent GUERBY
http://www.clarksys.com/blog/2009/09/02/using-irr-with-level3/
137 33 Laurent GUERBY
whois -h filtergen.level3.net "RIPE::YOUR-AS-SET  -searchpath=RIPE;ARIN;RADB -recurseok -warnonly"
138 33 Laurent GUERBY
139 20 Laurent GUERBY
h1. Blackholing
140 20 Laurent GUERBY
141 24 Laurent GUERBY
h2. Attaques
142 24 Laurent GUERBY
143 24 Laurent GUERBY
* 20120629 http://lists.tetaneutral.net/pipermail/technique/2012-July/000406.html
144 36 Laurent GUERBY
* http://blog.cloudflare.com/65gbps-ddos-no-problem
145 24 Laurent GUERBY
146 34 Laurent GUERBY
h2. URPF
147 34 Laurent GUERBY
148 34 Laurent GUERBY
blacklister une/plusieures sources est relativement complexe à mettre en place sur une petite infrastructure car nécessite la mise en place de l'URPF (Unicast Reverse Path Forwarding).
149 34 Laurent GUERBY
150 34 Laurent GUERBY
http://www.cisco.com/web/about/security/intelligence/ipv6_rtbh.html
151 34 Laurent GUERBY
152 20 Laurent GUERBY
h2. RFC3882 
153 1 Laurent GUERBY
154 22 Laurent GUERBY
* http://www.ietf.org/rfc/rfc3882.txt
155 1 Laurent GUERBY
community AS:666 sur annonce /32 pour balckhole par AS upstream
156 1 Laurent GUERBY
157 22 Laurent GUERBY
* doc CISCO
158 22 Laurent GUERBY
http://www.cisco.com/web/about/security/intelligence/blackhole.pdf
159 22 Laurent GUERBY
160 28 Laurent GUERBY
h2. RFC1997
161 28 Laurent GUERBY
162 28 Laurent GUERBY
* http://www.ietf.org/rfc/rfc1997.txt
163 28 Laurent GUERBY
BGP Communities Attribute
164 28 Laurent GUERBY
165 28 Laurent GUERBY
* doc CISCO
166 28 Laurent GUERBY
http://www.cisco.com/web/about/ac123/ac147/archived_issues/ipj_6-2/bgp_communities.html
167 28 Laurent GUERBY
168 22 Laurent GUERBY
h2. BIRD
169 22 Laurent GUERBY
170 22 Laurent GUERBY
* http://www.mail-archive.com/bird-users@atrey.karlin.mff.cuni.cz/msg01998.html
171 22 Laurent GUERBY
172 24 Laurent GUERBY
h2. Absolight
173 24 Laurent GUERBY
174 24 Laurent GUERBY
* communauté 29608:65001 sur /24..32 IPv4 et /41..128 IPv6 => blackhole
175 24 Laurent GUERBY
* test 20120703 IPv4 et IPv6, ça marche et convergence très rapide
176 24 Laurent GUERBY
177 22 Laurent GUERBY
h2. GIXE
178 22 Laurent GUERBY
179 1 Laurent GUERBY
* communauté 31576:666 sur /32 => blackhole
180 24 Laurent GUERBY
* test 20120703 => marche pas encore, signalé et dev a faire coté GIXE pour autoriser les /32
181 1 Laurent GUERBY
182 1 Laurent GUERBY
h2. Jaguar 
183 22 Laurent GUERBY
184 24 Laurent GUERBY
* https://extranet.jaguar-network.com/app/public/index.php?cmd=bgp-policy
185 22 Laurent GUERBY
* demande 20120702 : pas de communauté blackhole actuellement, en reflexion
186 22 Laurent GUERBY
* déploiement de matériel arbor networks, reglage a affiner (pas de detection d'attaque)
187 22 Laurent GUERBY
188 27 Laurent GUERBY
h2. Gitoyen
189 27 Laurent GUERBY
190 1 Laurent GUERBY
* demande 20120704 sur la liste, réponse 20120717
191 28 Laurent GUERBY
* Tata http://noc.easycolocate.nl/Teleglobe_bgp_comm.pdf
192 27 Laurent GUERBY
*** => black-hole route (host route or shorter prefix within customer’s RIR registred assignment) 64999:0
193 28 Laurent GUERBY
* Ielo  whois AS29075 => 29075:0 Null-route/Blackhole
194 32 Laurent GUERBY
* https://pad.ilico.org/p/cleanup-bgp-gitoyen
195 22 Laurent GUERBY
196 22 Laurent GUERBY
h2. France-IX
197 22 Laurent GUERBY
198 25 Laurent GUERBY
* community plan : https://apps.db.ripe.net/whois/lookup/ripe/aut-num/AS51706.html
199 26 Laurent GUERBY
* TODO tester
200 22 Laurent GUERBY
201 22 Laurent GUERBY
h2. Equinix-IX
202 1 Laurent GUERBY
203 26 Laurent GUERBY
* community plan : https://ix.equinix.com/ixp/mlpeCommunityInfo
204 26 Laurent GUERBY
* TODO tester
205 22 Laurent GUERBY
206 1 Laurent GUERBY
h2. TouIX
207 22 Laurent GUERBY
208 26 Laurent GUERBY
* demande acces switch et route server 20120702
209 22 Laurent GUERBY
* TODO
210 1 Laurent GUERBY
211 1 Laurent GUERBY
h2. Hurricane Electric
212 1 Laurent GUERBY
213 26 Laurent GUERBY
* http://www.he.net/adm/
214 1 Laurent GUERBY
* http://www.he.net/adm/blackhole.html
215 1 Laurent GUERBY
* TODO tester
216 28 Laurent GUERBY
217 28 Laurent GUERBY
h2. Sfinx
218 28 Laurent GUERBY
219 28 Laurent GUERBY
* http://www.renater.fr/route-servers-bgp?lang=fr
220 28 Laurent GUERBY
* whois  AS1304 =>
221 28 Laurent GUERBY
remarks:        1304:65281 = Apply NO-EXPORT community
222 28 Laurent GUERBY
remarks:        1304:65282 = Apply NO-ADVERTISE community