<div dir="ltr">Hi Saku,<div><br></div><div>To your IGP point let me observe that OSPF runs over IP and ISIS does not. That is first fundamental difference. There are customers using both all over the world and therefore any suggestion to just use OSPFv3 is IMHO quite unrealistic. Keep in mind that OSPF hierarchy is 2 (or 3 with super area) while in IETF there is ongoing work to extend ISIS to 8 levels. There is a lot of fundamental differences between those two (or three) IGPs and I am sure many folks on the lists know them. Last there is a lot of enterprise networks happily using IPv4 RFC1918 all over their global WAN and DCs infrastructure and have no reason to deploy IPv6 there any time soon. </div><div><br></div><div>If you are serious about converging to a single IGP I would rather consider look towards OpenR type of IGP architecture with message bus underneath. </div><div><br></div><div>Thx,</div><div>R.</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 18, 2020 at 7:26 AM Saku Ytti <<a href="mailto:saku@ytti.fi">saku@ytti.fi</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On Thu, 18 Jun 2020 at 01:17, Mark Tinka <<a href="mailto:mark.tinka@seacom.mu" target="_blank">mark.tinka@seacom.mu</a>> wrote:<br>
<br>
> IOS XR does not appear to support SR-OSPFv3.<br>
> IOS XE does not appear to support SR-ISISv6.<br>
> IOS XE does not appear to support SR-OSPFv3.<br>
> Junos does not appear to support SR-OSPFv3.<br>
<br>
The IGP mess we are in is horrible, but I can't blame SR for it. It's<br>
really unacceptable we spend NRE hours developing 3 identical IGP<br>
(OSPFv2, OSPFv3, ISIS). We all pay a 300-400% premium for a single<br>
IGP.<br>
<br>
In a sane world, we'd retire all of them except OSPFv3 and put all NRE<br>
focus on there or move some of the NRE dollars to some other problems<br>
we have, perhaps we would have room to support some different<br>
non-djikstra IGP.<br>
<br>
In a half sane world, IGP code, 90% of your code would be identical,<br>
then you'd have adapter/ospfv2 adapter/ospfv3 adapter/isis which<br>
translates internal struct to wire and wire to internal struct. So any<br>
features you code, come for free to all of them. But no one is doing<br>
this, it's 300% effort, and we all pay a premium for that.<br>
<br>
In a quarter sane world we'd have some CIC, common-igp-container RFC<br>
and then new features like SR would be specified as CIC-format,<br>
instead of OSPFv2, OSPFv3, ISIS and BGP. Then each OSPFv2, OSPFv3,<br>
ISIS and BGP would have CIC-to-x RFC. So people introducing new IGP<br>
features do not need to write 4 drafts, one is enough.<br>
<br>
I would include IPv4+IPv6 my-igp-of-choice SR in my RFP. Luckily ISIS<br>
is supported on platforms I care about for IPV4+IPV6, so I'm already<br>
there.<br>
<br>
> MPLS/VPN service signaling in IPv6-only networks also has gaps in SR.<br>
<br>
I don't understand this.<br>
<br>
<br>
> So for networks that run OSPF and don't run Juniper, they'd need to move to IS-IS in order to have SR forward IPv6 traffic in an MPLS encapsulation. Seems like a bit of an ask. Yes, code needs to be written, which is fine by me, as it also does for LDPv6.<br>
<br>
And it's really just adding TLV, if it already does IPv4 all the infra<br>
should be in place, only  thing missing is transporting the<br>
information. Adding TLV to IGP is a lot less work than LDPv6.<br>
<br>
> I'd be curious to understand what bugs you've suffered with LDP in the last 10 or so years, that likely still have open tickets.<br>
<br>
3 within a year.<br>
- PR1436119<br>
- PR1428081<br>
- PR1416032<br>
<br>
I don't have IOS-XR LDP bugs within a year, but we had a bunch back<br>
when going from 4 to 5. And none of these are cosmetic, these are<br>
blackholing.<br>
<br>
I'm not saying LDP is bad, it's just, of course more code lines you<br>
exercise more bugs you see.<br>
<br>
But yes, LDP has a lot of bug surface compared to SR, but in _your<br>
network_ lot of that bug surface and complexity is amortised<br>
complexity. So status quo bias is strong to keep running LDP, it is<br>
simpler _NOW_ as a lot of the tax has been paid and moving to an<br>
objectively simpler solution carries risk, as its complexity is not<br>
amortised yet.<br>
<br>
<br>
> Yes, we all love less state, I won't argue that. But it's the same question that is being asked less and less with each passing year - what scales better in 2020, OSPF or IS-IS. That is becoming less relevant as control planes keep getting faster and cheaper.<br>
<br>
I don't think it ever was relevant.<br>
<br>
> I'm not saying that if you are dealing with 100,000 T-LDP sessions you should not consider SR, but if you're not, and SR still requires a bit more development (never mind deployment experience), what's wrong with having LDPv6? If it makes near-as-no-difference to your control plane in 2020 or 2030 as to whether your 10,000-node network is running LDP or SR, why not have the choice?<br>
<br>
I can't add anything to the upside of going from LDP to SR that I've<br>
not already said. You get more by spending less, it's win:win. Only<br>
reason to stay in LDP is status quo bias which makes short term sense.<br>
<br>
> Routers, in 2020, still ship with RIPv2. If anyone wants to use it (as I am sure there are some that do), who are we to stand in their way, if it makes sense for them?<br>
<br>
RIP might make sense in some deployments, because it's essentially<br>
stateless (routes age out, no real 'session') so if you have 100k VM<br>
per router that you need to support and you want dynamic routing, RIP<br>
might be the least resistance solution with the highest scale. Timing<br>
wheels should help it scale and maintain great number of timers.<br>
<br>
--<br>
  ++ytti<br>
</blockquote></div>