Skip to content

Latest commit

 

History

History
304 lines (222 loc) · 16.8 KB

File metadata and controls

304 lines (222 loc) · 16.8 KB

MOC-XIA

Group members

Joseph Tierney [email protected]

Krystal Kallarackal [email protected]

Nicholas Memme [email protected]

Qiaobin Fu [email protected]

Mentor: Cody Doucette [email protected]

Project Description

The eXpressive Internet Architecture (XIA) is an experimental network architecture developed by researchers at BU at other collaborating universities. It is an alternative to the current TCP/IP-based Internet, and emphasizes that applications should be able to more clearly express their needs to the network. For example, the current Internet forces applications to say "find where this movie is, and then go retrieve it at that location." XIA allows applications to more simply say "retrieve this movie," without caring about where the movie is stored.

In other words, XIA enables applications to more accurately express their intent. This project focuses on applying this powerful tool to allow users and applications to choose better network services, especially in open cloud environments like the Massachusetts Open Cloud (MOC). In the same way that users can choose compute and storage resources from service providers in a marketplace, we envision that users should be able to choose networking services by various vendors as well.

In this project, we will create a very simple version of a networking marketplace. Users and applications will be able to choose between different link and physical technologies that suit their needs. To accomplish this, we will expand XIA in the Linux kernel and add XIA to virtual network switch software, called Open vSwitch (OVS). Although much of the XIA code has already been written in the Linux kernel, we will be modifying it and expanding it to also fit within the constraints of OVS. We will be coding and hacking in the kernel on both virtual machines and physical computers.

By the end of this project, participants will have gained significant experience in computer networking, cloud computing, Linux kernel programming, Linux and virtual machine configuration, etc.

Scope and Features Of The Project

  • Expand XIA in the Linux Kernel

    • Add additional features and functionality to the existing XIA code
    • Enable choice in a data center
      • Users can choose computational and storage resources from service providers in a marketplace, and can choose networking services by various vendors as well.
      • We may reuse the existing features and functionality in current XIA code.
  • Port XIA to a virtual network switch software (OVS)

    • Read through pre-written XIA code to determine how it works.
    • Read through OVS code to understand how IP, HTTP, etc. are ported in order to add the necessary code and headers to port XIA as well.
    • Revise code in order to port XIA into OVS to enable a router or switch to recognize XIA much like it recognized protocols like TCP or IP.
      • XIA can act as a transport layer, network layer, and link layer protocol. In this project, we're going to be using it as a link layer protocol that switches packets based on identifiers for links. Once XIA is in place in OVS, then the other functionality it employs (OpenFlow) will work "with" XIA.
      • We need to extend OVS to support the XIP header, so that XIA can work in the data center environment.
      • Also, we need to modify and expand XIA to fit within the constraints of OVS.
  • Creating an Application that utilizes XIA on OVS

    • Develop an application using XIA that displays the features and functionality of the architecture.

Solution Concept

Global Architectural Structure Of the Project

Below is a description of the system components that are the building blocks of the architectural design:

  • XIA: an experimental network architecture created as an alternative to TCP/IP under the premise that applications should be able to more clearly express their needs to the network rather than specifying the location of where to get it from.
  • OVS: a virtual multilayer network switch (Open vSwitch)

alt tag

The above figure shows the basic elements in the XIA enabled network. Assuming that both host A and host B are XIA enabled hosts, and A wants to communicate with B via a router/switch with OVS support. Like TCP/IP, the router/switch on the path from A to B needs to understand XIA, otherwise, the packets from A to B cannot be forwarded correctly, or will even be dropped. This highlights one important task in our project, i.e., porting XIA into OVS and making XIA understandable to the network.

alt tag

This figure shows the MOC-XIA architecture, in which all the hosts, routers, switches, etc., are XIA enabled, i.e., this is an XIA enabled cloud. In the cloud, it enables networking as a marketplace, so that users can choose better networking services from different providers to meet their desired requirements. For instance, the user may require a networking service provider that can meet their requirements of a low latency and low jitter networking service.

