mirror of https://github.com/q191201771/naza
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
1.6 KiB
Go
83 lines
1.6 KiB
Go
6 years ago
|
package main
|
||
|
|
||
|
import (
|
||
|
"flag"
|
||
|
"github.com/q191201771/nezha/pkg/errors"
|
||
|
"github.com/q191201771/nezha/pkg/log"
|
||
|
"net"
|
||
|
"sync"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
// 测试 net.Conn.SetWriteDeadline 的性能开销
|
||
|
//
|
||
|
// 使用 <numOfConn> 个客户端端连接,并行向服务端发送数据
|
||
|
// 每个客户端发送 <numOfMsgPerConn> 个消息
|
||
|
// 服务端 MockServer 只接收数据,不做其他逻辑
|
||
|
|
||
|
const (
|
||
|
addr = ":10027"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
numOfConn int
|
||
|
numOfMsgPerConn int
|
||
|
)
|
||
|
|
||
|
func raw(writeTimeoutSec int) {
|
||
|
log.Infof("> raw. writeTimeoutSec=%d", writeTimeoutSec)
|
||
|
var ms MockServer
|
||
|
var conns []net.Conn
|
||
|
buf := make([]byte, 8)
|
||
|
|
||
|
ms.start(addr)
|
||
|
for i := 0; i < numOfConn; i++ {
|
||
|
conn, err := net.Dial("tcp", addr)
|
||
|
errors.PanicIfErrorOccur(err)
|
||
|
conns = append(conns, conn)
|
||
|
}
|
||
|
|
||
|
var wg sync.WaitGroup
|
||
|
wg.Add(numOfConn)
|
||
|
|
||
|
b := time.Now()
|
||
|
log.Infof("b:%+v", b)
|
||
|
for i := 0; i < numOfConn; i++ {
|
||
|
go func(ii int) {
|
||
|
for j := 0; j < numOfMsgPerConn; j++ {
|
||
|
if writeTimeoutSec != 0 {
|
||
|
err := conns[ii].SetWriteDeadline(time.Now().Add(time.Duration(writeTimeoutSec) * time.Second))
|
||
|
errors.PanicIfErrorOccur(err)
|
||
|
}
|
||
|
_, err := conns[ii].Write(buf)
|
||
|
errors.PanicIfErrorOccur(err)
|
||
|
}
|
||
|
wg.Done()
|
||
|
}(i)
|
||
|
}
|
||
|
wg.Wait()
|
||
|
log.Infof("cost=%v", time.Now().Sub(b))
|
||
|
|
||
|
for i := 0; i < numOfConn; i++ {
|
||
|
err := conns[i].Close()
|
||
|
errors.PanicIfErrorOccur(err)
|
||
|
}
|
||
|
ms.stop()
|
||
|
log.Info("< raw.")
|
||
|
}
|
||
|
|
||
|
func main() {
|
||
|
c := flag.Int("c", 0, "num of conn")
|
||
|
n := flag.Int("n", 0, "num of msg per conn")
|
||
|
flag.Parse()
|
||
|
if *c == 0 || *n == 0 {
|
||
|
flag.Usage()
|
||
|
return
|
||
|
}
|
||
|
numOfConn = *c
|
||
|
numOfMsgPerConn = *n
|
||
|
|
||
|
raw(0)
|
||
|
raw(5)
|
||
|
}
|