main.go 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. jsoniter "github.com/json-iterator/go"
  6. mhayaHttp "github.com/mhaya/extend/http"
  7. "github.com/mhaya/game/game_cluster/internal/code"
  8. "github.com/mhaya/game/game_cluster/internal/param"
  9. mhayaLogger "github.com/mhaya/logger"
  10. "math/rand"
  11. "strconv"
  12. "sync"
  13. "time"
  14. )
  15. func main() {
  16. // 定义命令行标志
  17. userOffset := flag.Int("userOffset", 14000, "用户偏移量")
  18. count := flag.Int("count", 35, "请求总数")
  19. qps := flag.Int("qps", 10, "最大并发数")
  20. url := flag.String("url", "http://127.0.0.1:20000", "请求url")
  21. url1 := flag.String("url1", "http://127.0.0.1:20001", "请求url")
  22. url2 := flag.String("url2", "http://127.0.0.1:20002", "请求url")
  23. url3 := flag.String("url3", "http://127.0.0.1:20003", "请求url")
  24. duration := flag.Int("duration", 1, "测试持续时间")
  25. flag.Parse()
  26. startTime := time.Now()
  27. var wg sync.WaitGroup
  28. wg.Add(*count)
  29. // 创建一个 channel 来控制请求的速率
  30. reqCh := make(chan struct{}, *qps)
  31. // 控制请求速率的 goroutine
  32. go func() {
  33. ticker := time.NewTicker(time.Second / time.Duration(*qps))
  34. defer ticker.Stop()
  35. for range ticker.C {
  36. reqCh <- struct{}{}
  37. }
  38. }()
  39. // 发送请求的 goroutine
  40. go func() {
  41. for i := *userOffset; i < *count+*userOffset; i++ {
  42. <-reqCh
  43. go func() {
  44. defer wg.Done()
  45. str := strconv.Itoa(i)
  46. account := &param.LoginReq{
  47. Pid: 2,
  48. OpenID: str,
  49. Platform: "ios",
  50. Channel: "tg",
  51. }
  52. n := rand.Intn(1)
  53. switch n {
  54. case 0:
  55. RunRobot(*url, account, i)
  56. case 1:
  57. RunRobot(*url1, account, i)
  58. case 2:
  59. RunRobot(*url2, account, i)
  60. case 3:
  61. RunRobot(*url3, account, i)
  62. }
  63. }()
  64. }
  65. }()
  66. // 等待所有请求完成
  67. wg.Wait()
  68. fmt.Println("All goroutines have finished.")
  69. qpsAchieved := float64(*count) / time.Since(startTime).Seconds()
  70. fmt.Printf("Sent %d requests in %v, achieved QPS: %.2f\n", *count, duration, qpsAchieved)
  71. }
  72. func RunRobot(url string, val *param.LoginReq, num int) {
  73. fmt.Println("start goroutines i:%v", num)
  74. token := RegisterDevAccount(url, val)
  75. if token == "" {
  76. return
  77. }
  78. params := map[string]interface{}{
  79. "nickName": "guest" + val.OpenID,
  80. }
  81. rs := Login(url, params, token)
  82. if !code.IsFail(rs) {
  83. start(val, token, url)
  84. }
  85. params2 := map[string]interface{}{
  86. "parentName": "8FXc13he2T1bce64fJca9b2Qx",
  87. }
  88. Invite(url, params2, token)
  89. //singInList(val, token, url)
  90. //singIn(val, token,url)
  91. }
  92. func RegisterDevAccount(url string, val *param.LoginReq) string {
  93. requestURL := fmt.Sprintf("%s/auth", url)
  94. params := map[string]interface{}{
  95. "pid": val.Pid,
  96. "openid": val.OpenID,
  97. "platform": val.Platform,
  98. "channel": val.Channel,
  99. }
  100. jsonBytes, _, err := mhayaHttp.PostJSON(requestURL, params)
  101. if err != nil {
  102. mhayaLogger.Warn(err)
  103. return ""
  104. }
  105. rsp := &code.Result{}
  106. err = jsoniter.Unmarshal(jsonBytes, rsp)
  107. if err != nil {
  108. mhayaLogger.Warn(err)
  109. return ""
  110. }
  111. if rsp.Code == 0 {
  112. mhayaLogger.Debugf("register account = %v, result = %v", val.OpenID, rsp)
  113. return rsp.Data.(string)
  114. }
  115. return ""
  116. }
  117. func start(val *param.LoginReq, token string, url string) {
  118. requestURL := fmt.Sprintf("%s/start", url)
  119. params := map[string]interface{}{
  120. "pid": val.Pid,
  121. "openId": val.OpenID,
  122. }
  123. execute("start", requestURL, params, token)
  124. }
  125. func singInList(val *param.LoginReq, token string, url string) {
  126. requestURL := fmt.Sprintf("%s/signInList", url)
  127. params := map[string]interface{}{}
  128. execute("signInList", requestURL, params, token)
  129. }
  130. func singIn(val *param.LoginReq, token string, url string) {
  131. requestURL := fmt.Sprintf("%s/signIn", url)
  132. params := map[string]interface{}{}
  133. execute("signIn", requestURL, params, token)
  134. }
  135. func rank(val *param.LoginReq, token string, url string) {
  136. requestURL := fmt.Sprintf("%s/rank", url)
  137. params := map[string]interface{}{
  138. "id": 1,
  139. "tp": 1,
  140. }
  141. execute("rank", requestURL, params, token)
  142. }
  143. func inviteRewardRatio(val *param.LoginReq, token string, url string) {
  144. requestURL := fmt.Sprintf("%s/inviteRewardRatio", url)
  145. params := map[string]interface{}{}
  146. execute("inviteRewardRatio", requestURL, params, token)
  147. }
  148. func inviteNodeReward(val *param.LoginReq, token string, url string) {
  149. requestURL := fmt.Sprintf("%s/inviteNodeReward", url)
  150. params := map[string]interface{}{}
  151. execute("inviteNodeReward", requestURL, params, token)
  152. }
  153. func itemWeekRecord(val *param.LoginReq, token string, url string) {
  154. requestURL := fmt.Sprintf("%s/itemWeekRecord", url)
  155. params := map[string]interface{}{}
  156. execute("itemWeekRecord", requestURL, params, token)
  157. }
  158. func inviteRewardRatioHistory(val *param.LoginReq, token string, url string) {
  159. requestURL := fmt.Sprintf("%s/inviteRewardRatioHistory", url)
  160. params := map[string]interface{}{}
  161. execute("inviteRewardRatioHistory", requestURL, params, token)
  162. }
  163. func countryRank(val *param.LoginReq, token string, url string) {
  164. requestURL := fmt.Sprintf("%s/countryRank", url)
  165. params := map[string]interface{}{}
  166. execute("countryRank", requestURL, params, token)
  167. }
  168. func claim(val *param.LoginReq, token string, url string) {
  169. requestURL := fmt.Sprintf("%s/claim", url)
  170. params := map[string]interface{}{}
  171. execute("claim", requestURL, params, token)
  172. }
  173. func Login(url string, params map[string]interface{}, token string) int32 {
  174. requestURL := fmt.Sprintf("%s/login", url)
  175. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  176. if err != nil {
  177. mhayaLogger.Warnf("login err: %v", err)
  178. return 1
  179. }
  180. rsp := &code.Result{}
  181. err = jsoniter.Unmarshal(jsonBytes, rsp)
  182. if err != nil {
  183. mhayaLogger.Warnf("login Unmarshal err :%v ", err)
  184. return 1
  185. }
  186. if rsp.Code == 0 {
  187. mhayaLogger.Debugf("Login OK : %v", rsp.Code)
  188. return 0
  189. } else {
  190. mhayaLogger.Debugf("Login Fail : %v", rsp.Code)
  191. }
  192. return 1
  193. }
  194. func execute(handler string, url string, params map[string]interface{}, token string) {
  195. //requestURL := fmt.Sprintf("%s/start", url)
  196. jsonBytes, err := mhayaHttp.PostJSONWithHeader(url, params, token)
  197. if err != nil {
  198. mhayaLogger.Warn(err)
  199. return
  200. }
  201. rsp := &code.Result{}
  202. err = jsoniter.Unmarshal(jsonBytes, rsp)
  203. if err != nil {
  204. mhayaLogger.Warn(err)
  205. return
  206. }
  207. mhayaLogger.Debugf("%s parms =%v", handler, params)
  208. mhayaLogger.Debugf("%s rsp =%v", handler, rsp)
  209. }
  210. func Invite(url string, params map[string]interface{}, token string) {
  211. requestURL := fmt.Sprintf("%s/invite", url)
  212. jsonBytes, err := mhayaHttp.PostJSONWithHeader(requestURL, params, token)
  213. if err != nil {
  214. mhayaLogger.Warn(err)
  215. return
  216. }
  217. rsp := &code.Result{}
  218. err = jsoniter.Unmarshal(jsonBytes, rsp)
  219. if err != nil {
  220. mhayaLogger.Warn(err)
  221. return
  222. }
  223. mhayaLogger.Debugf("Invite %v", params)
  224. }
  225. //func RunRobot1(url, pid, userName, password, addr string, serverId int32, printLog bool) *Robot {
  226. // // 创建客户端
  227. // cli := New(
  228. // pomeloClient.New(
  229. // pomeloClient.WithRequestTimeout(10*time.Second),
  230. // pomeloClient.WithErrorBreak(true),
  231. // ),
  232. // )
  233. // cli.PrintLog = printLog
  234. //
  235. // // 登录获取token
  236. // if err := cli.GetToken(url, pid, userName, password); err != nil {
  237. // mhayaLogger.Error(err)
  238. // return nil
  239. // }
  240. //
  241. // // 根据地址连接网关
  242. // if err := cli.ConnectToTCP(addr); err != nil {
  243. // mhayaLogger.Error(err)
  244. // return nil
  245. // }
  246. //
  247. // if cli.PrintLog {
  248. // mhayaLogger.Infof("tcp connect %s is ok", addr)
  249. // }
  250. //
  251. // // 随机休眠
  252. // cli.RandSleep()
  253. //
  254. // // 用户登录到游戏节点
  255. // err := cli.UserLogin(serverId)
  256. // if err != nil {
  257. // mhayaLogger.Warn(err)
  258. // return nil
  259. // }
  260. //
  261. // if cli.PrintLog {
  262. // mhayaLogger.Infof("user login is ok. [user = %s, serverId = %d]", userName, serverId)
  263. // }
  264. //
  265. // //cli.RandSleep()
  266. //
  267. // // 查看是否有角色
  268. // err = cli.PlayerSelect()
  269. // if err != nil {
  270. // mhayaLogger.Warn(err)
  271. // return nil
  272. // }
  273. //
  274. // //cli.RandSleep()
  275. //
  276. // // 创建角色
  277. // err = cli.ActorCreate()
  278. // if err != nil {
  279. // mhayaLogger.Warn(err)
  280. // return nil
  281. // }
  282. //
  283. // //cli.RandSleep()
  284. //
  285. // // 角色进入游戏
  286. // err = cli.ActorEnter()
  287. // if err != nil {
  288. // mhayaLogger.Warn(err)
  289. // return nil
  290. // }
  291. //
  292. // elapsedTime := cli.StartTime.DiffInMillisecond(mhayaTime.Now())
  293. // mhayaLogger.Debugf("[%s] is enter to database. elapsed time:%dms", cli.TagName, elapsedTime)
  294. //
  295. // //cli.Disconnect()
  296. //
  297. // return cli
  298. //}