easyNet - NON BLOCKING IO
package main
import (
"fmt"
"github.com/wubbalubbaaa/easyNet"
"time"
)
func onOpen(c *easyNet.Conn) {
c.SetReadDeadline(time.Now().Add(time.Second * 13))
fmt.Println("onOpen:", c.RemoteAddr().String(), time.Now().Format("15:04:05.000"))
}
func onClose(c *easyNet.Conn) {
fmt.Println("onClose:", c.RemoteAddr().String(), time.Now().Format("15:04:05.000"))
}
func onData(c *easyNet.Conn, data []byte) {
c.SetReadDeadline(time.Now().Add(time.Second * 10))
c.SetWriteDeadline(time.Now().Add(time.Second * 3))
c.Write(append([]byte{}, data...))
}
func main() {
g, err := easyNet.NewGopher(easyNet.Config{
Network: "tcp",
Address: ":8888",
NPoller: 4,
NWorker: 8,
QueueSize: 1024,
BufferSize: 1024 * 64,
BufferNum: 1024 * 2,
PollInterval: 200, //ms
MaxTimeout: 10 * 1000, //ms
})
if err != nil {
fmt.Printf("easyNet.New failed: %v\n", err)
return
}
g.OnOpen(onOpen)
g.OnClose(onClose)
g.OnData(onData)
err = g.Start()
if err != nil {
fmt.Printf("easyNet.Start failed: %v\n", err)
return
}
go func() {
for {
time.Sleep(time.Second * 5)
fmt.Println(g.State().String())
}
}()
g.Wait()
}