Hi David, this is going to be very useful, I really appretiate it, thank you very much.
Just some comments about the root causes of BGP related problems, maybe you find something useful from the research perspective, although probably this is not going to be new for you.
I found a few author groups with very related and useful papers:
- Tim Griffin and co.
- Nick Feamster and co.
- Jennifer Rexford and co.
- Lixin Gao and co.
These people often have joint publications but sometimes separate as well. Also, Craig Labovitz and co have some very useful papers in the area of routing convergence time.
The IRTF also has some interesting, futuristic and somewhat visionary drafts about "Future Domain Routing".
As I see things now, in case of BGP, routing divergence, configuration and policies have a very strong correlation.
A high level conclusion (what you probably can expect from half year paper- and presentation-reading research) is that the first root cause of BGP problems is the absence of a >>widely deployed and practical<< formal language for policies. Since there is no formal language, there is no compiler, and so you have unwanted anomalies resulting from your config.
My conclusion was that BGP has an analogy to software development:
SW: Specification=>High-level formal language (e.g. C++)=>Low-level formal language (assembly, binary, etc.)
Both steps can be called implementation or compiliation. The good thing here is that you have automated compilers for the second step, which is harder.
BGP: Business relation=>Policies=>Router configuration
First you implement your business relations, when you think out policies, but in the end you will have to implement/compile your policies as router configuration. The problem is, there is no automated compiler for the second step, since there is no formal policy language, and so verifcation is also very hard.
As a result you may have configuration bugs or your config is not doing what you originally wanted to do, or you have inconsistency among your routers, etc.
Of course, it is clear why such a formal language and compiler is not used in practice (different router vendors, different features, different capabilities, no standard interface, etc.), although there is, e.g., RPSL and the tools built upon RPSL. Lately, Griffin and co have begun thinking about a completely new policy language.
The second root cause that I think can be somewhat separated is that there is no practically used central database about policies. You do not necessary know what your neighbour operators are doing (their configs and policies). As a result you may have external inconsistency (that may lead to divergence, "wedgies", etc.).
Of course, here it is also clear why, e.g., IRRs are not used or not updated frequently (information hiding principle , which is actually the basis of the hierarchical domain structure of the internet).
So, in the end, although we can possibly identify the root causes behind BGP problems, I'm not sure they can ever be fully ceased. OK, I can imagine a formal language and config compiler, and one can find verification tools as well, but I can hardly imagine e.g. the sharing of policies (although some papers write about methods how to infer the necessary knowledge from measurements).
Thanks again for you help,
Andr�s
p.s. Sorry for the long mail