kth.sePublications
Change search
CiteExportLink to record
Permanent link

Direct link
Cite
Citation style
  • apa
  • ieee
  • modern-language-association-8th-edition
  • vancouver
  • Other style
More styles
Language
  • de-DE
  • en-GB
  • en-US
  • fi-FI
  • nn-NO
  • nn-NB
  • sv-SE
  • Other locale
More languages
Output format
  • html
  • text
  • asciidoc
  • rtf
Systematically Testing OpenFlow Controller Applications
EPFL.
EPFL.
UCLouvain.
EURECOM.
Show others and affiliations
2015 (English)In: Computer Networks, ISSN 1389-1286, E-ISSN 1872-7069, Vol. 92Article in journal (Refereed) Published
Abstract [en]

The emergence of OpenFlow-capable switches enables exciting new network functionality, at the risk of programming errors that make communication less reliable. The centralized programming model, where a single controller program manages the network, seems to reduce the likelihood of bugs. However, the system is inherently distributed and asynchronous, with events happening at different switches and end hosts, and inevitable delays affecting communication with the controller. In this paper, we present efficient, systematic techniques for testing unmodified controller programs. Our NICE tool applies model checking to explore the state space of the entire system—the controller, the switches, and the hosts. Scalability is the main challenge, given the diversity of data packets, the large system state, and the many possible event orderings. To address this, we propose a novel way to augment model checking with symbolic execution of event handlers (to identify representative packets that exercise code paths on the controller). We also present a simplified OpenFlow switch model (to reduce the state space), and effective strategies for generating event interleavings likely to uncover bugs. Our prototype tests Python applications on the popular NOX platform. In testing three real applications—a MAC-learning switch, in-network server load balancing, and energy-efficient traffic engineering—we uncover thirteen bugs

Place, publisher, year, edition, pages
Elsevier, 2015. Vol. 92
National Category
Communication Systems Computer Sciences
Identifiers
URN: urn:nbn:se:kth:diva-176481DOI: 10.1016/j.comnet.2015.03.019ISI: 000366785500007Scopus ID: 2-s2.0-84948569552OAI: oai:DiVA.org:kth-176481DiVA, id: diva2:867620
Funder
EU, European Research Council, 259110
Note

QC 20151110

Available from: 2015-11-05 Created: 2015-11-05 Last updated: 2022-06-23Bibliographically approved

Open Access in DiVA

fulltext(1296 kB)417 downloads
File information
File name FULLTEXT01.pdfFile size 1296 kBChecksum SHA-512
9ddb5ea4d01f36c87ea25a2a95d1dd4c9e585edeb671bac96a3f11602df418b6bbe2836b015db9f336db964e9f144d6dd0c4b14761da87b0a7bcb88153f45cd0
Type fulltextMimetype application/pdf

Other links

Publisher's full textScopus

Authority records

Kostic, Dejan

Search in DiVA

By author/editor
Kostic, Dejan
By organisation
Network Systems Laboratory (NS Lab)
In the same journal
Computer Networks
Communication SystemsComputer Sciences

Search outside of DiVA

GoogleGoogle Scholar
Total: 417 downloads
The number of downloads is the sum of all downloads of full texts. It may include eg previous versions that are now no longer available

doi
urn-nbn

Altmetric score

doi
urn-nbn
Total: 732 hits
CiteExportLink to record
Permanent link

Direct link
Cite
Citation style
  • apa
  • ieee
  • modern-language-association-8th-edition
  • vancouver
  • Other style
More styles
Language
  • de-DE
  • en-GB
  • en-US
  • fi-FI
  • nn-NO
  • nn-NB
  • sv-SE
  • Other locale
More languages
Output format
  • html
  • text
  • asciidoc
  • rtf