当前位置: 首页 > 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.15wanjia.com/news/28372.html

相关文章:

  • 现代网站开发建设全网seo优化电话
  • 装修网站建设优缺点搜索引擎优化规则
  • 龙岩app定制南宁seo手段
  • 建设工程管理是干嘛的温州企业网站排名优化
  • 怎么用joomla做网站网站建设多少钱
  • 深圳疫情今天最新消息seo服务方案
  • 东莞网站建设 石佳四川seo快速排名
  • 谷歌做网站推广成都网站设计公司
  • 茂港网站设计公司可靠的网站优化
  • php购物网站开发设计网站排名推广软件
  • 做网站商城如何优化网络营销与策划实践报告
  • 个人网站设计论文摘要nba最新排行
  • 做网站方案seo资讯网
  • 汕头 做网站windows优化大师值得买吗
  • 网站开发与管理对应的职业及岗位微博营销软件
  • wordpress 死链检测企业seo排名
  • 护士公共课在哪个网站做西安seo服务公司
  • 内部网站 建设方案某企业网站的分析优化与推广
  • 靠网络营销火起来的企业优化大师怎么删除学生
  • 买的网站模板会影响搜狗推广登录平台
  • 西宁网站制作多少钱产品推广广告
  • wordpress 无法置顶惠州seo计费
  • 专门做恐怖电影网站百度学术免费查重入口
  • 外留网站建设网上营销是干什么的
  • wordpress标签云插件专业网站优化推广
  • 网络网站建网站统计
  • 模板企业快速建站软文文章
  • 做网站跟客人怎么沟通提高工作效率总结心得
  • 三明做网站的公司服务营销策略
  • 唐山建设网站网站网络推广的平台