main.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. package main
  2. import (
  3. "fmt"
  4. jsoniter "github.com/json-iterator/go"
  5. mhayaHttp "github.com/mhaya/extend/http"
  6. mhayaTime "github.com/mhaya/extend/time"
  7. "github.com/mhaya/game/game_cluster/internal/code"
  8. mhayaLogger "github.com/mhaya/logger"
  9. pomeloClient "github.com/mhaya/net/parser/pomelo/client"
  10. "math/rand"
  11. "sync"
  12. "time"
  13. )
  14. var (
  15. maxRobotNum = 10000 // 运行x个机器人
  16. url = "http://127.0.0.1" // web node
  17. addr = "127.0.0.1:10011" // 网关地址(正式环境通过区服列表获取)
  18. serverId int32 = 10001 // 测试的游戏服id
  19. pid = "2126001" // 测试的sdk包id
  20. printLog = false // 是否输出详细日志
  21. )
  22. func main() {
  23. wg := sync.WaitGroup{}
  24. wg.Add(1)
  25. accounts := make(map[string]string)
  26. for i := 1; i <= maxRobotNum; i++ {
  27. key := fmt.Sprintf("test%d", i)
  28. accounts[key] = key
  29. }
  30. RegisterDevAccount(url, accounts)
  31. for userName, password := range accounts {
  32. time.Sleep(time.Duration(rand.Int31n(2)) * time.Millisecond)
  33. go RunRobot(url, pid, userName, password, addr, serverId, printLog)
  34. }
  35. wg.Wait()
  36. }
  37. func RegisterDevAccount(url string, accounts map[string]string) {
  38. requestURL := fmt.Sprintf("%s/register", url)
  39. for key, val := range accounts {
  40. params := map[string]string{
  41. "account": key,
  42. "password": val,
  43. }
  44. jsonBytes, _, err := mhayaHttp.GET(requestURL, params)
  45. if err != nil {
  46. mhayaLogger.Warn(err)
  47. return
  48. }
  49. rsp := &code.Result{}
  50. err = jsoniter.Unmarshal(jsonBytes, rsp)
  51. if err != nil {
  52. mhayaLogger.Warn(err)
  53. return
  54. }
  55. mhayaLogger.Debugf("register account = %s, result = %+v", key, rsp)
  56. }
  57. }
  58. func RunRobot(url, pid, userName, password, addr string, serverId int32, printLog bool) *Robot {
  59. // 创建客户端
  60. cli := New(
  61. pomeloClient.New(
  62. pomeloClient.WithRequestTimeout(10*time.Second),
  63. pomeloClient.WithErrorBreak(true),
  64. ),
  65. )
  66. cli.PrintLog = printLog
  67. // 登录获取token
  68. if err := cli.GetToken(url, pid, userName, password); err != nil {
  69. mhayaLogger.Error(err)
  70. return nil
  71. }
  72. // 根据地址连接网关
  73. if err := cli.ConnectToTCP(addr); err != nil {
  74. mhayaLogger.Error(err)
  75. return nil
  76. }
  77. if cli.PrintLog {
  78. mhayaLogger.Infof("tcp connect %s is ok", addr)
  79. }
  80. // 随机休眠
  81. cli.RandSleep()
  82. // 用户登录到游戏节点
  83. err := cli.UserLogin(serverId)
  84. if err != nil {
  85. mhayaLogger.Warn(err)
  86. return nil
  87. }
  88. if cli.PrintLog {
  89. mhayaLogger.Infof("user login is ok. [user = %s, serverId = %d]", userName, serverId)
  90. }
  91. //cli.RandSleep()
  92. // 查看是否有角色
  93. err = cli.PlayerSelect()
  94. if err != nil {
  95. mhayaLogger.Warn(err)
  96. return nil
  97. }
  98. //cli.RandSleep()
  99. // 创建角色
  100. err = cli.ActorCreate()
  101. if err != nil {
  102. mhayaLogger.Warn(err)
  103. return nil
  104. }
  105. //cli.RandSleep()
  106. // 角色进入游戏
  107. err = cli.ActorEnter()
  108. if err != nil {
  109. mhayaLogger.Warn(err)
  110. return nil
  111. }
  112. elapsedTime := cli.StartTime.DiffInMillisecond(mhayaTime.Now())
  113. mhayaLogger.Debugf("[%s] is enter to game. elapsed time:%dms", cli.TagName, elapsedTime)
  114. //cli.Disconnect()
  115. return cli
  116. }