Design Implications and Discussion

  • Using XIA for better expressiveness: XIA enables applications to more accurately express their intent. For instance, the current Internet forces applications to say "find where this movie is, and then go retrieve it at that location." XIA allows applications to more simply say "retrieve this movie," without caring about where the movie is stored.
  • Using OVS for multi-server virtualization deployments in data centers: Open vSwitch (OVS) is a production quality, multilayer virtual switch, and enables automated and dynamic network control in large-scale Linux-based virtualization environments through programmatic extension. OVS enables the network to support XIA for creating a networking marketplace.
  • Creating a networking marketplace: XIA enabled cloud allows users to choose networking services by various vendors in the same way that users choose compute and storage resources from service providers in a marketplace. This meets the users’ and applications’ need for better networking service.

Acceptance criteria

Minimum acceptance criteria is a working implementation of XIA on OVS.

Stretch goals are:

  • Develop new functionality for XIA to build a network marketplace.
  • Build an application that utilizes XIA on OVS, and demonstrate its advantages.

Release Planning

Release #1 (due by Tuesday Feb 9):

Release #2 (due by Tuesday Feb 23):

  • Setup the developement environment, and show how to run XIA and OVS.

Release #3 (due by Tuesday March 15):

  • Port XIA into OVS.

Release #4 (due by Tuesday March 29):

  • Port XIA into OVS, release a demo to show XIA works in OVS.

Release #5 (due by Tuesday April 12):

  • Write new functionality in XIA to enable choice in a datacenter.

Release #6 (final demo due by Tuesday April 26):

  • Build an application on top of XIA and OVS, to allow users to choose network services for better performance.

Project Video

We have compiled a video explanation and demonstration of our project.

Where Are Projects Maintained

XIA

The eXpressive Internet Architecture (XIA) is an experimental network architecture aimed at allowing applications and users to more accurately express their intent. Linux XIA is a native implementation of XIA in the Linux kernel.

Open vSwitch

Open vSwitch is a virtual multilayer network switch, it has two important components: (1) ovs-vswitchd, a userspace daemon that is essentially the same from one operating system and operating environment to another. (2) datapath kernel module, is usually written specially for the host operating system for performance. For more information, you can read the NSDI'15 paper "The Design and Implementation of Open vSwitch".

As we extensively modified the OVS project in both user-space and kernel datapath, the OVS user-space project is maintained here, and the OVS kernel datapath is maintained here.

Extended net-echo Application

net-echo is an application built on top of Linux XIA. It implements a simple server (eserv) and client (ecli), where the client sends a message and the server simply echoes it back to the client.

In the extended version, we adapt net-echo to enforce some price constraint within some time bound, i.e., only allow 5 echo messages to use the more expensive link within a minute. Any echo messages beyond those 5 would have to use the cheaper link until some time expires. The extended net-echo application is maintained here.

Installation and Deployment

XIA Install

cd ~
git clone https://github.com/mengxiang0811/XIA-for-Linux.git
cd XIA-for-Linux
sudo make
sudo make install

For more detailed installation, please refer to the Linux XIA wiki.

OVS Kernel Datapath Install

cd ~
sudo rmmod openvswitch
git clone https://github.com/BU-NU-CLOUD-SP16/Building-a-Network-Marketplace-with-XIA.git
cd Building-a-Network-Marketplace-with-XIA
cp openvswitch.h ~/XIA-for-Linux/include/uapi/linux/
cp -r openvswitch/ ~/XIA-for-Linux/net/
cd ~/XIA-for-Linux/
make clean M=net/openvswitch
make M=net/openvswitch/
sudo install -oroot -groot -m644 net/openvswitch/openvswitch.ko /lib/modules/`uname -r`/kernel/net/openvswitch
sudo modprobe openvswitch

OVS User Space Install

cd ~
git clone https://github.com/cjdoucette/ovs.git
cd ovs
sudo make
sudo make install

Extended Net-echo Application Install

cd ~
git clone https://github.com/mengxiang0811/net-echo.git
cd net-echo
sudo make
sudo make install

Mininet Install

For the installation of Mininet, please refer to its official website.

Wireshark-XIA Install

Wireshark is a network protocol analyzer that allows users to inspect packet data. It provides a GUI through which users can view conveniently-formatted packet information broken down by protocol. Users can view XIP packets using the Wireshark with XIA support.

Instructions on Running Demos

OVS Setup

On booting the VM, you will always need to get OVS up and running first.

