返回介绍

代码

调试技术

数据库

前端

GOLANG

JAVA

网络

心理学

PYTHON

创业

UNIX/LINUX

分布式

系统设计

搜索引擎

开发工具

思维

源码

网站架构微服务

软件工程/项目管理

运维

金融理财

写作

互联网

区块链

技术演讲网课

职场

《哔哩哔哩的go微服务实战》

发布于 2023-09-17 00:26:21 字数 1686 浏览 0 评论 0 收藏 0

微服务演进

巨石架构:部署难;升级痛苦

步骤:

  • 梳理业务边界。
    • 拆分服务,周边业务(观看历史,收藏)。
    • 保持 API 兼容
    • 让相关方迁移,请人家吃烧烤

业务

  • 资源隔离部署
    • 不要和老代码一同部署
  • 内外网服务隔离
  • RPC框架(基于netrpc改造,加上context/超时)
    • 序列化(GOB)。语言统一
    • 上下文管理(超时控制)。一堵就挂掉
    • 拦截器(鉴权,统计,限流)
    • 服务注册(zookeeper)
    • 负载均衡(客户端)
  • API Gateway
    • 统一&聚合协议
    • errgroup 并行调用
    • 业务隔离
    • 熔断,降级,限流等高可用

高可用

  • 隔离

  • 超时

  • 限流

  • 降级

  • 容错(netflix java 代码改写)

中间件

  • databus (基于kafka)
  • canal (mysql replication)
  • bilitw (基于 twemproxy)
  • bfs (facebook haystack, opencv)
  • config-service
  • dapper (google dapper)

持续集成和交付

  • 语义化版本控制
  • 微服务

运维体系

内容:

  • https://www.youtube.com/watch?v=wC-EIYJw4nk

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文