Fractal Rosette: A Stable Space-Ground Network Structure in Mega-constellation
←
→
Page content transcription
If your browser does not render page correctly, please read the page content below
Fractal Rosette: A Stable Space-Ground Network Structure in Mega-constellation Yuanjie Li, Hewu Li, Lixin Liu, Wei Liu, Jiayi Liu, Jianping Wu, Qian Wu, Jun Liu, Zeqi Lai, Guojie Fan Institute for Network Sciences and Cyberspace, Tsinghua University ABSTRACT A grand challenge for a usable space-ground network is We present F-Rosette, a stable space-ground network struc- to guarantee its stability under satellites and earth’s high arXiv:2105.05560v1 [cs.NI] 12 May 2021 ture for low-earth orbit (LEO) satellite mega-constellations mobility. Unlike the traditional satellite and terrestrial net- at scale. Due to the dynamic many-to-many space-ground works, the LEO network exhibits highly dynamic many-to- mapping in high mobility, existing LEO mega-constellations many mapping between the moving satellites and terrestrial with IP protocol stack suffer from frequent user IP address users. Each LEO satellite can cover ≈100,000 users, while changes (every 133–510s per user) and network routing re- each terrestrial user has visibility to ≈20 satellites in mega- convergence (thus ≤20% network usability). To provably constellations [8]. The high satellite mobility and earth’s stabilize the space-ground network under high dynamics, rotation force the terrestrial users to frequently re-associate F-Rosette aligns the network design in the cyberspace with to new satellites. Therefore, the network topology between the mega-constellations in the physical world. It devises a re- the space and ground repetitively changes, which results in cursively stable network structure over the Rosette constella- frequent network address changes and routing protocol re- tion, decouples the hierarchical network addresses from mo- convergence. Our projection of mega-constellations running bility for stability, and aligns the geographical routing on the IP protocols shows that (§2.2), every terrestrial user switches ground with the topological routing in space for efficiency its IP address every 133–510s (with 2,082–7,961 users chang- and high usability. Our hardware-in-the-loop, trace-driven ing IP addresses every second), and the network usability emulations validate F-Rosette’s stability, near-optimal rout- decreases to ≤20% with frequent routing re-convergence. ing (≤1.4% additional delays), and affordable overhead (
A small LEO satellite usually has very limited coverage, R computation power, and storage. To enable ubiquitous net- RE LEO H MEO work services, one possible solution is to deploy an LEO Earth satellite mega-constellation. Table 1 summarizes the statistics of com- sub-point mon mega-constellations today. The massive satellites help fully cover the areas of interest, while the LEO orbits en- Figure 1: Satellites, constellations, and their coverages. sure low ground-to-space round trips. Each satellite uses its microwave radio link for data transfer from/to terres- Num. Num. Altitude Inclination Ground-to- satellites orbits (km) angle space RTT (ms) trial users. Satellites can interconnect with each other via 1584/1584/ 72/72/ 550/540/ 53/53/ 3.7/3.6/ Starlink [1] 720/348/172 36/6/4 570/560/560 70/97/97 3.8/3.7/3.7 free-space laser inter-satellite links. Unlike the traditional Kuiper [2] 1156/1296/784 34/36/28 630/610/590 52/42/33 4.2/4.07/3.93 communications satellites at link layer only, LEO satellites in Telesat [3] 351/1320 27/40 1015/1325 98.98/50.88 6.77/8.83 Iridium [9] 66 6 725 86.4 4.83 the mega-constellations should route traffic at the network Table 1: Statistics of common LEO constellations. layer and inter-connect to other terrestrial networks (e.g., via TCP/IP) for global Internet services at scale (acknowledged by Elon Musk [11] and recent work [12, 13]). retaining high network usability. Routing between satellites follows the standard IPv6 prefix/wildcard matching with 2.2 Unstable Space-Ground Network Today provable optimality and multi-path support. To route traffic The LEO mega-constellations aim to enable usable and per- between terrestrial users, F-Rosette performs local geo- formant network services for terrestrial users. Unfortunately, graphical routing by embedding it into the topological rout- our analysis and trace-driven emulation project that, with ing between satellites over the stable network topology. For the dynamic many-to-many space-ground mapping in high practical deployment, F-Rosette is backward compatible mobility, existing mega-constellations running standard IP with IPv6, supports incremental expansion, and facilitates will suffer from frequent IP address changes for the users and inter-networking to external networks. routing re-convergence for the network (thus low usability). We prototype F-Rosette’s protocol suite and evaluate it Why unstable: Dynamic many-to-many mapping In with hardware-in-the-loop, trace-driven emulations. Com- LEO mega-constellations, the many-to-many mapping be- pared to existing mega-constellations, F-Rosette stabilizes tween satellites and terrestrial users is a norm rather than an network topology, addressing, and routing with near-optimal exception. Each LEO satellite can cover many users (≈100,000), data delivery (≤1.4% additional delay). F-Rosette incurs while each terrestrial user has visibility to many satellites negligible CPU (
1HWZRUN8VLELOLW\ 1HWZRUN8VLELOLW\ FKDQJH,3SHUVHFRQG 1XPEHURIXVHUVWKDW ,QWHUYDOEHWZHHQ ,3FKDQJHV VHF 500 15000 400 10000 300 200 5000 100 0 0 Starlink Telesat Kuiper Iridium Starlink Telesat Kuiper Iridium (a) Interval between changes (b) IP changed users per second &RQVWHOODWLRQ6FDOH &RQVWHOODWLRQ6FDOH Figure 2: Projected users’ IP address change frequency (a) Starlink (b) Kuiper in LEO mega-constellations in the direct access mode. Figure 3: Projected network usability in LEO mega- satellite network at different locations. (2) Ground station- constellations in ground station-assisted mode. assisted access: Terrestrial users associate to a ground station [16, 17], which connects to a satellite for network access. Users in the direct access mode will experience more hand- We assume six ground stations in New York, Tokyo, Beijing, offs with more satellites, thus causing more frequent IP ad- Hong Kong, Shanghai, and Singapore; the results for ground dress changes. For the network in the ground station-assisted stations at other locations are similar. We assume each user mode, Figure 3 shows more satellites prolong the routing or ground station will always associate to the physically re-convergence on link change, thus lowering the network nearest satellite for good coverage [18]. All network nodes usability. Moreover, more satellites complicate the dynamic run the IPv6 stack and OSPF. Figure 2 and Figure 3 show the routing between the moving satellites and terrestrial users projected impact on the users and the network, respectively. (due to the earth’s rotation). Solutions for small LEO net- ◦ Impact on users: Frequent IP address changes. In the direct works decades ago (e.g., virtual topology [19, 20] and virtual access mode, a terrestrial user’s IP address belongs to the nodes [21, 22]) cannot scale to the mega-constellations today subnet of the corresponding satellite logical network inter- due to their vulnerability to dynamic many-to-many map- face. With rapid satellite motions, the terrestrial user has ping, and expensive (pre-)computation and storage for small to frequently handoff to new satellites (thus new network LEO satellites. Motivated by this, we next design F-Rosette, interfaces and addresses) to retain its Internet access. As a stable space-ground network structure for LEO mega-constellations. shown in Figure 2, each user is forced to change its logical IP address every 133–510s, and every second we observe 3 THE F-ROSETTE NETWORK STRUCTURE 2082–7961 global users per second should change their IP We introduce F-Rosette’s structure and its basic properties. addresses. Such frequent address changes will repetitively disrupt the TCP connections and upper-layer applications, 3.1 A Primer of Rosette Constellation and will negatively impact the user experiences. The basic building block of F-Rosette is a Rosette constella- ◦ Impact on network: Frequent routing re-convergence and tion, which was originally proposed in [23] to guarantee full low usability. To prevent frequent user IP changes, one can coverage with as few satellites as possible. This section in- adopt the ground station-assisted access mode. In this mode, troduces the necessary background of Rosette constellation the ground station is a gateway for a fixed IP subnet, so that for F-Rosette; a complete description is available in [23]. all users associating with it retain the time-invariant address. Figure 4 exemplifies the Rosette constellation with 8 satel- As the ground station re-associates to a new satellite, the lites. Each orbit has one satellite, and all satellites move in space-ground logical network topology changes. Then the circular orbits at the altitude of (thus period ). A Rosette IP routing must re-converge to guarantee reachability to this constellation is defined as a tuple ( , ), where is the ground station, before which the network cannot route traffic number of satellites and ∈ N is a harmonic phase shift. to the ground station. Note each LEO satellite can only pro- All satellites are numbered from 0 to − 1. For satellite , its vide very short coverage for a ground station (10 minutes in runtime location can be described by three constant angles Iridium, ≤3 minutes in Starlink). Frequent handoffs between ( , , ) and one time-varying phase angle at time : satellites result in repetitive routing re-convergence and thus routing re-convergence duration low network usability (i.e., 1− each satellite’s service duration ). Fig- 2 ure 3 shows that, all mega-constellations today suffer from = , = 0, 1, ..., − 1 (1) ≤ 20% network usability even under small constellations. ≡ , ∀ (2) The network usability decreases with more satellites, which 2 causes more frequent handoffs for ground stations. = = · (3) How mega-constellation amplifies instability: Both issues will worsen with more satellites in the mega-constellations. 2 = (4) 3
0 7 1 Algorithm 1 F-Rosette construction. Input: A Rosette constellation ( , , ) , and a F-Rosette level ≥ 0 6 2 Output: F-Rosette γi 1: F-Rosette0 = ( , , ) Rosette constellation; α=0 2: for j=1 to k do αi β 3: F-Rosette = { }; 4: for i= 0 to N-1 do ⊲ Step 1: Construct F-Rosette −1 s 5 3 5: F-Rosette −1 = Shift ( F-Rosette −1 , 2 ) ; i-th point of 6: F-Rosette .append(F-Rosette −1 ); right ascension 4 7: end for (a) Physical constellation in space (b) Logical topology in F-Rosette0 8: for i=0 to N-1 do ⊲ Step 2: Inter-connect F-Rosette −1 s Figure 4: A Rosette constellation with = 8, = 6. 9: for each satellite in F-Rosette −1 do ( +1 mod ) 10: Connect to ( +1 mod ) in F-Rosette −1 ; where is satellite ’s right ascension angle, ≡ is the 11: end for inclination angle for all orbits, is ’s initial phase angle 12: end for 13: end for in its orbit at time = 0, and is the time-varying phase 14: return F-Rosette ; angle (identical for all satellites anytime). Compared to other constellations, the Rosette constellation has two appealing primarily designed for full coverage rather than network properties for networking: routing. There was no specification on how to inter-connect Full coverage with fewer satellites: The Rosette con- satellites, how to forward traffic among satellites, and how stellation usually needs fewer satellites than Walker (build- to route data among terrestrial users via satellites. This mo- ing block for Starlink and Kuiper) and polar orbits for full tivates us to re-struct the Rosette constellation for stable coverage (see [23] and §7.1 for the evaluations). Each satel- space-ground network at scale. lite’s coverage in Figure 1 can be determined by its altitude and elevation angle : 3.2 F-Rosette Construction cos − /( + ) tan = (5) F-Rosette adopts the Rosette constellation as a base case, sin but extends it recursively with inter-satellite links. Specifi- For LEO satellites, given each satellite’s coverage on cally, a F-Rosette0 is a ( , ) Rosette constellation in §3.1, the earth, the minimum number of satellites needed to with inter-satellite links in adjacent satellites (exemplified fully cover the earth is decided by the following relation: in Figure 4b) and ground-track repeat orbits for all satel- √ lites. A F-Rosette ( ≥ 1) is constructed recursively from sec = 3 tan (6) F-Rosette −1 s. Algorithm 1 shows F-Rosette construc- 6 − 2 tion. It takes two phases (exemplified in Figure 5): Periodic ground-track repeat orbits: Due to the earth (1) Construct F-Rosette −1 s: The F-Rosette −1 s are rotation and high LEO satellite mobility, the satellite sub- 0 1 numbered from 0 to − 1 as F-Rosette − 1 , F-Rosette − 1 , point in Figure 1 is time-varying and non-repeatable in gen- − 1 ..., F-Rosette −1 . As shown in Figure 5a, F-Rosette −1 eral3 (exemplified in Figure 10). This complicates locating and is obtained by first duplicating a F-Rosette − 0 , and then routing between the ground and space. Instead, the Rosette 1 shifting it by a time interval = (or equivalently a phase constellation allows LEO satellites to retain periodic satellite sub-points via ground-track repeat orbits, i.e., every satellite angle shift = 2 · = 2 according to Equation 4). Each 0 will periodically revisit its previous satellite sub-point. To do satellite in F-Rosette − 1 is replicated times on the 0 1 same orbit, denoted as , , ... −1 . so, we configure the satellites’ orbital period such that = /( − ) (7) (2) Interconnect F-Rosette −1 s: The next step is to bridge F-Rosette −1 s with intra-orbit inter-satellite links only. As where is the period of earth rotation. For each satellite , shown in Figure 5b and Figure 5c, each in F-Rosette −1 the latitude and longitude of its sub-point is: ( +1 mod ) ( = 0, 1, ..., −1) adds a link to ( +1 mod ) in F-Rosette − 1 . sin = sin sin ( − ) (8) This creates a circle among satellites on the same orbit. tan [ + ( − )] = cos tan ( − ) (9) 3.3 Basic Properties of F-Rosette where = 2 / is the earth’s angular rotation speed. F-Rosette inherits all good properties from the classical Despite these merits, however, the original Rosette constel- Rosette constellation in §3.1, and has additional appealing lation is not immediately applicable to networking. It was features for networking due to its recursive architecture. 3 The geostationary satellites guarantee time-invariant satellite sub-point, Network structure size: A F-Rosette has +1 satel- but at the altitude of 35,786km and thus suffer from long network latency. lites and ( + 1) +1 inter-satellite links. Table 2 exemplifies 4
T t= Nk 0.0 1.7 2.6 3.5 2m 0.1 0.7 1.0 1.6 2.7 2.5 3.6 3.4 shift angel= t =0 Nk F-Rosette 0 0 0.6 F-Rosette 1 01.5 F-Rosette 2 02.4 F-Rosette30 0.2 3.3 0.3 0.5 1.2 1.4 2.1 2.3 3.0 3.2 0.4 1.3 2.2 3.1 7.1 6.2 5.3 4.4 7.2 7.0 6.3 6.1 5.4 5.2 4.5 4.3 7 6 5 F-Rosette 0 F-Rosette 0 F-Rosette 0 F-Rosette04 7.3 7.7 6.4 6.0 5.5 5.1 4.6 4.2 7.4 7.6 6.5 6.7 5.6 5.0 4.7 4.1 7.5 6.6 5.7 4.0 (a) Shift(F-Rosette, t) in Algorithm 1 (b) Logical network topology of F-Rosette ——Inter-satellite links O Coverages —— Satellite sub-point trajectory ◇ F-Rosettek -1 Cells ◇ F-Rosettek Cells O coverages ——Orbits (c) Physical constellation in 3D space (d) Hierarchical geographical cells by fixed satellite sub-point trajectories. Figure 5: Recursive construction of F-Rosette. Table 2: F-Rosette’s satellites’ altitude with =8/16, the scale when = 8.Each satellite has 2( +1) inter-satellite =1, and the elevation angle = 25◦ . links, which is affordable even for small LEO satellites (typi- Num. Minimun Ground-to- Avg. cell cally 4–5 links [12, 13]). satellites altitude (km) space RTT (ms) size (km2 ) F-Rosette0 Full coverage: Each F-Rosette is also a Rosette con- 8 11848.46 78.99 9,060,419 = 16 = 8 F-Rosette1 64 1259.58 8.40 141,569 stellation and thus can ensure full coverage. Specifically, we F-Rosette2 512 335.33 2.23 2,212 have the following theorem (proved in Appendix A): F-Rosette0 16 4268.73 28.46 1,973,158 F-Rosette1 256 504.83 3.36 7,707 F-Rosette2 4096 107.62 0.72 30 Theorem 1 (Full coverage). A F-Rosette guarantees full coverage if its satellites’ altitude > , where specifying the minimum altitude of all satellites, as shown 1 below (proved in Appendix C): = −1 cos − sin tan Theorem 2 (Stable network topology). The network topology √ +1 = sec −1 3 tan of a F-Rosette remains stable if its satellites’ altitude > 6 +1 − 2 max{( 1 − 1) , }, where is the max great 2 circle range of inter-orbit links and is the earth radius. With this full coverage guarantee, a satellite operator can Stable satellite sub-point trajectory: F-Rosette always customize the F-Rosette size to meet its demands. In Ap- adopts the Rosette constellations with ground-track repeat pendix B, we show how to select the size given the demand orbits = /( − ). As shown in Figure 5d, this results in of ground-to-space RTT and the minimum elevation angle. stable and periodic satellite sub-point trajectory. As we will Stable network topology: F-Rosette guarantees time- see in §4, these trajectories enable hierarchical space-ground invariant network topology despite satellites’ high mobility network addresses and simplify routing. and earth’s rotation. This is desirable to simplify the routing Propagation delay of an inter-satellite link: Despite and ensure high network usability (§2.2). F-Rosette guar- high satellite mobility, F-Rosette retains regular and pre- antees the logical connection between any two satellites dictable delay variations for each inter-satellite link. For intra- remains always-on and unchanged. This can be achieved by orbit links, F-Rosette guarantees fixed propagation delay 5
Cell of F-Rosettek-1 l = -0 l=0 l = 0 0 row 0 ...N-m-1 0 1 2 3 ... between two satellites, due to their time-invariant distances. 1 ... ...N-m-1 0 1 2 3 ... row k For the inter-orbit links, its length (thus propagation delay) 0≤k≤a-b N-2 ...N-m-1 0 1 2 3 ... unavoidably varies over time. For any two satellites and row a-b N-1 N ... 2N-1 2N-2 in different orbits, its inter-satellite link length and propagation delay : (a) Base case (k=0) (b) Hierarchical cells Figure 6: Hierarchical geographical cells in F-Rosette. ( ) = 2 ( + ) sin ( )/2 (10) 1 M M+1 M+klogN 128 ( ) = ( )/ (11) Network prefix 0 s0 s1 … sk Suffix (a) Satellite address where ( ) is the range between and on the great 1 M M+1 M+1+2log2(N-m) M+1+2log2(N-m)+klog2N(2N-1) 128 circle: c0 c1 … ck Network prefix 1 User suffix row0 col0 row1 col1 … … rowk colk sin2 ( ( )/2) = cos4 ( /2) sin2 ( + 1) ( − ) ( / ) For internetworking F-Rosette hierarchical Per-user identifier to external network geographical cell (unique in each cell) 2 2 2 + 2 sin ( /2) cos ( /2) sin ( − ) ( / ) (b) Ground address 4 2 + sin ( /2) sin ( − 1) ( − ) ( / ) Figure 7: Embedding F-Rosette into IPv6 address. + 2 sin2 ( /2) cos2 ( /2) sin2 ( − )( / ) F-Rosette’s satellites. The F-Rosette cells exhibit three 4 · cos[ + 2 ( + ) ( / )] appealing features for satellite routing in space: Stable geographical cells: F-Rosette’s satellites run on (12) the ground-track orbits (§3.2), which implies all satellite sub- Note such delay is periodic and bounded, thus facilitating point trajectories are time-invariant. Therefore, despite the delay-sensitive apps. We will evaluate the link delay in §7.1. high satellite mobility and earth’s rotation, each F-Rosette cells’s location, size, and coverage are fixed and invariant. 4 NETWORK ADDRESSING IN F-ROSETTE Hierarchical geographical cells: F-Rosette’s recursive We next define F-Rosette’s hierarchical network addressing and symmetric structure forms a hierarchy of cells. With re- for space and ground. We show how F-Rosette decouples cursive construction, each cell in the F-Rosette −1 will be its network addressing from mobility for stability, and avoids divided into a group of sub-cells in F-Rosette . This hierar- frequent user IP changes in §2.2. chy is exemplified in Figure 6b and validated by the following theorem (proved in Appendix D): 4.1 Hierarchical Addressing for Satellites Theorem 3 (Hierarchical geographical cells). When con- F-Rosette’s recursive structure naturally defines hierarchi- structing F-Rosette from F-Rosette −1 , each geographical cal network addresses for its satellites. We assign each satel- cell in F-Rosette −1 will be divided in to 2 disjoint sub-cells lite in F-Rosette with a hierarchical address 0 . 1 . 2 ... in F-Rosette . ( = 0, 1, ..., −1, ∀ ). Each digit represents the correspond- We also have the total number of cells in a F-Rosette as ing F-Rosette structure that belongs to. The length of follows (proved in Appendix F): this satellite address is log bits (which is usually small as evaluated in §7.2). This hierarchical address can be naturally Lemma 1. A F-Rosette divides its coverage areas into embedded into IPv6’s address space, as shown in Figure 7a. ( − ) 2 2 disjoint cells. It is constant despite satellite mobility, since it only relies on Network addressing for the ground: F-Rosette as- F-Rosette’s stable network topology. signs geographical address to each ground user based on the cell it resides. Figure 7b illustrates how this geographical 4.2 Hierarchical Addressing for Ground cell ID can be readily realized embedded into IPv64 . For each To stabilize the addressing in high mobility, F-Rosette di- user in this cell, F-Rosette assigns its address as a concate- vides the earth’s spherical surface into a hierarchy of dis- nation of new prefix, hierarchical geographical ID, and the joint geographical cells and allocates cell-based addresses to user suffix. The network prefix is used for inter-networking terrestrial users and ground stations. In this way, the net- with external networks and backward compatibility with work addresses are decoupled from the satellite and earth standard IPv6 (§6). The per-user suffix guarantees the glob- mobility, thus free of frequent changes (§2.2). They are un- ally unique address inside each geographical cell. In this way, changed unless the users move to a new geographical cell. the user address remains invariant unless (s)he moves to a Figure 5d exemplifies F-Rosette’s cells. Each cell is a quadri- 4 Besides IPv6, this address can also be embedded into the future architecture lateral bounded by four satellite sub-point trajectories of such as NDN [24, 25], SCION [26], MobilityFirst [27], and XIA [28]. 6
Algorithm 2 Shortest-path satellite routing in F-Rosette. 0.0 1.7 Destination Next hop 0.1 Input: Source satellite address = 0 . 1 . 2 ... , destination satellite address 0.7 1.0 1.6 001.xxx 001.000 = 0 . 1 . 2 ... , and a permutation = [ 0 , 1 , ..., ] of [0,1,...,k] 000.0xx 000.001 0.2 0.6 1.5 Output: A path from to 1: path(S,D)={S,}; next_hop=S; 000.1xx 000.111 2: for i= 0 , 1 , ..., do ⊲ The permutation shuffles indexes for multi-path routing 0.3 0.5 1.2 1.4 0.4 1.3 3: if next_hop[i] − mod N ≤ /2 then ⊲ Clockwise routing is shorter 4: while next_hop[i] ≠ do 5: next_hop[i] = next_hop[i]+1 mod N; Figure 8: Prefix/wildcard match in F-Rosette routing. 6: path(S,D).append(next_hop); 7: end while new cell (which is rare due to the cell size in Table 2). To help 8: else ⊲ Counter-clockwise routing is shorter 9: while next_hop[i] ≠ do detect if the address is for satellite or ground for routing in 10: next_hop[i] = next_hop[i]-1 mod N; §5, we add a 1-bit flag to differentiate their addresses. 11: path(S,D).append(next_hop); 12: end while We next elaborate on how to allocate the hierarchical 13: end if geographical cell IDs. A geographical cell in F-Rosette is 14: end for 15: return path; uniquely identified by 0 . 1 ..., . , where 0 = 0, 1, ...( − ) 2 −1 and = 0, 1, ..., 2 −1( ≠ 0). Each digit represents the corresponding F-Rosette cell identifier that this user = [ 0, 1, ..., ] of indexes 0,1,...,k is also given as an in- belongs to, and can be further decomposed into a row ID put to facilitate the enumeration of multiple paths (detailed and column ID . For F-Rosette0 , its sub-satellite below). To route traffic from to , we follow the permu- point trajectories and two latitude lines divide the earth into tation to traverse all layers of F-Rosette . At each layer − row and − columns, and we identify each cell , all satellites form a ring topology according to §3.2. The with the left point. As shown in Figure 6a, we number each shortest path is either the clockwise or counter-clockwise row from 0 to − − 1 from north to south. Starting from routing. To find the shortest path, we first decide the routing the cell whose left dot is on the trajectory of satellite 0 above direction, and then increment (or decrement) the -th digit the equator and its extension line, each column is numbered of the previous satellite’s address, until the -th digit equals from 0 to − − 1 according to the increasing direction of the destination’s corresponding digit . The correctness of the longitude value. Next, a F-Rosette ( ≥ 1) divides each Algorithm 2 is therefore straightforward: cell in F-Rosette −1 ( ≥ 1) into 2 − 1 layers. We number Theorem 4 (Shortest path). Algorithm 2 finds the shortest each layer from 0 to 2 − 2 in the direction from north to path in hop counts between any two satellites. south, and at the same time, we number cells in each layer from left to right. Encoding this hierarchical geographical F-Rosette’s routing exhibits three desirable features: cell address requires 2 log + 2 [( − )] bits (which (1) Stable and highly usable without re-convergence: Algo- is usually small for IPv6, as evaluated in §7.2). rithm 2 avoids global routing (re-)convergence in F-Rosette’s regular and stable topology, thus retain high usability despite 5 ROUTING IN F-ROSETTE dynamic many-to-many mapping (§2.2). With F-Rosette’s regular structure, the satellite’s address inherently implies We describe how F-Rosette enables stable, highly-usable, the routing path. Each satellite can locally decide the next and efficient routing without re-convergence (§2.2). We first hop without global routing (re-)convergence. show how to route between satellites over F-Rosette’s sta- (2) Prefix/wildcard-based routing table: With F-Rosette’s hi- ble graphical topology (§5.1). Then we show how to route erarchical satellite address, Algorithm 2 can be realized with between ground users by embedding hierarchical geograph- the standard prefix/wildcard matching in IP networks. Fig- ical routing into the satellites’ topological routing (§5.2). ure 8 exemplifies the routing table for Algorithm 2. With the ring topology at each F-Rosette layer, destinations with 5.1 Topological Routing for the Satellites the same prefix (or layer) can be aggregated as a single With its stable and regular constellation, F-Rosette supports entry in the standard routing table. The storage required efficient and highly-usable single/multi-path routing that is by the F-Rosette routing table is also small for memory- compatible with standard Internet routing mechanisms. constrained satellites (proved in Appendix E): Single-path routing: With F-Rosette’s regular topol- Theorem 5 (FIB storage bound). Each satellite in a F-Rosette ogy, a satellite can locally compute the shortest path without has at most 2( + 1) ⌈log 2 ⌉ entries in its routing table. global routing (re-)convergence and thus avoids low net- work usability in §2.2. Algorithm 2 shows the shortest-path (3) Performance bound: F-Rosette’s regular structure also routing from a source satellite = 0 . 1 . 2 ... to a destination provides bounded latency for its single-path routing. The = 0 . 1 . 2 ... defined in §4.1. A pre-defined permutation upper bound can be derived from Algorithm 2 as follows: 7
0 0 01 2 12 12 0 0° 12 11 c0d.c1s 2 14 −3 … … 21 2 Algorithm 3 F-Rosette’s geographical routing for ground. 0 . 0 10.76° 12 12 … … … 12 2 Input: Source user’s serving satellite’s = ( ( ), ( )) and destination user’s 1 16 −4 cell = ( , ) − −1 12.69° −1 0 Output: A routing path from to through F-Rosette satellites 00 , γ = ( 0 + ⋅ Δ , ( − ) 0 ) 1: path(S,D)={S,}; next_hop=S; 2: Δ = − ( ) mod 2 ; Δ = − ( ) mod 2 ; 3: if Δ < then ⊲ Clockwise routing is shorter Figure 9: Hierarchical geographical routing for users. 4: while Δ ≥ 2 do 5: next_hop[0] = next_hop[0]+1 mod N; Theorem 6 (Hop bound). The maximum number of hops 6: Δ = Δ − 2 mod 2 ; Δ = Δ − 2 mod 2 ; between two satellites in F-Rosette is no more than ( +21) . 7: path(S,D).append(next_hop); goto Line 31 if next_hop covers ; 8: end while 9: else ⊲ Counter-clockwise routing is shorter Multi-paths: F-Rosette also offers abundant parallel 10: while Δ ≥ 2 do 11: next_hop[0] = next_hop[0]-1 mod N; paths for performance acceleration and fault tolerance. By 12: Δ = Δ + 2 mod 2 ; Δ = Δ + 2 mod 2 ; enumerating the permutations of the F-Rosette layers 13: path(S,D).append(next_hop); goto Line 31 if next_hop covers ; [0,1,...,k], Algorithm 2 yields parallel paths from the same 14: end while 15: end if source-destination pair. The following theorem shows the 16: for i=1,2,...,k-1 do available paths in F-Rosette (proved in Appendix G): 17: if Δ < then ⊲ Clockwise routing is shorter 18: while Δ ≥ 2 do Theorem 7 (Multi-path). There are 2( + 1) disjoint parallel 19: next_hop[i] = next_hop[i]+1 mod N; 20: Δ = Δ − 2 mod 2 ; paths between any two satellites in a F-Rosette . 21: path(S,D).append(next_hop); goto Line 31 if next_hop covers ; 22: end while Stability and high network usability: With its stable 23: else ⊲ Counter-clockwise routing is shorter 24: while Δ ≥ 2 do network topology, F-Rosette ensures stable routing despite 25: next_hop[i] = next_hop[i]-1 mod N; high mobility. Each satellite locally routes traffic without 26: Δ = Δ + 2 mod 2 ; requiring slow global (re)-convergence. This prevents the 27: path(S,D).append(next_hop); goto Line 31 if next_hop covers ; low network usability as discussed in §2.2. 28: end while 29: end if 30: end for 5.2 Geographical Routing for the Ground 31: return path; F-Rosette adopts geographical routing to deliver traffic be- tween terrestrial users. Geographical routing is appealing facilitating the geographical-to-topological routing below. for its efficiency, scalability, and high network usability. It In this coordinate, each satellite’s sub-point location ( , ) takes the physically short path to forward the traffic. More- can be mapped to the runtime latitude and longitude as over, geographical routing can be mostly performed locally follows (derived from Equation 1, 3, 8, and 9): without global routing (re-)convergence, thus avoiding low sin = sin sin ( − ) network usability in mobility (§2.2). tan ( + − ) = cos tan ( − ) F-Rosette supports native hierarchical geographical rout- ing for the ground. As shown in Figure 9, data from cell Due to the high mobility, a satellite sub-point’s longitude 0 . 1 .... to 0 . 1 .... in §4.2 can traverse from to at shifts over time with dynamic mapping between ( , ) and each level of the F-Rosette cells. In F-Rosette, this geo- ( , ). Despite so, it is easy to verify from Equation 1–4 that, graphical routing can be converted to an equivalent topolog- the relative position (Δ , Δ ) between any two connected ical routing between satellites in §5.1, thus retaining stability satellites’ sub-points remains constant. This results in an and efficiency. We next elaborate on it. important property to bridge the topological routing between Space-ground alignment with F-Rosette coordinates: satellites and geographical routing between ground cells: The first step for F-Rosette’s geographical routing is to Property 1 (Space-ground routing alignment). A packet align the logical satellite address in the cyberspace and ground routed through an inter-orbit satellite link in F-Rosette moves locations in the physical world. F-Rosette’s structure im- a fixed relative position of plies a geographic coordinate system that facilitates this. 2 2 Figure 4a exemplifies this coordinate system. Different from Δ 0 = , Δ 0 = the classical Cartesian coordinates or latitudes/longitudes, F-Rosette defines the position of each location on the earth A packet routed through an intra-orbit satellite link at layer as ( , ), where is its right ascension angle, and is the = 1, 2, ... moves a fixed relative position of phase angle along a virtual orbit of inclination across the 2 right ascension angle. This coordinate aligns the ground lo- Δ = 0, Δ = cation with F-Rosette’s satellite sub-point trajectories, thus 8
Geographical-to-topological routing embedding: Prop- erty 1 implies routing between satellites in Algorithm 2 is (a) = 0 (b) = / equivalent to traversing a fixed relative position in F-Rosette’s Figure 10: Exploiting regular satellite mobility to guar- coordinate system. Given two cells = 0 . 1 .... and = antee data delivery in flat incremental expansion. 0 . 1 .... , one can compute their relative position (Δ , Δ ) via table lookup (detailed below), and route the traffic from computing the source user’s serving satellite’s runtime loca- to by following the topological routing in Algorithm 2 tion ( ( ), ( )) for all packets, the satellite can cache its to hierarchically shorten the packet’s relative position to . runtime location and refresh it every 2 seconds (which This is equivalent to the geographical routing in Figure 9. guarantees consistent forwarding decision given the minimal Algorithm 3 elaborates on the geographical ground rout- (Δ , Δ )). Last but not least, to avoid repetitive next-hop ing via topological satellite routing. It extends Algorithm 2, calculation for the packets to the same destination cell, a and maps the relative motion to hop count. It uses the source satellite can create a cached geographical FIB entry and pe- user’s serving satellite’s sub-point as the input, which is lo- riodically update it every 2 seconds. cally maintained by the satellite as ( ) = (0)− 2 , ( ) = Stability and high network usability: F-Rosette em- (0) + 2 (Equation 1–4). The routing ends if the user on beds geographical routing into F-Rosette’s stable network in target cell is covered by the current satellite (detected if topology, thus facilitating stable routing. Similar to topologi- the current satellite finds the user associates to it at the link cal routing in §5.1, F-Rosette’s geographical routing relies layer). Algorithm 3 can be realized atop Algorithm 2, thus on local information only. It does not require the slow rout- retaining high efficiency for resource-constrained satellites. ing (re)-convergence, thus retaining high network usability Avoiding local minimum and last-hop ambiguity: A despite high satellite mobility and earth’s rotation (§2.2). classical problem for the greedy geographical routing is the local minimum [29–32], i.e., the physically nearest satellite 6 ISSUES IN PRACTICAL DEPLOYMENT is not reachable for delivery (mostly due to limited coverage). This problem is largely mitigated in F-Rosette: Similar to In this section, we discuss various issues and solutions for greedy embedding [33, 34], geographical routing in Algo- the deployment of F-Rosette in practice. rithm 3 relies on topological routing in §5.1 for guaranteed Incremental expansion: In practice, it is unlikely to reachability and successful delivery. The only exception is deploy F-Rosette all at once. The satellites can only be the last hop, where the terrestrial user does not associate to launched to space incrementally. For example, as of January the nearest satellite. Since the ground-satellite link depends 2021, the latest SpaceX Falcon 9 rocket can launch up to 143 on user-specific satellite selection strategy and is beyond the satellites each time [35], which is less than F-Rosette1 ’s satellite topology, simply relying on topological routing is 256 satellites when = 16. When incrementally expand- insufficient to guarantee delivery. Fortunately, Algorithm 3 ing F-Rosette in space, it is desirable to retain always-on, over F-Rosette’s ring structure implies all satellites at each seamless network services for existing users. This demand layer can be reached in the worst case. This ensures eventu- results in three concrete goals in expansion: (1) guarantee ally the user-selected satellite will be reached for successful data delivery despite incomplete deployment; (2) avoid re- delivery, at some cost of detouring delays. interconnection of satellites whenever possible; and (3) retain Data forwarding acceleration via table lookup: Sim- stable address during the deployment. ilar to the topological routing, geographical routing in Algo- A straightforward way to incrementally deploy F-Rosette rithm 3 can also be accelerated via table lookup at least four is to follow Algorithm 1, i.e., launch F-Rosette −1 first and aspects. First, the relative motion between connected satel- recursively expand it to F-Rosette . This ensures stable net- lites (Δ , Δ ) can be pre-computed and pre-stored in each work topology and addresses, but can’t guarantee delivery FIB entry, thus avoiding runtime per-packet computation in with partial coverage before all satellites are launched (§3.2). Algorithm 3. Second, to decide the destination cell’s location To this end, we propose an iterative incremental expan- ( , ) given its cell ID 0 . 1 ..... , each satellite can pre- sion scheme, and exploit regular satellite mobility to guaran- compute and store a hierarchical lookup table as shown in tee the data delivery. Instead of building F-Rosette from Figure 9. Since all geographical cells are formed by the satel- F-Rosette −1 , we incrementally deploy it orbit by orbit. Fol- lite sub-points, one can follow Equation 8–9 to pre-compute lowing step 8–12 in Algorithm 1, each time we deploy satel- each cell’s location for hierarchical lookup. This results in lites that uniformly distribute on the same orbit. As exempli- fied in Figure 10, F-Rosette satellites in the same orbit form a table with ( − ) 2 entries and ( + 1) runtime lookup a moving wave of satellite sub-point trajectories that traverse time (elaborated in Appendix H). Third, to avoid repetitively the entire coverage. This differs from the satellite sub-points in a complete F-Rosette −1 , which are fixed and thus limit 9
Quagga F-Rosette address Routing (§5) resolution (§4) Control plane Data plane No FIB entry Add FIB entry its full coverage at lower altitude. As the satellite sub-point FIB lookup Data forwarding trajectories move, all users have the opportunity to send IPv6 pkt IPv6 pkt the data to the satellite sometime. If a packet’s destination IPv6 protocol stack (Linux kernel) SAT/earth trajectories is currently outside the coverage, it can be buffered by the Constellation Inter-SAT links satellite and eventually delivered if any one of the satellite F-Rosette configuration (§3) StarPerf on the same orbit covers the destination. With more satel- Starlink Kuiper Telesat State-of-the-art constellations lites deployed, more packets will be delivered via routing Hardware-in-the-loop emulators and less packets will be buffered. Similar to DTN in classical Figure 11: Hardware-in-the-loop experimental setup. satellite networking [36, 37], this approach is feasible when the F-Rosette users are all tolerant to data delays. Table 3: F-Rosette under the same altitude and eleva- Implications for ground stations: The ground stations tion angle of state-of-the-art mega-constellations. can play as “gateways” to bridge the satellite and terres- Number of Altitude Inclination Min. number of trial networks, or download telemetry data from satellites satellites (km) angle satellites in F-Rosette [16, 17, 38, 39]. It is desirable to deploy the ground stations Starlink 1584 550 53 676 Kuiper 1156 630 51.9 676 where they can maximize its radio quality and access to more TeleSat 351 1015 98.98 225 satellites. F-Rosette’s stable satellite-to-ground mapping offers a natural solution for this. A ground station using with -local links. In this case, the maximum number of hops F-Rosette can be deployed at the intersection of the fixed in Theorem 6 can be reduced to ( + 1) 2 . The cost is more link satellite sub-point trajectories. This guarantees maximal re- failures (Theorem 2) and unstable routing. We are neutral to ceived power from the satellites (right above the ground this tradeoff and leave it for the operators to decide. station), and helps gain visibility to more satellites. Network address allocation: The satellites’ F-Rosette addresses in §4.1 are fixed and can be pre-allocated before 7 EVALUATION they are launched. For the ground users, their F-Rosette We evaluate the efficiency and overhead of F-Rosette’s net- addresses in §4.2 are fixed unless they move to a new geo- work structure (§7.1), addressing (§7.2), and routing (§7.3). graphical cell. To tackle it, a DHCP address server (e.g., at the Prototype: We prototype an IPv6-based F-Rosette satel- ground station) can be deployed for each cell to manage the lite protocol suite with 13K lines of C code, as shown in address allocation and duplication detection. As evidenced Figure 11. We build F-Rosette on top of the standard IPv6 in Figure 7b, the DHCP server can generate a F-Rosette ad- routing suite by extending Quagga 0.99.23 [40] and run it in dress by concatenating the network prefix, the geographical a customized Linux 3.10.0 kernel (which resembles Starlink’s cell ID, and a per-user suffix that is unique inside this cell. Linux-based small satellites [41]). At the control plane, we Inter-networking to external networks: The discus- implement F-Rosette’s hierarchical addresses, and embed sion so far focuses on the networking inside a F-Rosette. them into the IPv6 address as shown in Figure 7. We also In reality, both the terrestrial users and satellites need to implement F-Rosette’s routing algorithms in §5 to compute communicate with others through the Internet. For com- the FIB entry for a new incoming packet. At the data plane, patibility with Internet routing and global reachability, we we reuse the standard IPv6 routing table and forwarding en- propose IPv6-based network addressing for F-Rosette. As gine for prefix-based F-Rosette routing in §5. At runtime, shown in §4 and exemplified in Figure 7, the IPv6 prefix in an IPv6 packet with F-Rosette address will be forwarded Figure 7b can be used to identify whether a packet is inside a to the user plane. If the routing table does not have a FIB F-Rosette. If so, the F-Rosette routing in §5 can be applied. entry for this address, it will be relayed to the control plane. Otherwise, the packet will leave F-Rosette and enter the ex- The control plane will parse the IPv6 address to get the ternal network. In this case, the classical prefix match-based F-Rosette address, run Algorithm 2–3 for this address, gen- IP routing will be applied to the IPv6 address, thus retaining erate and install the FIB entry, and then forward the packet. backward compatibility and global reachability. Later packets with to the same destination will be directly Stability-performance tradeoff: F-Rosette’s primar- forwarded by routing table lookup at the data plane. ily goal is stability for a usable space-ground network. It Experimental setup: With our limited capability of launch- is possible to refine F-Rosette to balance the stability and ing massive satellites to space, we conduct a hardware-in-the- performance. For instance, the basic F-Rosette design only loop, trace-driven emulation to approximate the real space- utilizes local links to for stable topology (Theorem 2). It is ground networks. We use StarPerf [42] to approximate the possible to extend F-Rosette with non-local links for lower mega-constellations based on F-Rosette’s setup in §3.2 and latency (first proposed in [13]), by extending the base Rosette real TLE orbit information of Starlink [1], Kuiper [2], and constellation in Figure 4b and construction in Algorithm 1 Telesat [3] from Space-Track [43]. The emulator will generate 10
3URSDJDWLRQ'HOD\ PV 3URSDJDWLRQ'HOD\ PV 1.00 15.0 175 150 )5RVHWWH 0.75 12.5 125 2SWLPDO &') 10.0 0.50 100 +RS LQWUDRUELWOLQNRIOD\HU LQWHURUELWOLQN 7.5 LQWUDRUELWOLQNRIOD\HU 75 0.25 'HOD\ 5.0 50 0.00 0.0 0.5 1.0 1.5 2.0 2.5 0 1000 2000 3000 4000 5000 6000 0.000 0.005 0.010 0.015 0.020 7LPH K
7LPH V
_)5RVHWWH2SWLPDO__2SWLPDO_ Figure 12: F-Rosette’s inter-satellite link delay in free (a) An example trace (b) Closeness to optimality space under J4 orbit propagation model [44, 45]. Figure 13: F-Rosette’s near-optimal routing. the runtime satellite motions, earth’s rotations, and inter- Table 4: Header usage in F-Rosette’s address ( = 16). satellite link qualities (delay, loss, and capacity) based on the Num. satellites Bits of row Bits of column Total bits well-tested J4 orbit propagation model [44, 45] in aerospace F-Rosette0 16 4 4 8 engineering. For the projections in §2.2, we use a ThinkSta- F-Rosette1 256 8 9 17 F-Rosette2 4096 12 14 26 tion P910 workstation (22-core 3.5GHz Intel E5-2600, 64GB F-Rosette3 65536 16 19 35 DDR4) with mininet [46] to create all virtual satellites in LEO mega-constellations. We also run our prototype on a testbed Compared to terrestrial networks, RTT between satellites is of 5 servers (with 2.2GHz CPU and 4GB memory usage limit less noisy due to the laser communication in vacuum. to approximate the real small LEO satellites in [47, 48]) to quantify its data forwarding performance and overhead. Ethics: This work does not raise any ethical issues. 7.2 Network Addressing in F-Rosette We next evaluate the network addressing in F-Rosette. It has been proved in §4 that F-Rosette does not incur satel- 7.1 Characteristics of F-Rosette Structure lite or user IP address changes in §2.2. Here we assess the efficiency and cost of F-Rosette address in IPv6. We first assess the F-Rosette’s network structure in §3.3, Addressing efficiency: We quantify the packet space us- and compare them with existing mega-constellations. age by F-Rosette’s address. Table 4 shows the header spaces Full coverage with fewer satellites: Table 3 compares needed inside an 128-bit IPv6 address to embed F-Rosette’s F-Rosette with state-of-the-art mega-constellations under hierarchical address in §4. For satellites, a F-Rosette with the same altitude and elevation angle. It confirms F-Rosette = 16 can support up to = 8 (232 satellites) with 32- can achieve the same coverage as the state-of-the-art’s with bit address space. For ground cells, with a 32-bit address, a 35.9–57.3% fewer satellites. This is mainly because F-Rosette F-Rosette with = 16 can support up to = 2. More cells is based on Rosette constellation, which typically requires can be accommodated with more bits in 128-bit IPv6 address. less satellites than Walker-based constellations today [23]. Note users in the same geographical cell should be assigned Note existing mega-constellations may still achieve full cov- different suffixes to avoid duplicate IPv6 address (§4.2). With erage with fewer satellites. Besides, to satisfy F-Rosette’s 32-bit suffix in an IPv6 address, F-Rosette can support up construction, the actual number of satellites in F-Rosette to 232 in each geographical cell, and leaves 64 bits as IPv6 can be slightly more than this minimum. This can be opti- prefixes for inter-networking to external networks. mized by tuning the choices of , and . Addressing overhead: At runtime, F-Rosette should Stable network topology: F-Rosette’s stability under process its address for Algorithm 2 (for satellites) or Algo- the minimum altitude has been proven in Theorem 2. rithm 3 (for ground users). For the satellite address, F-Rosette Table 2 quantifies under different F-Rosette sizes. More performs the prefix/wildcard matching based on the standard satellites in F-Rosette generally lead to a lower altitude, FIB, thus retaining same cost as standard IPv6 with negli- thus facilitating low latency network services. gible overhead. For ground users, F-Rosette should map Geographical cells on the ground: Table 2 quantifies its geographical cell ID to the corresponding location ( , ). the number of geographical cells and their average sizes in Table 6 confirms that the runtime table lookup time is mar- F-Rosette with = 8, = 6. More geographical cells can ginal. Table 5 shows ≤2MB is needed for the geographical be formed by increasing the number of layers , thus offering ID-to-location table for = 16, = 3, which is acceptable fine-grained and faster network services. even for small LEO satellites with limited storage. Propagation delay of an inter-satellite link: Figure 12 exemplifies the RTT variance of links between two satellites with = 16, = 1 using J4 orbit perturbation [44, 45]. For 7.3 Routing in F-Rosette intra-orbit links, F-Rosette ensures fixed one-hop RTT be- We last evaluate the routing in F-Rosette. It has been proven cause of the fixed inter-satellite distance. For inter-orbit links, in §5 that F-Rosette does not incur routing re-convergence F-Rosette confirms periodic, predictive and bounded vari- or suffer from low network usability in §2.2. So this section ance of the RTT, which is feasible for low-jitter applications. focuses on the routing efficiency and overhead. 11
8 RELATED WORK LEO satellite network has been actively studied for decades. Early efforts design constellations to ensure coverage, such as Walker [49], Rider [50], Rosette [23], Ellipso [51], to name Figure 14: Data forwarding speed at 1Gbps links. a few. LEO satellites in these constellations are standalone, without forming a network in space. The first LEO network Table 5: Storage overhead with = 16 in operation is Iridium [9], a 66-satellite small constellation F-Rosette0 F-Rosette1 F-Rosette2 F-Rosette3 Memory (bytes) 64 1,984 61,504 1,906,624 on the polar orbit. Since 2000s, various network designs have been proposed for Iridium, such as the location address [52–57], virtual node routing [21, 22], virtual topology rout- Table 6: System overhead of F-Rosette. ing [19, 20], multi-layer routing [58, 59], and geographical CPU usage < 1% Memory usage 1344kB routing [30, 33, 60–62]. However, they cannot easily extend 1st packet’s processing latency 0.048–0.058ms or scale to the mega-constellations as explained in §2.2. As table lookup time 0.006–0.008ms mega-constellations are still at early adoptions, recent stud- Bandwidth 867.42Mbps ies explore their performance optimization [63–65] or ap- plication to broader scenarios like navigation [66], in-orbit Routing efficiency: We first compare F-Rosette’s rout- computing [48] and content delivery [38, 39]. [13] notices ing in §5 with the paths with the shortest hop counts and the link churns between satellites and proposes remedies, but propagation delays. In this experiment, we route traffic from it does not stabilize the network between space and ground. Beijing to New York using F-Rosette with = 16, = Instead, F-Rosette takes to first step to strive for a stable 2, = 1 (256 satellites) at the altitude of 878.76km. We space-ground network in LEO mega-constellations. compare F-Rosette’s hop counts and propagation delays F-Rosette is inspired by many network structure designs with those in the shortest path. Figure 13 confirms that, in other domains such as data center [67–69], P2P [70, 71], F-Rosette always achieves the shortest path in hop counts and wireless network [72–74]. It is based on the Rosette con- as proved in Theorem 4. Due to the time-varying inter-orbit stellation [23], but generalizes it with a recursive structure satellite link delays (Figure 12 and Equation 11), F-Rosette and inter-satellite links. Its network addressing is inspired does not always find the shortest path in propagation delays. by classical geographical information systems like Google S2 Even so, Figure 13b shows F-Rosette’s bounded link delay [75] and Uber H3 [76], but customized for space-ground net- variances help F-Rosette approximates the optimal delay working. F-Rosette’s geographical-to-topological routing with ≤1.4% difference, thus ≤1.62ms. Note the spikes in Fig- embedding resembles greedy embedding [33, 34], but works ure 13b arise from user’s handoffs between satellites, during in a different domain of space-ground network. which the user re-associates to a closer satellite. Despite this dynamics, F-Rosette still retains near-optimality compared to the shortest path in propagation delays. 9 CONCLUSION Besides near-optimal routing path, F-Rosette’s forward- This work devises F-Rosette, a stable space-ground network ing engine also retains high data throughput. Figure 14 shows structure in LEO mega-constellation. F-Rosette strives for the end-to-end iperf throughput in a five-server testbed run- stable network topology, address, and routing under dy- ning F-Rosette over 1Gbps links. It confirms F-Rosette’s namic many-to-many space-ground mapping in high mobil- routing can saturate the physical bandwidth, and achieves ity. F-Rosette’s recursive structure over the Rosette con- comparable speed to the standard OSPF routing in IPv6. Since stellation guarantees provably stable network topology. Its its routing algorithm can be realized with readily-available hierarchical, geographical addressing embedded prevents the prefix/wildcard matching today, F-Rosette achieves compa- frequent address change for its users. F-Rosette does not rable data forwarding performance to standard IP routing. incur global routing re-convergence in satellite mobility or Routing overhead: Since F-Rosette runs atop IPv6, it earth’s rotations. To route traffic between users, F-Rosette incurs marginal cost compared to state-of-the-arts. Table 6 performs efficient geographical routing by embedding it into shows that the processing latency of the first packet with a the stable topological routing between satellites. F-Rosette new destination address is ≤0.058ms (for FIB setup). Later is compatible with IPv6 and incrementally deployable. packets to the same destination will be directly forwarded by F-Rosette is an initial effort to strive for a stable space- FIB lookup without this additional processing. Table 6 shows ground network at scale. Compared to the terrestrial network < 1% CPU and ≤1.3MB memory usage of F-Rosette under nodes, satellites are much harder to modify or upgrade once the same CPU/memory conditions as the LEO satellite’s, thus they are launched to space. Therefore, although the mega- affordable for resource-constrained small satellites. constellations are still at early deployments, it is necessary 12
to systematically design the network before it is too late to Kim. Fsa-based link assignment and routing in low-earth orbit satellite change. We hope F-Rosette could call for the community’s networks. IEEE transactions on vehicular technology, 47(3):1037–1048, attention and stimulate more research efforts in this area. 1998. [21] Eylem Ekici, Ian F Akyildiz, and Michael D Bender. Datagram routing algorithm for leo satellite networks. In Proceedings IEEE INFOCOM REFERENCES 2000. Conference on Computer Communications. Nineteenth Annual [1] SpaceX Starlink. https://www.starlink.com/, 2021. Joint Conference of the IEEE Computer and Communications Societies [2] Amazon receives FCC approval for project Kuiper satellite constella- (Cat. No. 00CH37064), volume 2, pages 500–508. IEEE, 2000. tion. https://www.aboutamazon.com/news/company-news/amazon- [22] Eylem Ekici, Ian F Akyildiz, and Michael D Bender. A distributed rout- receives-fcc-approval-for-project-kuiper-satellite-constellation, 2020. ing algorithm for datagram traffic in leo satellite networks. IEEE/ACM [3] Telesat LEO satellites. https://www.telesat.com/leo-satellites/, 2021. Transactions on networking, 9(2):137–147, 2001. [4] OneWeb constellation. https://www.oneweb.world/, 2021. [23] Arthur H Ballard. Rosette constellations of earth satellites. IEEE [5] CNBC. SpaceX prices Starlink satellite internet service at $99 per Transactions on Aerospace and Electronic Systems, (5):656–673, 1980. month, according to e-mail. https://www.cnbc.com/2020/10/27/spacex- [24] Lixia Zhang, Alexander Afanasyev, Jeffrey Burke, Van Jacobson, starlink-service-priced-at-99-a-month-public-beta-test-begins.html, KC Claffy, Patrick Crowley, Christos Papadopoulos, Lan Wang, and 2020. Beichuan Zhang. Named data networking. ACM SIGCOMM Computer [6] Wccftech. SpaceX Successfully Tests Inter-Satellite Starlink Connec- Communication Review, 44(3):66–73, 2014. tivity Via Lasers. https://wccftech.com/spacex-starlink-satellite-laser- [25] Van Jacobson, Diana K Smetters, James D Thornton, Michael F Plass, test/, Sep 2020. Nicholas H Briggs, and Rebecca L Braynard. Networking named [7] TheVerge. With latest Starlink launch, SpaceX touts 100 Mbps down- content. In Proceedings of the 5th international conference on Emerging load speeds and “space lasers” (though the system still has a ways to networking experiments and technologies, pages 1–12, 2009. go). https://www.theverge.com/2020/9/3/21419841/spacex-starlink- [26] Xin Zhang, Hsu-Chun Hsiao, Geoffrey Hasker, Haowen Chan, Adrian internet-satellite-constellation-download-speeds-space-lasers, 2020. Perrig, and David G Andersen. Scion: Scalability, control, and isolation [8] Inigo Del Portillo, Bruce G Cameron, and Edward F Crawley. A techni- on next-generation networks. In 2011 IEEE Symposium on Security and cal comparison of three low earth orbit satellite constellation systems Privacy, pages 212–227. IEEE, 2011. to provide global broadband. Acta Astronautica, 159:123–135, 2019. [27] Arun Venkataramani, James F Kurose, Dipankar Raychaudhuri, Kiran [9] Zizhong Tan, Honglei Qin, Li Cong, and Chao Zhao. New method for Nagaraja, Morley Mao, and Suman Banerjee. Mobilityfirst: a mobility- positioning using iridium satellite signals of opportunity. IEEE Access, centric and trustworthy internet architecture. ACM SIGCOMM Com- 7:83412–83423, 2019. puter Communication Review, 44(3):74–80, 2014. [10] Wikipedia. Orbital Elements. https://en.wikipedia.org/wiki/Orbital_ [28] Dongsu Han, Ashok Anand, Fahad Dogar, Boyan Li, Hyeontaek Lim, elements, 2021. Michel Machado, Arvind Mukundan, Wenfei Wu, Aditya Akella, [11] Elon Musk’s twitter on IPv6 for Starlink. David G Andersen, et al. Xia: Efficient support for evolvable inter- [12] Handley, Mark. Delay is Not an Option: Low Latency Routing in Space. networking. In Presented as part of the 9th {USENIX} Symposium In Proceedings of the 17th ACM Workshop on Hot Topics in Networks on Networked Systems Design and Implementation (NSDI 12), pages (HotNet), pages 85–91. ACM, 2018. 309–322, 2012. [13] Debopam Bhattacherjee and Ankit Singla. Network topology design [29] Stefan Ruehrup. Theory and practice of geographic routing. Ad hoc at 27,000 km/hour. In Proceedings of the 15th International Conference and sensor wireless networks: architectures, algorithms and protocols, 69, on Emerging Networking Experiments And Technologies, pages 341–354, 2009. 2019. [30] Brad Karp and Hsiang-Tsung Kung. Gpsr: Greedy perimeter stateless [14] NASA Socioeconomic Data and Applications Center (SEDAC). routing for wireless networks. In Proceedings of the 6th annual interna- Gridded population of the world: Population count, v4.11 (2020). tional conference on Mobile computing and networking, pages 243–254. https://sedac.ciesin.columbia.edu/data/set/gpw-v4-population-count- ACM, 2000. rev11. [31] Young-Jin Kim, Ramesh Govindan, Brad Karp, and Scott Shenker. Ge- [15] CNBC. Investing in space: SpaceX says Starlink internet has ographic routing made practical. In Proceedings of the 2nd conference “extraordinary demand,” with nearly 700,000 interested in service. on Symposium on Networked Systems Design & Implementation-Volume https://www.cnbc.com/2020/08/01/spacex-starlink-extraordinary- 2, pages 217–230. USENIX Association, 2005. demand-with-nearly-700000-interested.html, 2020. [32] Ben Leong, Barbara Liskov, and Robert Tappan Morris. Geographic [16] Amazon AWS Ground station: Easily control satellites and ingest data routing without planarization. In NSDI, volume 6, page 25, 2006. with fully managed Ground Station as a Service. https://aws.amazon. [33] Robert Kleinberg. Geographic routing using hyperbolic space. In com/ground-station/, 2021. IEEE INFOCOM 2007-26th IEEE International Conference on Computer [17] Microsoft Azure. New Azure Orbital, ground station as a service, now Communications, pages 1902–1909. IEEE, 2007. in preview. https://azure.microsoft.com/en-us/updates/new-azure- [34] Simon S Lam and Chen Qian. Geographic routing in -dimensional orbital-ground-station-as-a-service-now-in-preview/, 2020. spaces with guaranteed delivery and low stretch. IEEE/ACM Transac- [18] Pulak K Chowdhury, Mohammed Atiquzzaman, and William Ivancic. tions on Networking, 21(2):663–677, 2012. Handover schemes in satellite networks: state-of-the-art and future [35] AmericaSpace. 143-Strong Haul of Satellites Set for Sunday SpaceX research directions. IEEE Communications Surveys & Tutorials, 8(4):2– Launch. https://www.americaspace.com/2021/01/23/143-strong-haul- 14, 2006. of-satellites-set-for-sunday-spacex-launch/, 2021. [19] Markus Werner. A dynamic routing concept for atm-based satellite [36] Vinton Cerf, Scott Burleigh, Adrian Hooke, Leigh Torgerson, Robert personal communication networks. IEEE journal on selected areas in Durst, Keith Scott, Kevin Fall, and Howard Weiss. Delay-tolerant communications, 15(8):1636–1648, 1997. networking architecture. 2007. [20] Hong Seong Chang, Byoung Wan Kim, Chang Gun Lee, Sang Lyu Min, Yanghee Choi, Hyun Suk Yang, Doug Nyun Kim, and Chong Sang 13
You can also read