RT, Go 服务如何部署到线上环境,包括如何发布、回滚。
我先说说我知道的
前提:会对 go 应用进行打 tag
方案一:
1 、把 go 应用要上线的 release tag 打包成 docker 镜像 2 、然后在 k8s 进行部署, 回滚的话直接回滚到上一个 tag 3 、域名直接解析到 k8s 的 ingress 解析到对应的 service 中,服务也可以 HPA 动态扩容
方案二:
1 、直接把 go 的二进制文件+配置文件 放到对应的线上的机器上,如果是多台就部署到多台服务器
2 、前面加一层 nginx ,然后通过 proxy_pass + upstream
解析到对应的 go 服务器上
3 、域名直接解析到 nginx 即可。
想知道除了这两种方式,还有什么方式?
相比而言,你认为哪种方式更好?
欢迎大家畅所欲言
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.