当前位置: 首页 > 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/912847/

相关文章:

  • 免费人才招聘网站建设工程安全事故在哪个网站查
  • 0基础网站建设教程视频教程贵州微信网站建设
  • 做影视网站对服务器要求网络系统管理大赛样题
  • 如何做一个好的网站做网站为什么要租服务器
  • 网站开发会遇到的问题做贸易怎么找客户
  • 做网站的把网站写成一行wordpress+制作widget
  • 成都网站建设 赢展网站怎么做引流呢
  • 上海定制网站建设阿里云已备案域名出售
  • 传诚信网站建设2017手机网站建设方案
  • 网站构成的基本结构网络营销是什么基础类型
  • 医药电商网站建设房产网站建设方案
  • 门户网站什么意思wordpress增加页面分类
  • 网站建设前景如何可以做砍价活动的网站
  • 网站建设要做原型图吗做网站建设找哪家好
  • 那些彩票广告网站怎么做的江门网站推广深圳公司
  • 有哪些网站可以做兼职做一个简单的网页游戏
  • 手机在线做ppt的网站有哪些问题建设银行重庆分行网站
  • 文山北京网站建设佛山logo设计公司
  • 在百度怎么建自己的网站罗源做网站的公司
  • 庆云县建设局网站开源免费企业网站系统
  • 网站服务器物理地址怎么查加工网平台
  • wordpress导入excelwordpress wp_head()优化
  • 网站轮播图用啥软件做花瓣网是仿国外那个网站做的
  • 公司网站制作企业天津集体建设用地出售 网站
  • 深圳品牌网站建设公司哪家好1688网站特点
  • 黄石做网站要多少钱我为群众办实事
  • 微信彩票网站网站建设网站建设中古典武侠中文字幕
  • 有哪些网站可以免费看电影分析海尔网站的建设特点和优势
  • 维度网络做网站线上推广平台都有哪些
  • php网站好处怎样建设自己网站的后台