2016-03-09 20:37:30 -08:00
# *NOTICE*
2016-03-09 20:39:45 -08:00
#### Soon master branch, website/docs and godoc will be pointing to v2 branch, if you want to continue using v1, use a package manager (https://github.com/Masterminds/glide, it's nice!) to get a stable v1 release or latest commit or you can use `https://gopkg.in` like `go get gopkg.in/labstack/echo.v1`. It is advisable to migrate to v2.
2016-03-09 20:37:30 -08:00
2015-10-08 13:54:31 -07:00
# [Echo](http://labstack.com/echo) [](http://godoc.org/github.com/labstack/echo) [](https://raw.githubusercontent.com/labstack/echo/master/LICENSE) [](https://travis-ci.org/labstack/echo) [](https://coveralls.io/r/labstack/echo) [](https://gitter.im/labstack/echo)
2015-06-30 12:10:35 -07:00
2015-08-28 10:37:14 -07:00
A fast and unfancy micro web framework for Go.
2015-03-12 14:51:39 -07:00
2016-02-10 09:28:49 -08:00
[](https://www.paypal.com/cgi-bin/webscr?cmd=_donations& business=JD5R56K84A8G4& lc=US& item_name=LabStack& item_number=echo& currency_code=USD& bn=PP%2dDonationsBF%3abtn_donate_LG%2egif%3aNonHosted)
2015-04-13 17:42:44 -07:00
## Features
2015-04-18 16:47:48 -07:00
2015-06-18 14:40:48 -07:00
- Fast HTTP router which smartly prioritize routes.
2015-06-03 09:20:32 -07:00
- Extensible middleware, supports:
- `echo.MiddlewareFunc`
- `func(echo.HandlerFunc) echo.HandlerFunc`
- `echo.HandlerFunc`
- `func(*echo.Context) error`
- `func(http.Handler) http.Handler`
- `http.Handler`
- `http.HandlerFunc`
- `func(http.ResponseWriter, *http.Request)`
- Extensible handler, supports:
- `echo.HandlerFunc`
- `func(*echo.Context) error`
- `http.Handler`
- `http.HandlerFunc`
- `func(http.ResponseWriter, *http.Request)`
2015-06-18 14:40:48 -07:00
- Sub-router/Groups
2015-07-08 13:51:08 -07:00
- Handy functions to send variety of HTTP response:
- HTML
- HTML via templates
2015-08-28 10:37:14 -07:00
- String
2015-07-11 15:20:59 -04:00
- JSON
2015-07-24 18:54:42 -07:00
- JSONP
2015-07-11 15:20:59 -04:00
- XML
2015-08-04 19:45:44 -07:00
- File
2015-07-08 13:51:08 -07:00
- NoContent
- Redirect
- Error
2015-06-03 09:20:32 -07:00
- Build-in support for:
2015-07-08 13:51:08 -07:00
- Favicon
- Index file
2015-06-03 09:20:32 -07:00
- Static files
- WebSocket
2015-06-18 14:40:48 -07:00
- Centralized HTTP error handling.
2015-07-08 13:51:08 -07:00
- Customizable HTTP request binding function.
- Customizable HTTP response rendering function, allowing you to use any HTML template engine.
2015-03-12 14:51:39 -07:00
2015-08-28 10:37:14 -07:00
## Performance
2015-04-18 16:47:48 -07:00
2015-06-05 21:47:33 -07:00
Based on [vishr/go-http-routing-benchmark] (https://github.com/vishr/go-http-routing-benchmark), June 5, 2015.
2015-04-18 16:47:48 -07:00
2015-04-16 10:18:35 -07:00
##### [GitHub API](http://developer.github.com/v3)
2015-04-18 16:47:48 -07:00
2015-06-05 21:36:31 -07:00
> Echo: 38662 ns/op, 0 B/op, 0 allocs/op
2015-04-16 10:18:35 -07:00
2015-06-27 13:03:42 -07:00

2015-06-22 14:25:39 -07:00
2015-04-16 10:18:35 -07:00
```
2015-06-05 21:36:31 -07:00
BenchmarkAce_GithubAll 20000 93675 ns/op 13792 B/op 167 allocs/op
BenchmarkBear_GithubAll 10000 264194 ns/op 79952 B/op 943 allocs/op
BenchmarkBeego_GithubAll 2000 1109160 ns/op 146272 B/op 2092 allocs/op
BenchmarkBone_GithubAll 1000 2063973 ns/op 648016 B/op 8119 allocs/op
BenchmarkDenco_GithubAll 20000 83114 ns/op 20224 B/op 167 allocs/op
BenchmarkEcho_GithubAll 30000 38662 ns/op 0 B/op 0 allocs/op
BenchmarkGin_GithubAll 30000 43467 ns/op 0 B/op 0 allocs/op
BenchmarkGocraftWeb_GithubAll 5000 386829 ns/op 133280 B/op 1889 allocs/op
BenchmarkGoji_GithubAll 3000 561131 ns/op 56113 B/op 334 allocs/op
BenchmarkGoJsonRest_GithubAll 3000 490789 ns/op 135995 B/op 2940 allocs/op
BenchmarkGoRestful_GithubAll 100 15569513 ns/op 797239 B/op 7725 allocs/op
BenchmarkGorillaMux_GithubAll 200 7431130 ns/op 153137 B/op 1791 allocs/op
BenchmarkHttpRouter_GithubAll 30000 51192 ns/op 13792 B/op 167 allocs/op
BenchmarkHttpTreeMux_GithubAll 10000 138164 ns/op 56112 B/op 334 allocs/op
BenchmarkKocha_GithubAll 10000 139625 ns/op 23304 B/op 843 allocs/op
BenchmarkMacaron_GithubAll 2000 709932 ns/op 224960 B/op 2315 allocs/op
BenchmarkMartini_GithubAll 100 10261331 ns/op 237953 B/op 2686 allocs/op
BenchmarkPat_GithubAll 500 3989686 ns/op 1504104 B/op 32222 allocs/op
BenchmarkPossum_GithubAll 5000 259165 ns/op 97441 B/op 812 allocs/op
BenchmarkR2router_GithubAll 10000 240345 ns/op 77328 B/op 1182 allocs/op
BenchmarkRevel_GithubAll 2000 1203336 ns/op 345554 B/op 5918 allocs/op
BenchmarkRivet_GithubAll 10000 247213 ns/op 84272 B/op 1079 allocs/op
BenchmarkTango_GithubAll 5000 379960 ns/op 87081 B/op 2470 allocs/op
BenchmarkTigerTonic_GithubAll 2000 931401 ns/op 241089 B/op 6052 allocs/op
BenchmarkTraffic_GithubAll 200 7292170 ns/op 2664770 B/op 22390 allocs/op
BenchmarkVulcan_GithubAll 5000 271682 ns/op 19894 B/op 609 allocs/op
BenchmarkZeus_GithubAll 2000 748827 ns/op 300688 B/op 2648 allocs/op
2015-04-16 10:18:35 -07:00
```
2015-07-03 11:50:59 -07:00
## Echo System
2016-01-30 11:26:45 -08:00
### Who's using Echo?
2016-02-01 15:10:15 -08:00
- [LabStack ](https://labstack.com )
2016-01-30 11:26:45 -08:00
- [ShowChampions ](https://showchampions.photoserve.co )
- [deferpanic ](https://deferpanic.com )
- [Center for Open Science ](https://cos.io )
- [SeeSaw Labs ](http://www.seesawlabs.com )
- [Kyäni ](http://www.kyani.net )
- [Carrot Creative ](http://carrot.is )
- [EurekaMetrics ](http://eurekametrics.com )
- [Coursella ](https://www.coursella.com )
- [blue Vanilla ](https://www.bleuvanille.fr )
- [ImPlaces ](http://www.implaces.com )
- [Gomoku ](http://gomoku.thoughtsfromplac.es )
- [DrinkIn ](https://drinkin.com )
- [PodBaby ](https://podbaby.me )
2016-01-31 08:55:43 -08:00
- [gifs ](https://gifs.com )
2016-01-30 11:26:45 -08:00
### Community created packages around Echo
2015-07-03 11:50:59 -07:00
- [echo-logrus ](https://github.com/deoxxa/echo-logrus )
- [go_middleware ](https://github.com/rightscale/go_middleware )
- [permissions2 ](https://github.com/xyproto/permissions2 )
- [permissionbolt ](https://github.com/xyproto/permissionbolt )
2015-07-11 15:30:26 -07:00
- [echo-middleware ](https://github.com/syntaqx/echo-middleware )
2015-11-06 14:53:49 -08:00
- [dpecho ](https://github.com/deferpanic/dpecho )
2015-11-15 11:09:57 +01:00
- [echosentry ](https://github.com/01walid/echosentry )
2016-01-30 11:26:45 -08:00
- [go-starter-kit ](https://github.com/olebedev/go-starter-kit )
[Want to get listed? ](https://github.com/labstack/echo/issues/295 )
2015-07-03 11:50:59 -07:00
2016-01-30 11:32:56 -08:00
## Installation
```sh
$ go get github.com/labstack/echo
```
## [Recipes](http://labstack.com/echo/recipes/hello-world)
## [Guide](http://labstack.com/echo/guide/installation)
2015-04-25 16:10:28 -07:00
## Contribute
**Use issues for everything**
2015-04-26 22:41:41 -07:00
2015-04-25 16:10:28 -07:00
- Report problems
2015-11-09 09:43:40 -08:00
- Discuss before sending a pull request
- Suggest new features/recipes
2015-04-25 16:10:28 -07:00
- Improve/fix documentation
## Credits
- [Vishal Rana ](https://github.com/vishr ) - Author
- [Nitin Rana ](https://github.com/nr17 ) - Consultant
- [Contributors ](https://github.com/labstack/echo/graphs/contributors )