cd ~
sudo modprobe openvswitch
sudo ovsdb-server -v --remote=punix:/usr/local/var/run/openvswitch/db.sock --remote=db:Open_vSwitch,Open_vSwitch,manager_options  --pidfile --detach --log-file
sudo ovs-vsctl --no-wait init
sudo ovs-vswitchd --pidfile --detach
sudo modprobe xia_ppal_hid
sudo modprobe xia_ppal_xdp

Demos

Running Wireshark to capture XIA packets

If you would like to observe what happens to packets when we try to send them between two machines in the network. You can open a terminal (1) and start wireshark from the command line:

$ sudo wireshark

When it opens, double-click on Loopback: lo. This will make wireshark start capturing (and displaying) all packets that are flowing through the VM. To capture only the XIA packets that we're interested in, type "xip" into the display filter near the top of the wireshark screen.

Running Mininet to create network topology

To create a network using mininet, open a new terminal (2), and input the following command:

$ sudo mn

This creates a really simple network with one switch connected to two hosts:

h1 <-----> s1 <-----> h2

Mininet is actually capable of creating some really complex and interesting networks. For the final demo with extended net-echo application, you can create the network topology by running:

$ sudo python 3s2h.py

This will create a network topology with three switches connected to two hosts:

h1 h1-eth0:s1-eth1
h2 h2-eth0:s2-eth2 h2-eth1:s3-eth2

Running ovs-ofctl to manage flow rules

From here, we can see what kind of rules are installed on the switch connecting these two hosts. In a third terminal (beside the one running wireshark and the one running mininet), do this:

$ sudo ovs-ofctl dump-flows s1

Besides, you can add a rule to switch 1 that says to drop any packet coming in on port 1 (from host 1):

$ sudo ovs-ofctl add-flow s1 in_port=1,actions=drop

For the final demo, you can run the shell script named "edge_command.sh" to add rules for XIA packets.

Running net-echo application

Finally, we can try to send XIA packets through the mininet network. In order to do this, we'll first need to see how to generate XIA packets.

XIA comes in a series of kernel modules. Each kernel module represents an XIA principal. We're going to use two principals: the HID principal to allow XIA packets to be routed to a different host, and the XDP principal to allow packets to be delivered to sockets for applications. (XDP is XIA's version of the UDP protocol).

Open a terminal on the VM and add the modules this way:

$ sudo modprobe xia_ppal_hid
$ sudo modprobe xia_ppal_xdp

You can check that the modules were loaded by running:

$ dmesg

This displays the kernel ring buffer, which shows the user important information coming from the kernel.

Since all of the mininet hosts share the same kernel and filesystem as the host VM that we're using, by loading these modules on the host VM, they are automatically loaded on every mininet host.

We have already generated HIDs for both of these hosts (HID_1 for host h1, and HID_2 for host h2). If you would like to generate new HIDs for these hosts, you can run the following command:

mininet> h1 xip hid new hid_h1   // create a new HID for h1
mininet> h2 xip hid new hid_h2   // create a new HID for h2

All you need to do is assign these already-generated HIDs to the hosts. This is kind of like assigning an IP address to a machine. In the mininet prompt, issue these commands:

mininet> h1 xip hid add hid_h1   // assign it to host h1
mininet> h2 xip hid add hid_h2   // assign it to host h2

You can check that each host was assigned an HID by running:

mininet> h1 xip hid showaddrs
mininet> h2 xip hid showaddrs

Finally, you need to replace the HID XID in client.txt by the new "hid_h1", and the HID XID in server.txt by the new "hid_h2". The following is the example DAG addresses in our demo:

@client.txt with HID_1

 hid-14f57b16cc126f75eed7ce9055c9668fade23121-1:                                 
 xdp-2093723472747047808047502873423749070988-0

@server.txt with HID_2
hid-82e0476015683b23aa2c6ca1947d407e6241294b-1:
xdp-2093723472747047808047502873423749070987-0

When you add HIDs to machines on the same network, the machines run a protocol called NWP to find each other and communicate. So, at this point, h1 and h2 will actually have figured out they are neighbors. At h1, you can list its neighbors, and you should see information about h2:

mininet> h1 xip hid showneighs

To send an XIP packet from h1 to h2, we need to use a new application called net-echo. You need to run the server on h2 with commands:

mininet> h2 eserv datagram xip server.txt &

Then you can run the client on h1:

mininet> h1 ecli datagram xip client.txt server.txt

The client will remain open, waiting for you to input text. So type "hello" and press enter. The message should be echoed back!