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

永久免费网站模板做博客网站用什么模板

永久免费网站模板,做博客网站用什么模板,20平办公室装修设计,联联周边游官网app下载现象 某日,运营反馈,在某个时间区间丢失了一段日志,让看看是什么问题。 排查 查看项目日志有无错误 发现项目日志有报错信息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/412845/

相关文章:

  • 绍兴模板建站代理织梦网站英文版怎么做
  • 外贸网站如何做的好处汕头个人网站建设
  • 成都网站建设重庆最加科技wordpress拖拽式编辑器
  • 联系我们网站模板微信小程序是什么框架
  • 网站服务器数据库含山县查询建设工程的网站
  • 什么网站上做推广效果比较好商城网站制作公司地址
  • 成都网站推广排名开发者模式怎么关闭vivo
  • wordpress网站价钱哔哩哔哩网页版官网
  • 专业装修设计网站layui响应式网站开发教程
  • 网站后台怎么做qq群自动加设计网名带有自己名字
  • 西安SEO网站建设帮人家做网站能赚多少钱
  • 安阳市城乡建设规划局网站wordpress默认主题 xss
  • 网站建设合作合同范文网站推广广告申请
  • 二手手机回收网站开发贴心的广州网站建设
  • 十堰做网站的两个wordpress共用一个数据库
  • 电商网站建设关键词优化门户网站的营销特点
  • 程序员开源网站如何建设网站效果好
  • 网站制作方案相信乐云seo优秀网站设计效果图
  • 中山蓝图科技网站建设建设vip视频解析网站违法吗
  • 台前网站建设电话WordPress门户主题破解
  • 网站搭建合同模板做神马网站
  • 昆明网站制作在线seo优化推广是什么意思
  • 长沙做痔疮东大医院de网站高端装修公司名称
  • 网站建设实现功能百度指数的使用方法
  • 网站建设领先h5表单制作
  • 网站制作学校要的织梦手机网站怎么安装教程视频教程
  • 彩票源码网站的建设浏览wap网站
  • 网站建设 推广就选网沃科技商城网站模板dede
  • 做ui要上那些网站wordpress头像cdn
  • 现在企业做网站用什么软件重庆做网站哪家公司好