package main

import (
"os"
"errors"
"math/rand"
"time"
"log"
"strconv"
) func init() {
rand.Seed(time.Now().Unix())
file := "/www/logs/test.log";
logFile, err := os.OpenFile(file, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0766)
if err != nil {
panic(err)
}
log.SetOutput(logFile) // 将文件设置为log输出的文件
log.SetPrefix("[elk-test]")
log.SetFlags(log.LstdFlags | log.Lshortfile | log.LUTC)
} func main() { for {
go func() {
strs := []string{"浏览页面", "评论商品", "加入收藏", "加入购物车", "提交订单", "使用优惠券", "领取优惠券", "搜索", "查看订单"} a, _ := Random(strs, 1) now := time.Now()
date := now.Format("2006-01-02 15:04:05") userId := rand.Intn(10000) result := "brady|" +strconv.Itoa(userId+1) + "|" + a + "|" + date; log.Println(result) // log 还是可以作为输出的前缀
}() time.Sleep(1*time.Second)
} } func Random(strings []string, length int) (string, error) {
if len(strings) <= 0 {
return "", errors.New("the length of the parameter strings should not be less than 0")
} if length <= 0 || len(strings) <= length {
return "", errors.New("the size of the parameter length illegal")
} for i := len(strings) - 1; i > 0; i-- {
num := rand.Intn(i + 1)
strings[i], strings[num] = strings[num], strings[i]
} str := ""
for i := 0; i < length; i++ {
str += strings[i]
}
return str, nil
}

  

结果

p.p1 { margin: 0; font: 11px Menlo; color: rgba(0, 0, 0, 1); background-color: rgba(255, 255, 255, 1) }
span.s1 { font-variant-ligatures: no-common-ligatures }

[elk-test]2020/07/05 01:10:22 main.go:42: brady|1203|加入收藏|2020-07-05 09:10:22

[elk-test]2020/07/05 01:10:23 main.go:42: brady|6144|领取优惠券|2020-07-05 09:10:23

[elk-test]2020/07/05 01:10:24 main.go:42: brady|7903|提交订单|2020-07-05 09:10:24

[elk-test]2020/07/05 01:10:25 main.go:42: brady|9768|领取优惠券|2020-07-05 09:10:25

[elk-test]2020/07/05 01:10:26 main.go:42: brady|6031|查看订单|2020-07-05 09:10:26

[elk-test]2020/07/05 01:10:27 main.go:42: brady|7422|评论商品|2020-07-05 09:10:27

[elk-test]2020/07/05 01:10:28 main.go:42: brady|497|查看订单|2020-07-05 09:10:28

[elk-test]2020/07/05 01:10:29 main.go:42: brady|6295|搜索|2020-07-05 09:10:29

[elk-test]2020/07/05 01:10:30 main.go:42: brady|7660|搜索|2020-07-05 09:10:30

[elk-test]2020/07/05 01:10:31 main.go:42: brady|1622|加入购物车|2020-07-05 09:10:31

[elk-test]2020/07/05 01:10:32 main.go:4

最新文章

  1. 关于开放式CNC系统实时软件控制系统的一些简单分析
  2. js实现对移动设备的检测
  3. Python——Day3知识点——文件操作
  4. 在CentOS中将/var等已有目录挂载到新添加的硬盘
  5. C#中如何定义全局变量及在各窗体中使用全局变量
  6. Android 蹲坑的疑难杂症集锦一
  7. PHP获取今天、昨天、明天的日期
  8. 通过虚拟机VMware来练习安装ESXi
  9. JS面向对象思想(OOP)
  10. C# 哈希表的实现
  11. 【HDOJ】1688 Sightseeing
  12. JAVA基于AE调用GP实现泰森多边形
  13. c#的as关键字
  14. css 定位功能position
  15. js 选择图片生成base64数据
  16. django项目外部的脚本文件执行ORM操作,无需配置路由、视图启动django服务
  17. 【代码笔记】Web-CSS-CSS Display
  18. PHP-不同Str 拼接方法性能对比 参考自https://www.cnblogs.com/xiaoerli520/p/9624309.html
  19. rails 杂记 - model 中的exists?
  20. 开源HIS之C/S选型

热门文章

  1. NetCore微服务实战体系:日志管理
  2. liunx配置本地yum源和更新aliyun yum源
  3. memcached缓存:安装和清缓存
  4. 最全总结 | 聊聊 Python 数据处理全家桶(Mysql 篇)
  5. nginx实战(1):宝塔设置反向代理
  6. Redis学习(四)redis发布订阅
  7. Magicodes.IE之导入导出筛选器
  8. PYG5.4第十六期第一轮基础六题
  9. 关于button和submit的form提交以及 页面跳转问题
  10. Vue mustache语法