main.go 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. //package main
  2. //
  3. //import (
  4. // "database/sql"
  5. // "fmt"
  6. // _ "github.com/taosdata/driver-go/v3/taosSql"
  7. // "log"
  8. // "math/rand"
  9. // "sync"
  10. // "time"
  11. //)
  12. //
  13. //var DateFmtYYYYMMDDHHmmss = "2006-01-02 15:04:05"
  14. //
  15. //func main() {
  16. // var taosDSN = "root:taosdata@tcp(192.168.0.153:6030)/test2"
  17. // taos, err := sql.Open("taosSql", taosDSN)
  18. // if err != nil {
  19. // log.Fatalln("failed to connect TDengine, err:", err)
  20. // return
  21. // }
  22. // defer taos.Close()
  23. //
  24. // // 测试插入数据
  25. // now := time.Now().Add(-18 * time.Hour)
  26. //
  27. // list := getObject(100)
  28. //
  29. // fmt.Println("开始 ", time.Now().Format(DateFmtYYYYMMDDHHmmss))
  30. // wg := sync.WaitGroup{}
  31. // for p := 0; p < len(list); p++ {
  32. // wg.Add(1)
  33. // go func(p int) {
  34. // defer wg.Done()
  35. //
  36. // for i := 40; i > 1; i-- {
  37. // num := rand.Intn(24)
  38. // day := now.AddDate(0, 0, -i).Add(time.Duration(num) * time.Hour)
  39. //
  40. // data := ""
  41. // for j := 0; j < 10001; j++ {
  42. // //for j := 0; j < 5; j++ {
  43. // num := 1
  44. // addMill := rand.Intn(3000) + 1
  45. // operation := rand.Intn(19) + 1
  46. // operationType := rand.Intn(1) + 1
  47. //
  48. // //fmt.Println(day.Add(time.Duration(j*22)*time.Minute).Format(DateFmtYYYYMMDDHHmmss), a)
  49. // data = fmt.Sprintf("%s (%d,%d)", data, day.Add(time.Duration(j*addMill)*time.Second).UnixMilli(), num)
  50. // if j%10000 == 0 {
  51. // //if j%2 == 0 {
  52. // // insert into 1_1_2 USING tx_metrics TAGS (1,1,2,4,1) values ....
  53. // data = fmt.Sprintf("insert into %d_%d_%d USING tx_metrics TAGS (%d, %d, %d, %d, %d) values%s", list[p].Chain, list[p].Uid, list[p].Pid, list[p].Chain, list[p].Uid, list[p].Pid, operation, operationType, data)
  54. //
  55. // _, err = taos.Exec(data)
  56. // if err != nil {
  57. // fmt.Println("failed to insert, err:", err)
  58. // fmt.Println("failed to insert, cup:", list[p])
  59. // return
  60. // }
  61. // data = ""
  62. // }
  63. // }
  64. // }
  65. //
  66. // fmt.Println("完成 ", time.Now().Format(DateFmtYYYYMMDDHHmmss), " 当前cup: ", list[p])
  67. // }(p)
  68. // wg.Wait()
  69. // fmt.Println("结束 ", time.Now().Format(DateFmtYYYYMMDDHHmmss))
  70. //
  71. // }
  72. //}
  73. //
  74. //type TxObject struct {
  75. // Chain int
  76. // Uid int
  77. // Pid int
  78. // //Account string
  79. //}
  80. //
  81. //func getObject(num int) []TxObject {
  82. // var list []TxObject
  83. // for i := 0; i < num; i++ {
  84. // rand.Seed(time.Now().UnixNano())
  85. // chain := rand.Intn(3) + 1
  86. // user := rand.Intn(10) + 1
  87. // project1 := rand.Intn(20) + 1
  88. // project2 := rand.Intn(20) + 1
  89. // list = append(list, TxObject{
  90. // Chain: chain,
  91. // Uid: user,
  92. // Pid: project1,
  93. // }, TxObject{
  94. // Chain: chain,
  95. // Uid: user,
  96. // Pid: project2,
  97. // })
  98. // }
  99. // return list
  100. //}
  101. package main
  102. import (
  103. "context"
  104. "database/sql"
  105. "errors"
  106. "fmt"
  107. "log"
  108. "math/rand"
  109. "strings"
  110. "time"
  111. "golang.org/x/sync/errgroup"
  112. _ "github.com/taosdata/driver-go/v3/taosSql"
  113. )
  114. func Client() *sql.DB {
  115. var taosDSN = "root:taosdata@tcp(192.168.0.153:6030)/avata_1"
  116. taos, err := sql.Open("taosSql", taosDSN)
  117. if err != nil {
  118. log.Fatalln("failed to connect TDengine, err:", err)
  119. return nil
  120. }
  121. return taos
  122. }
  123. type TxGas struct {
  124. ChainID int
  125. UserID int
  126. ProjectID int
  127. Account string
  128. Timestamp int64
  129. Gas int
  130. }
  131. func Producer(v chan<- *[]*TxGas) {
  132. defer close(v)
  133. rand.Seed(time.Now().UnixNano())
  134. // 随机生成链账户 3000w
  135. // 对于每个链账户的不同 operation 都造一个 point
  136. group, ctx := errgroup.WithContext(context.Background())
  137. for i := 1; i <= 1000; i++ {
  138. chainId := rand.Intn(3) + 1
  139. userId := i
  140. prjId := i
  141. group.Go(func() error {
  142. for a := 0; a < 5000; a++ {
  143. points := []*TxGas{}
  144. gas := 0
  145. select {
  146. case <-ctx.Done():
  147. return nil
  148. case <-time.After(time.Second * 10):
  149. return errors.New("timeout 10s")
  150. default:
  151. }
  152. address := RandAddress("iaa", 39)
  153. // 每个链账户的 20 种操作类型随机出 30 个
  154. for j := 10; j > 0; j-- {
  155. gas += rand.Intn(1e5)
  156. points = append(points, &TxGas{
  157. ChainID: chainId,
  158. UserID: userId,
  159. ProjectID: prjId,
  160. Timestamp: time.Now().Add(-(time.Hour * time.Duration(j))).UnixMilli(),
  161. Account: address,
  162. Gas: gas,
  163. })
  164. }
  165. v <- &points
  166. }
  167. return nil
  168. })
  169. }
  170. err := group.Wait()
  171. if err != nil {
  172. log.Fatalf("group err: %v", err)
  173. return
  174. }
  175. }
  176. func Consumer(v <-chan *[]*TxGas) {
  177. client := Client()
  178. group, ctx := errgroup.WithContext(context.Background())
  179. count := 0 // 30418
  180. for i := 0; i < 100; i++ {
  181. group.Go(func() error {
  182. for points, ok := <-v; ok; {
  183. select {
  184. case <-ctx.Done():
  185. return nil
  186. case <-time.After(time.Second * 10):
  187. log.Println(errors.New("timeout 10s"))
  188. //return errors.New("timeout 10s")
  189. default:
  190. }
  191. data := ""
  192. for _, p := range *points {
  193. data += fmt.Sprintf(" (%d,%d)", p.Timestamp, p.Gas)
  194. }
  195. data = fmt.Sprintf("insert into %s USING txs_gas TAGS (%d, %d, %d, '%s') values %s", (*points)[0].Account, (*points)[0].ChainID, (*points)[0].UserID, (*points)[0].ProjectID, (*points)[0].Account, data)
  196. //fmt.Println(data)
  197. _, err := client.Exec(data)
  198. if err != nil {
  199. fmt.Println("failed to insert, err:", err)
  200. continue
  201. }
  202. count += 100
  203. fmt.Println("count:", count, " ,len of v :", len(v))
  204. points, ok = <-v
  205. }
  206. return nil
  207. })
  208. }
  209. err := group.Wait()
  210. if err != nil {
  211. log.Fatalf("group err: %v", err)
  212. return
  213. }
  214. }
  215. func main() {
  216. v := make(chan *[]*TxGas, 100)
  217. go Producer(v)
  218. Consumer(v)
  219. }
  220. func RandAddress(prefix string, n int) string {
  221. return prefix + RandomString(n)
  222. }
  223. func RandomString(l int) string {
  224. now := time.Now().Format("060102150405.000")
  225. nowFmt := strings.Replace(now, ".", "", -1)
  226. str := "0123456789abcdefghijklmnopqrstuvwxyz"
  227. bytes := []byte(str)
  228. var result []byte
  229. j := 0
  230. r := rand.New(rand.NewSource(time.Now().UnixNano() + int64(rand.Intn(100))))
  231. for i := 0; i < l; i++ {
  232. if i%2 != 0 && j < len(nowFmt) {
  233. result = append(result, nowFmt[j])
  234. j++
  235. } else {
  236. result = append(result, bytes[r.Intn(len(bytes))])
  237. }
  238. }
  239. return string(result)
  240. }
  241. // RandTime 随机生成近 n 天内的任意某天的时间点
  242. func RandTime(n int64) time.Time {
  243. start := time.Now().Add(-time.Hour * 24 * time.Duration(n))
  244. rand.Seed(time.Now().UnixNano())
  245. hours := n * 24
  246. return start.Add(time.Duration(rand.Intn(int(hours))) * time.Hour)
  247. }