2018-12-02 16:53:43 +03:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/panjf2000/ants"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Request struct {
|
|
|
|
Param []byte
|
|
|
|
Result chan []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
pool, _ := ants.NewPoolWithFunc(100, func(payload interface{}) {
|
|
|
|
request, ok := payload.(Request)
|
|
|
|
if !ok {
|
2018-12-02 17:03:18 +03:00
|
|
|
request = Request{Param:[]byte(""), Result: make(chan []byte)}
|
2018-12-02 16:53:43 +03:00
|
|
|
}
|
|
|
|
reverseParam := func(s []byte) []byte {
|
|
|
|
for i, j := 0, len(s)-1; i < j; i, j = i+1, j-1 {
|
|
|
|
s[i], s[j] = s[j], s[i]
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}(request.Param)
|
|
|
|
|
|
|
|
request.Result <- reverseParam
|
|
|
|
})
|
|
|
|
defer pool.Release()
|
|
|
|
|
|
|
|
http.HandleFunc("/reverse", func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
param, err := ioutil.ReadAll(r.Body)
|
|
|
|
if err != nil {
|
|
|
|
http.Error(w, "request error", http.StatusInternalServerError)
|
|
|
|
}
|
|
|
|
defer r.Body.Close()
|
|
|
|
|
|
|
|
request := Request{Param: param, Result: make(chan []byte)}
|
|
|
|
|
|
|
|
// Throttle the requests with ants pool. This process is asynchronous and
|
|
|
|
// you can receive a result from the channel defined outside.
|
|
|
|
if err := pool.Serve(request); err != nil {
|
|
|
|
http.Error(w, "throttle limit error", http.StatusInternalServerError)
|
|
|
|
}
|
|
|
|
|
|
|
|
w.Write(<-request.Result)
|
|
|
|
})
|
|
|
|
|
|
|
|
http.ListenAndServe(":8080", nil)
|
|
|
|
}
|