Last week I received a form from APNIC with a new AS numbers. When I had a look through papers I saw there something strange: AS 123456 (I replaced the original with this number). 6 digits. First I thought that there is a mistake or something, then I recall the new 4-bytes ASN. If for IPv6 the things seems to be moving slower, than for the new format of AS numbers, it seems that the things are going faster. So faster that by January 1, 2010 all BGP speaker must support this feature, according to Cisco. I didn’t understood if they refer in the document for their products or it is something that is mandatory globally. No matter how, the things are moving quite fast in this direction.
Since I have to implement a BGP configuration with this 4-Bytes ASN, I started to search with Google friend about the standards and I was surprised that there is not to much to search after. Of course there is the official RFC, some other documentation, but not real examples how to configure, troubleshoot and so on. That’s why I said it’s nice to put something together for a general understanding of what is and how does it work this 4-Bytes ASN. I assume here that reader has a basic understanding of what ASN and BGP is.
RFC 4893 is the reference for “BGP Support for Four-octet AS Number Space”. Currently the Autonomous System number is encoded as a two-octet (2-bytes) entity in BGP, meaning 16bits and this was defined in RFC 4271. The new system is using a four-octet (4-bytes) , meaning 32bits. Currently the ASN 2-bytes include a range from 1 – 65535, used in decimal plain text when configuring the BGP. The expansion from 2-bytes to 4-bytes give us 4,294,967,295 AS number which can be written in ASPLAIN or ASDOT format.
Why two formats? Mainly due to different opinions about how the 4-bytes number should be represented:
The RIPE NCC assigns and registers 4-byte AS Numbers in ASPLAIN format.
ASPLAIN defines the 4-byte AS Number as a basic 32-bit integer.
“2-byte only AS Numbers” refers to AS Numbers in the range 0 – 65535
“4-byte only AS Numbers” refers to AS Numbers in the range 65536 – 4294967295”
“4-byte AS Numbers” refers to AS Numbers in the range 0 – 4294967295
– IETF preferred notation
– continuation on how a 2-Byte AS number has been represented historically
– does not break AS-PATH REGEX
– APNIC reached consensus to adopt ASPLAIN for assignment and representation of 4-byte AS Numbers
– routers vendors appear to be supporting ASPLAIN, which will require no conversion from allocation to configuration
– long number to remember
– All existing 4-byte only assignments have been made in ASDOT
The full binary 4-byte AS number is split two words of 16 bits each. It is proposed to identify 4-byte AS Numbers using a syntax of <high
order 16 bit value in decimal>.<low order 16 bit value in decimal>:
“2-byte only AS Numbers” refers to AS Numbers in the range 0 – 65535
”4-byte only AS Numbers” refers to AS Numbers in the range 1.0 – 65535.65535
“4-byte AS Numbers” refers to AS Numbers in the range 0.0 – 65535.65535
– easy to read and remember
-require conversion from ASPLAIN to ASDOT
-hard for regular expressions
What’s happening if in a BGP peering one router supports the new format and the other one only the old one. The new reserved ASN 23456 is used for backward compatibility between 4-bytes and 2-bytes BGP speakers. So, if your router advertise BGP with a 4-bytes as number (doesn’t matter in which representation ASDOT or ASPLAN), the peer which does not support the new format, will translate the 4-bytes ASN into 2-bytes ASN 23456. A graphical representation of the AS path from 4-bytes to 2-bytes in BGP would be:
OK, I hope you understand the basics of 4-bytes ASN. For me, some challenge was to understand to transform the 4-bytes ASN from ASPLAIN to ASDOT. In every document that I saw on the Internet there was the same example: AS 65546 in ASPLAIN is 1.10 in ASDOT, but without no explanation. See below how I understood that the conversion takes place. If I understood it wrong, please let me know, to correct it here. After all I’m not an 4-byte ASN expert, I just try to help as much as I can.
So let’s take the number 65546.
1. 65546 / 65535 = 1 (integer) which will be the parte in front of the . (dot) in ASDOT representation.
2. 65546 – ( 65535 * 1) = 11 (see how much rest remains after 65353 going once in 65546)
3. 11 – 1 = 10 which will be the part after . (dot)
4. You obtain 1.10
As a general rule, you have an ASPLAIN number. You take 65535 and see how many times it goes, with integer in the ASPLAIN number (1 time, 2 times, 3 times…depending). This will be your decimal number before dot in ASDOT format . Then you multiple the 65535 with the integer obtained in the first step and you deduct from the ASPLAIN number. From the rest after the second operation, you deduct the the decimal you have in front of the dot. The rest in decimal that comes after the dot .
What confused me is that the number in the example was so close to the last 2-bytes ASN which is 65535.
Now for the last example, let me take a random higher number 194534 (the example from the first line) and to obtain the ASDOT format.
1. 194534 / 65535 = 2 (integer)
2 194534 – ( 65535 * 2) = 194534 – 131070 = 63464
3 63464 – 2 = 63462
4 ASDOT = 2.63462
An online converter from ASPLAIN do ASDOT you can find here: http://as4.nullroute.se/index.php
For some more detailed explanation I would like to ask you to download the Cisco and Juniper documents regarding 4-bytes ASN implementation in BGP.
If you have any useful information about this topic or if something is wrong in my post, please comment and share your knowledge.
5 thoughts on “4-bytes Autonomous System Number”
Actually, to convert from ASPLAIN to ASDOT, the number to use is 65536. Divide by 65536 and write in “quotient.remainder” form. So for 65546, quotient is 1 and remainder is 10, hence 1.10 :)
Btw, great work on the graphical representation of the AS path. And your other post on 2-byte/4-byte was a great help too. Thanks!
As good as this post is there is issue with actual calculation of ASDOT, which is the primary concern for most who look here. Follow below link or see blow info.
ASPLAIN = X, and LET Y = 65536(always same value) and ASDOT = A.B where X/Y = A.xxxx (A is closet possible multiple of 65536) and B = X-(A*Y)
So finally you get ASPLAIN “X” = ASDOT “A.B”
Thanks for sharing this here. Your example is excellent and maybe more easy to use, but my article is based on this link from Cisco:
http://www.cisco.com/en/US/prod/collateral/iosswrel/ps6537/ps6554/ps6599/white_paper_c11_516829.html“All AS numbers between 0-65535..”
That’s why I used 65535.
I just came across with the URL from APNIC. “http://submit.apnic.net/cgi-bin/convert-asn.pl”
It is really good. No need to calculate. But really very good efforts and really a good calculation.