 
                        REST ON ROUTERS? Preliminary Lessons for Language Designers, Framework Architects and App Developers Joe Kaylor, Konstantin Läufer and George K. Thiruvathukal Department of Computer Science, Loyola University Chicago, Chicago, IL 60611, U.S.A. Keywords: Embedded systems, Environmental monitoring, Green computing, Linux, OpenWrt, Programming languages, Representational state transfer, Resource oriented computing, REST, Software frameworks. Abstract: In this position paper, we provide a preliminary assessment of hardware and software solution stack choices available to developers of resource-oriented web services on commodity embedded devices. As part of an ongoing interdisciplinary research project on air and water quality in a major urban ecosystem, we are de- veloping an information infrastructure amounting to a role-based hierarchy of individually addressable, in- terconnected resources, ranging from sensors, analyzers, and other monitoring devices to aggregators and publishers. This infrastructure follows the Representational State Transfer (REST) architectural pattern and integrates non-networked or non-RESTful monitoring devices through RESTful proxy resources running on low-cost, low-energy, possibly wireless, always-on embedded servers. Commodity wireless routers running a suitable embedded Linux distribution are a good choice for this purpose, and we have started to survey the landscape of supported solution stacks, including programming languages and RESTful frameworks: Not only were our preferred, familiar choices unavailable for medium-end routers, but we had to develop our own lightweight REST layer for lower-end routers. Given the growing popularity of embedded Linux devices, however, we argue that programming language designers and framework architects should support them to a much greater extent than they do now. In addition, as the demand for green computing grows, we argue that memory- and processor-efficient languages and frameworks become increasingly important. 1 INTRODUCTION Given that such devices are readily available in the form of commodity wireless routers running a suit- The purpose of this position paper is to provide a pre- able embedded Linux distribution, we have started to liminary assessment of hardware and software solu- survey the landscape of supported solution stacks, in- tion stack choices available to developers of resource- cluding programming languages and RESTful frame- oriented web services on low-power equipment. The works: Not only were our preferred, familiar choices context for this discussion is an ongoing interdisci- unavailable for medium-endrouters, but we had to de- plinary research project on air and water quality in a velop our own lightweight REST layer for lower-end major urban ecosystem. routers. Because embedded Linux devices are becom- The information infrastructure we are develop- ing increasingly common for a wide range of uses, ing for this project amounts to a role-based hierar- however, we argue that language designers and soft- chy of individually addressable, interconnected re- ware framework architects should support them to a sources, ranging from a large number of sensors, an- much greater extent than they do now. In addition, alyzers, and other monitoring devices to aggregators as the demand for green computing grows, memory- and publishers. In developing this infrastructure, we and processor-efficient languages and frameworks be- follow the Representational State Transfer (REST) ar- come increasingly important. chitectural pattern (Fielding, 2000); accordingly, we incorporate non-networked or non-RESTful monitor- ing devices through RESTful proxy resources running on low-cost, low-energy, possibly wireless, always-on embedded servers. 166 Kaylor J., Läufer K. and K. Thiruvathukal G.. REST ON ROUTERS? - Preliminary Lessons for Language Designers, Framework Architects and App Developers. DOI: 10.5220/0003612801660171 In Proceedings of the 6th International Conference on Software and Database Technologies (ICSOFT-2011), pages 166-171 ISBN: 978-989-8425-76-8 Copyright c 2011 SCITEPRESS (Science and Technology Publications, Lda.) REST ON ROUTERS? - Preliminary Lessons for Language Designers, Framework Architects and App Developers 2 THE NEED FOR RESTFUL support for the PATCH request method), or other non- THINKING idempotent operations. While most interaction with environmental sensors is read-only, some sensors do provide mutable resource state for configuration set- The Representational State Transfer (REST) architec- tings such as the unit of measurement, calibration set- tural pattern (Fielding, 2000) is centered around ad- tings, and the like. Our resources naturally support dressable resources with a uniform interface and hy- the uniform interface as follows: permedia representations. In RESTful web services, URIs are used as addresses, HTTP verbs (request • Obtaining a measurement reading or device set- methods) as the uniform interface, and XML or JSON ting from the sensor maps to the GET method. (JavaScript Object Notation) as representations. • Providing a specific new value for a device setting By exposing our hierarchical information infras- is idempotent and, thus, maps to the PUT method. tructure as a collection of interconnected RESTful • Toggling or cycling among several options is not web services, we allow the available information to idempotent and, thus, maps to the POST method. be consumed in flexible ways by user interface pre- sentation layers, data analysis tools, web application • Some nodes in our infrastructure cache histori- mashups, and other planned or unforeseen program- cal data as their resource state; explicitly deleting matic clients. some of those data maps to the DELETE method. Addressable Resources. Our information infras- Hypermedia Representations. The resources in tructure can be conceived naturally as a RESTful re- our information infrastructure are naturally intercon- source set (Pisupati and Brown, 2006; Taherkordi nected, and hypermedia representation formats ex- et al., 2010). pose these connections as links. For example, the rep- resentation of an aggregatornode includes a link to its • The singleton root resource corresponds to the in- list of (statically known and/or dynamically discov- formation infrastructure itself. ered) children. In addition, in following the Hyperme- • Locations can be grouped at multiple levels cor- dia as the Engine of Application State (HATEOAS) responding to places, organizations, or organiza- principle (Fielding, 2008), the representations include tional units. links that represent the next actions, corresponding to • state transitions, currently available to the consumer. Each location can be configured to house one or For example, the representation of a reading includes more devices. a link to the device that produced the reading, and the • Each device is responsible for measurements, representation of a device includes links to the various such as nitrogen monoxide (NO), nitrogen diox- device settings, which can be modified with sufficient ide (NO2), or ozone (O3). authorization. • For any measurement, the device can provide the current reading or historical values such as the Implementation. Using the Restlet framework for minimum, maximum, or average over a given Java, to which the second author contributed ex- time period. A unit of measurement is associated ample code and documentation, we have imple- with each reading. mented a RESTful proxy for monitoring devices that are network-capable but not RESTful on their A topic for further investigation is the federation of own. Our implementation runs on a conventional disjoint resource sets (across physical servers) into a Linux server and includes an adapter component single, seamlessly browsable distributed resource. for a class of devices that support the widely used TCP-based Modbus protocol. It is currently serves HTTP Verbs as the Uniform Interface. Our re- as a RESTful proxy for several Thermo Scien- sources support the main verbs of the uniform inter- tific air quality analyzers available at our institu- face of HTTP, that is, the request methods GET, PUT, tion. For example, our proxy maps routes of POST, and DELETE. These are similar to the familiar the form /{location}/{device}/{measurement} CRUD (Create, Read, Update, Delete) operations for /{reading} to a resource that obtains a reading from manipulating resources but do not correspond one-to- a device. The fragment of the externalized configura- one. Specifically, PUT is idempotent and corresponds tion metadata (for the Spring Framework dependency to creating or fully updating a specific resource, while injection container) in Figure 1 shows a specific loca- POST corresponds to adding a child resource, par- tion with a nitrogen oxide analyzer. The measurement tially updating a resource (in absence of widespread register settings specify which Modbus data registers 167 ICSOFT 2011 - 6th International Conference on Software and Data Technologies <entry key="baumhart"> systems and typically offer half a gigabyte of <bean class="DefaultLocation"> RAM or more. These systems also support stan- <property name="devices"><map> dard available solution stacks. Idle power con- <entry key="42i"> sumption ranges from 5 to 15 watts. Cost starts <bean class="ModbusDevice"> around US$100 but can reach two or three times <property name="hostname" value="147.126.68.251" /> that amount for fanless systems with diverse I/O <property ports, such as eSATA and USB. name="readableSettings"> ... Wireless
Details
- 
                                File Typepdf
- 
                                Upload Time-
- 
                                Content LanguagesEnglish
- 
                                Upload UserAnonymous/Not logged-in
- 
                                File Pages6 Page
- 
                                File Size-
