README.md in trema-0.4.7 vs README.md in trema-0.4.8
- old
+ new
@@ -1,266 +1,50 @@
Welcome to Trema
================
-[data:image/s3,"s3://crabby-images/a00ed/a00ed971c3f73a4b5812888e16d90bf82c81d1f0" alt="Gem Version"][gem]
[data:image/s3,"s3://crabby-images/c05d1/c05d152b76d15fd95dbf27f6dfb9f726a04cc112" alt="Build Status"][travis]
[data:image/s3,"s3://crabby-images/56a90/56a90213c4a45ee329a3e77d2deaf0215cb1abb5" alt="Code Climate"][codeclimate]
[data:image/s3,"s3://crabby-images/47298/47298253689d36b20a732b8089c275a42761b10e" alt="Coverage Status"][codeclimate]
[data:image/s3,"s3://crabby-images/4671a/4671ab56d302e36bea9124d03f45da6b6b72fdad" alt="Dependency Status"][gemnasium]
-[data:image/s3,"s3://crabby-images/d6d7c/d6d7cc6ff5e5c8d7929679e031727b0444279087" alt="Gitter chat"][gitter]
-Trema is a OpenFlow controller framework that includes everything
-needed to create OpenFlow controllers in Ruby and C.
+Trema is an OpenFlow controller programming framework that provides
+everything needed to create OpenFlow controllers in Ruby. It provides
+a high-level OpenFlow library and also a network emulator that can
+create OpenFlow-based networks for testing on your PC. This
+self-contained environment helps streamlines the entire process of
+development and testing.
-This distribution includes all the source code of Trema you need to
-develop your own OpenFlow controllers. The source tree includes basic
-libraries and functional modules that work as an interface to OpenFlow
-switches.
-
-Several sample applications developed on top of Trema are also
-provided, so you can run them as a sample of OpenFlow
-controllers. Additionally, a simple but powerful framework that
-emulates an OpenFlow-based network and end-hosts is provided for
-testing your own controllers. For debugging, a wireshark plug-in to
-diagnose internal data-flows among functional modules is provided.
-
-[gem]: https://rubygems.org/gems/trema
[travis]: http://travis-ci.org/trema/trema
[codeclimate]: https://codeclimate.com/github/trema/trema
[gemnasium]: https://gemnasium.com/trema/trema
[gitter]: https://gitter.im/trema/trema
-Supported Platforms
--------------------
+Prerequisites
+-------------
-Trema supports GNU/Linux only. And it has been tested on the following environments:
+* Ruby 2.0.0 or higher ([RVM][rvm]).
+* [Open vSwitch][openvswitch] (`apt-get install openvswitch-switch`).
-* Ruby 1.8.7 or higher
-* RubyGems 1.3.6 or higher
-* Ubuntu 13.04, 12.10, 12.04, 11.10, and 10.04 (i386/amd64, Desktop Edition)
-* Debian GNU/Linux 7.0 and 6.0 (i386/amd64)
-* Fedora 16-19 (i386/x86_64)
+[rvm]: https://rvm.io/
+[openvswitch]: https://openvswitch.org/
-It may also run on other GNU/Linux distributions but is not tested and
-NOT SUPPORTED at this moment.
+Sample Code
+-----------
-Supported OpenFlow Protocol Versions
-------------------------------------
+Study sample code for implementation examples of Trema features. Each
+sample code project is executable source example of how to write a
+OpenFlow controller using Trema Ruby API.
-Trema currently supports OpenFlow version 1.0 only.
-
-
-Getting Started
----------------
-
-1.Install the prerequisites at the command prompt:
-
- (In Ubuntu or Debian GNU/Linux)
- $ sudo apt-get install gcc make git ruby rubygems ruby-dev libpcap-dev libsqlite3-dev libglib2.0-dev
-
- (In Ubuntu 10.04)
- $ sudo apt-get install gcc make git ruby rubygems ruby-dev libopenssl-ruby libpcap-dev libsqlite3-dev libglib2.0-dev
- $ sudo gem install rubygems-update
- $ sudo /var/lib/gems/1.8/bin/update_rubygems
-
- (In Fedora 16-19)
- $ sudo yum install tar gcc make git ruby rubygems ruby-devel libpcap-devel libsqlite3x-devel glib2-devel
-
-2.Install Trema at the command prompt:
-
- $ sudo gem install trema
-
-3.Optional: Install Wireshark to diagnose internal data-flows.
-
- $ sudo apt-get install wireshark
-
-4.Follow the guidelines to start developing your OpenFlow controller. You may find the following resources handy:
-
-* The [Getting Started with Trema](https://github.com/trema/trema/wiki/Quick-start).
-* The [Trema in 10 Minutes Tutorial](http://trema-10min.heroku.com/).
-* The [Trema Tutorial](http://trema-tutorial.heroku.com/).
-* The [Programming Trema Article (in Japanese)](http://gihyo.jp/dev/serial/01/openflow_sd/0007).
-
-
-Ruby API
---------
-
-The following is an excerpt from the Trema Ruby API.
-The full documents are found here http://rubydoc.info/github/trema/trema/master/frames
-
-### Event and Message Handlers
-
-Subclass
-[Trema::Controller](http://rubydoc.info/github/trema/trema/master/Trema/Controller)
-and override some of the following methods to implement your own
-controller.
-
-```ruby
-class MyController < Controller
- # handle Packet-In messages here.
- def packet_in datapath_id, message
- # ...
- end
-
- # handle Flow-Removed messages here.
- def flow_removed datapath_id, message
- # ...
- end
-
- # ...
-end
-```
-
-* [switch_ready(datapath_id)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:switch_ready)
-* [switch_disconnected(datapath_id)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:switch_disconnected)
-* [list_switches_reply(datapath_ids)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:list_switches_reply)
-* [packet_in(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:packet_in)
-* [flow_removed(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:flow_removed)
-* [port_status(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:port_status)
-* [openflow_error(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:openflow_error)
-* [features_reply(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:features_reply)
-* [stats_reply(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:stats_reply)
-* [barrier_reply(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:barrier_reply)
-* [get_config_reply(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:get_config_reply)
-* [queue_get_config_reply(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:queue_get_config_reply)
-* [vendor(datapath_id, message)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:vendor)
-
-### Flow-Mod and Packet-Out
-
-For sending Flow-Mod and Packet-Out, there are some methods defined in
-[Trema::Controller](http://rubydoc.info/github/trema/trema/master/Trema/Controller)
-class.
-
-```ruby
-class MyController < Controller
- def packet_in datapath_id, message
- # ...
- send_flow_mod_add( datapath_id, ... )
- send_packet_out( datapath_id, ... )
- end
-
- # ...
-end
-```
-
-* [send_flow_mod_add(datapath_id, options)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:send_flow_mod_add)
-* [send_flow_mod_delete(datapath_id, options)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:send_flow_mod_delete)
-* [send_flow_mod_modify(datapath_id, options)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:send_flow_mod_modify)
-* [send_packet_out(datapath_id, options)](http://rubydoc.info/github/trema/trema/master/Trema/Controller:send_packet_out)
-
-### Other OpenFlow Messages
-
-The following OpenFlow messages can be sent with
-[Trema::Controller#send_message](http://rubydoc.info/github/trema/trema/master/Trema/Controller:send_message)
-
-```ruby
-class MyController < Controller
- def switch_ready datapath_id
- # send a FeaturesRequest message
- send_message datapath_id, FeaturesRequest.new
- end
-
- def features_reply datapath_id, message
- # ...
- end
-
- # ...
-end
-```
-
-* [Trema::Hello](http://rubydoc.info/github/trema/trema/master/Trema/Hello)
-* [Trema::EchoRequest](http://rubydoc.info/github/trema/trema/master/Trema/EchoRequest)
-* [Trema::EchoReply](http://rubydoc.info/github/trema/trema/master/Trema/EchoReply)
-* [Trema::FeaturesRequest](http://rubydoc.info/github/trema/trema/master/Trema/FeaturesRequest)
-* [Trema::SetConfig](http://rubydoc.info/github/trema/trema/master/Trema/SetConfig)
-* [Trema::GetConfigRequest](http://rubydoc.info/github/trema/trema/master/Trema/GetConfigRequest)
-* [Trema::QueueGetConfigRequest](http://rubydoc.info/github/trema/trema/master/Trema/QueueGetConfigRequest)
-* [Trema::DescStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/DescStatsRequest)
-* [Trema::FlowStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/FlowStatsRequest)
-* [Trema::AggregateStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/AggregateStatsRequest)
-* [Trema::TableStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/TableStatsRequest)
-* [Trema::PortStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/PortStatsRequest)
-* [Trema::QueueStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/QueueStatsRequest)
-* [Trema::VendorStatsRequest](http://rubydoc.info/github/trema/trema/master/Trema/VendorStatsRequest)
-* [Trema::BarrierRequest](http://rubydoc.info/github/trema/trema/master/Trema/BarrierRequest)
-* [Trema::PortMod](http://rubydoc.info/github/trema/trema/master/Trema/PortMod)
-* [Trema::Vendor](http://rubydoc.info/github/trema/trema/master/Trema/Vendor)
-
-### Matching Rules
-
-The matching rule of each flow table entry can be created with
-[Match.new(options)](http://rubydoc.info/github/trema/trema/master/Trema/Match)
-and passed as ":match =>" option when sending Flow-Mod or Packet-Out.
-
-```ruby
-def packet_in datapath_id, message
- # ...
-
- send_flow_mod_add(
- datapath_id,
- :match => Match.new( :in_port => message.in_port, ...)
- # ...
- )
-
- # ...
-end
-```
-
-Also there is a utility method called
-[ExactMatch.from(packetin)](http://rubydoc.info/github/trema/trema/master/Trema/ExactMatch)
-for getting an exact match corresponding to a packet.
-
-```ruby
-def packet_in datapath_id, message
- # ...
-
- send_flow_mod_add(
- datapath_id,
- :match => ExactMatch.from( message )
- # ...
- )
-
- # ...
-end
-```
-
-### Actions
-
-The actions list of each flow table entry can be set with ":actions
-=>" when sending Flow-Mod or Packet-Out.
-
-```ruby
-# Strip the VLAN tag of a packet then send it out to switch port #1
-send_flow_mod_add(
- datapath_id,
- # ...
- :actions => [ StripVlanHeader.new, SendOutPort.new( 1 ) ]
-)
-```
-
-* [Trema::SendOutPort](http://rubydoc.info/github/trema/trema/master/Trema/SendOutPort)
-* [Trema::SetEthSrcAddr](http://rubydoc.info/github/trema/trema/master/Trema/SetEthSrcAddr)
-* [Trema::SetEthDstAddr](http://rubydoc.info/github/trema/trema/master/Trema/SetEthDstAddr)
-* [Trema::SetIpSrcAddr](http://rubydoc.info/github/trema/trema/master/Trema/SetIpSrcAddr)
-* [Trema::SetIpDstAddr](http://rubydoc.info/github/trema/trema/master/Trema/SetIpDstAddr)
-* [Trema::SetIpTos](http://rubydoc.info/github/trema/trema/master/Trema/SetIpTos)
-* [Trema::SetTransportSrcPort](http://rubydoc.info/github/trema/trema/master/Trema/SetTransportSrcPort)
-* [Trema::SetTransportDstPort](http://rubydoc.info/github/trema/trema/master/Trema/SetTransportDstPort)
-* [Trema::SetVlanVid](http://rubydoc.info/github/trema/trema/master/Trema/SetVlanVid)
-* [Trema::SetVlanPriority](http://rubydoc.info/github/trema/trema/master/Trema/SetVlanPriority)
-* [Trema::StripVlanHeader](http://rubydoc.info/github/trema/trema/master/Trema/StripVlanHeader)
-* [Trema::VendorAction](http://rubydoc.info/github/trema/trema/master/Trema/VendorAction)
-
-
-Meta
-----
-
-* Web Page: http://trema.github.com/trema/
-* Bugs: https://github.com/trema/trema/issues
-* Mailing List: https://groups.google.com/group/trema-dev
-* Twitter: http://twitter.com/trema_news
+* [trema/hello_trema](https://github.com/trema/hello_trema)
+* [trema/repeater_hub](https://github.com/trema/repeater_hub)
+* [trema/patch_panel](https://github.com/trema/patch_panel)
+* [trema/cbench](https://github.com/trema/cbench)
+* [trema/learning_switch](https://github.com/trema/learning_switch)
+* [trema/switch_monitor](https://github.com/trema/switch_monitor)
+* [trema/topology](https://github.com/trema/topology)
+* [trema/routing_switch](https://github.com/trema/routing_switch)
Contributors
------------