当前位置: 首页 > news >正文

大安移动网站建设网络游戏推广员

大安移动网站建设,网络游戏推广员,兼职网站建设推广人才,歌曲推广平台有哪些现象 某日,运营反馈,在某个时间区间丢失了一段日志,让看看是什么问题。 排查 查看项目日志有无错误 发现项目日志有报错信息Error 1062 Duplicate entry 149059529550598144 for key PRIMARY,很显然,问题在此,数据库…

现象

某日,运营反馈,在某个时间区间丢失了一段日志,让看看是什么问题。

排查

  1. 查看项目日志有无错误
    发现项目日志有报错信息Error 1062 Duplicate entry '149059529550598144' for key 'PRIMARY',很显然,问题在此,数据库主键冲突,无法插入数据,导致这部分数据被丢弃。那么问题来了,我们使用的雪花算法,为什么会生成重复的ID呢?

进一步排查

  1. 猜想可能早成该问题的原因,可能有两个
    1. 两个项目用了同样的MachineId,然而并没有,我们是单体应用
    2. 时钟回拨,存疑,需进一步确定,大概率是这个问题

  2. 进一步查看代码,bwmarrin/snowflake库的生成方法

// Generate creates and returns a unique snowflake ID
// To help guarantee uniqueness
// - Make sure your system is keeping accurate system time
// - Make sure you never have multiple nodes running with the same node ID
func (n *Node) Generate() ID {n.mu.Lock()now := time.Since(n.epoch).Nanoseconds() / 1000000if now == n.time {n.step = (n.step + 1) & n.stepMaskif n.step == 0 {for now <= n.time {now = time.Since(n.epoch).Nanoseconds() / 1000000}}} else {n.step = 0}n.time = nowr := ID((now)<<n.timeShift |(n.node << n.nodeShift) |(n.step),)n.mu.Unlock()return r
}

可以看出确实没对 now <n.time做判定,而且方法的注释中有说明Make sure your system is keeping accurate system time要自己保障系统时间的准确性。
3. 进一步找运营确认情况,运营老哥说问题是自两天前才有的,想想两天前我对服务器做了什么。两天前我把项目的容器内编译,改为了本地编译,采用挂载时区的方式来设置时区。

FROM golang:1.16 as builder
ENV GO111MODULE=on \CGO_ENABLED=0 \GOOS=linux \GOARCH=amd64 \GOPROXY=https://goproxy.cn,direct
WORKDIR /go/release
COPY go.mod .
COPY go.sum .
RUN go mod download
RUN go build -ldflags="-s -w" -installsuffix cgo -o serve .
FROM scratch as prod
COPY --from=builder /usr/share/zoneinfo /usr/share/zoneinfo
ENV TZ=Asia/Shanghai
COPY --from=builder /go/release/* ./
CMD ["/serve"]//以上每次部署需要3分钟左右,我觉得太慢,改为宿主机执行go build 然后直接把二进制镜像丢给scratch镜像
FROM scratch
ENV TZ=Asia/Shanghai
COPY . /
CMD ["/serve"]
//启动容器时挂载时区
docker run -p 8080:8080 -v /usr/share/zoneinfo:/usr/share/zoneinfo:ro -d test:v1.0.0

但是我没想到的是,宿主机会通过NTP对时间进行矫正,每次矫正,都会造成时钟回拨,生成的ID重复。

解决方案

让容器读自己的时区信息

FROM alpine:latest as base
RUN echo "https://mirrors.aliyun.com/alpine/v3.8/main/" > /etc/apk/repositories \&& echo "https://mirrors.aliyun.com/alpine/v3.8/community/" >> /etc/apk/repositories \&& apk add --no-cache tzdata \&& cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime  \&& echo Asia/Shanghai > /etc/timezone
FROM scratch
COPY --from=base /usr/share/zoneinfo /usr/share/zoneinfo
ENV TZ=Asia/Shanghai
COPY . /
CMD ["/serve"]
http://www.yayakq.cn/news/358832/

相关文章:

  • 网站开发 图片存放加工平台有哪些设备
  • 安卓优化大师下载安装到手机上海建站 seo
  • 建设银行网站的服务管理wordpress忘记管理员密码
  • 关于网站建设营销类文章yanderedev wordpress
  • 布吉网站建设哪家技术好化妆品公司网站模板
  • 石泉县城乡建设局网站wordpress数据库域名
  • 丹阳网站织梦末班和dw建设网站哪个方便优化
  • 做期货应关注什么网站网页设计师岗位分析
  • WordPress交互式网站c 网站开发数据库
  • 百度网站检测wordpress个人中心无法登录
  • 济宁网站建设制作设计建设项目竣工验收网站
  • 邵阳网站建设网站muse做网站
  • 做网站运营经理的要求网站免费正能量直接进入
  • 建网站的网络公司的名称以及服务通州微网站优化
  • 上海网站制作机构泰安招聘信息最新招聘2023
  • 高新西区网站建设水滴保险官方网站
  • 实例网站制作教程作文网下载
  • 网站模板文件在哪里下载网站开发人员 工资
  • 网站空间与服务器中山软件开发项目管理
  • 网站建设基础筹备网站优化 seo和sem
  • 能看网站的视频app百度seo营销
  • 坂田网站建设方案公司网站域名及空间
  • 企业网站排名提升软件智能优化汕头推广公司
  • 人事代理网站建设网站推广的方式有哪些
  • h5响应式网站是什么建设工程竣工规划局网站
  • 网站如何设置默认首页wordpress修改标签
  • wordpress两个网站同步wordpress多用户小程序商城
  • 龙岩建设局网站厦门企业建网站制作
  • 网站设计的评估什么是seo优化
  • 怎么做网站子页如何在百度上营销