4.1 KiB
4.1 KiB
bone
What is bone ?
Bone is a lightweight and lightning fast HTTP Multiplexer for Golang. It support :
- URL Parameters
- REGEX Parameters
- Wildcard routes
- Router Prefix
- Sub Router,
mux.SubRoute()
, support most standard router (bone, gorilla/mux, httpRouter etc...) - Http method declaration
- Support for
http.Handler
andhttp.HandlerFunc
- Custom NotFound handler
- Respect the Go standard
http.Handler
interface
Speed
- BenchmarkBoneMux 10000000 118 ns/op
- BenchmarkZeusMux 100000 144 ns/op
- BenchmarkHttpRouterMux 10000000 134 ns/op
- BenchmarkNetHttpMux 3000000 580 ns/op
- BenchmarkGorillaMux 300000 3333 ns/op
- BenchmarkGorillaPatMux 1000000 1889 ns/op
These test are just for fun, all these router are great and really efficient. Bone do not pretend to be the fastest router for every job.
Example
package main
import(
"net/http"
"github.com/go-zoo/bone"
)
func main () {
mux := bone.New()
// mux.Get, Post, etc ... takes http.Handler
mux.Get("/home/:id", http.HandlerFunc(HomeHandler))
mux.Get("/profil/:id/:var", http.HandlerFunc(ProfilHandler))
mux.Post("/data", http.HandlerFunc(DataHandler))
// Support REGEX Route params
mux.Get("/index/#id^[0-9]$", http.HandleFunc(IndexHandler))
// Handle take http.Handler
mux.Handle("/", http.HandlerFunc(RootHandler))
// GetFunc, PostFunc etc ... takes http.HandlerFunc
mux.GetFunc("/test", Handler)
http.ListenAndServe(":8080", mux)
}
func Handler(rw http.ResponseWriter, req *http.Request) {
// Get the value of the "id" parameters.
val := bone.GetValue(req, "id")
rw.Write([]byte(val))
}
Changelog
Update 10 September 2016
- Add support for go1.7 net.Context
Update 25 September 2015
- Add support for Sub router
Example :
func main() {
mux := bone.New()
sub := mux.NewRouter()
sub.GetFunc("/test/example", func(rw http.ResponseWriter, req *http.Request) {
rw.Write([]byte("From sub router !"))
})
mux.SubRoute("/api", sub)
http.ListenAndServe(":8080", mux)
}
Update 26 April 2015
- Add Support for REGEX parameters, using
#
instead of:
. - Add Mux method
mux.GetFunc(), mux.PostFunc(), etc ...
, takeshttp.HandlerFunc
instead ofhttp.Handler
.
Example :
func main() {
mux.GetFunc("/route/#var^[a-z]$", handler)
}
func handler(rw http.ResponseWriter, req *http.Request) {
bone.GetValue(req, "var")
}
Update 29 january 2015
- Speed improvement for url Parameters, from
~ 1500 ns/op
to~ 1000 ns/op
.
Update 25 december 2014
After trying to find a way of using the default url.Query() for route parameters, i decide to change the way bone is dealing with this. url.Query() is too slow for good router performance.
So now to get the parameters value in your handler, you need to use
bone.GetValue(req, key)
instead of req.Url.Query().Get(key)
.
This change give a big speed improvement for every kind of application using route parameters, like ~80x faster ...
Really sorry for breaking things, but i think it's worth it.
TODO
- DOC
- More Testing
- Debugging
- Optimisation
Contributing
- Fork it
- Create your feature branch (git checkout -b my-new-feature)
- Write Tests!
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create new Pull Request
License
MIT
Links
- Blog post talking about bone : http://www.peterbe.com/plog/my-favorite-go-multiplexer