B站Golang技术栈分析

技术栈技术选型参考链接
RPC基于grpc封装的warden框架, 已开源https://github.com/bilibili/kratos
HTTP框架基于gin封装的blade master框架, 已开源同上
服务注册与发现初期为zk, 后面逐步改为参考Spring Cloud体系Eureka自研的discovery已开源 https://github.com/bilibili/discovery
存储DB, redis, memcache, hbase存储一些用户kv信息和历史流水, 已封装好库 library/database/client库已开源 https://github.com/bilibili/kratos
搜索B站视频, 用户, 历史记录等使用es搜索, 客户端已封装在基础库中 library/database/elastic
小文件存储毛剑个人研发的bfs, 已开源.https://www.toutiao.com/i6272104949560115714/https://github.com/Terry-Mao/bfs
消息队列基于kafka封装的databus
log基于uber的zap封装的日志框架
配置及配置中心支持从环境变量读取配置, 从toml中解析配置, 支持远程配置中心(自研, mysql存储, 本地落地,http协议, long poll, 客户端有更新事件, 类似于携程开源的Apollo)
监控使用开源的prometheus, 框架和库(sql, redis, hbase等)中已预埋计数点和时间统计点, 同时也可以在业务逻辑中打点. library/stat/stat.go
tracetrace似乎是基于agent的方式, 使用unix domain socket进行传送, 框架和库已预埋点. library/net/trace.go
研发流程管理TAPD,  有相关的tapd struct信息

其中RPC, HTTP框架, 数据访问的一些库封装, 包括生成工具, 均以kratos项目在github开源了(https://github.com/bilibili/kratos )Kratos是bilibili开源的一套Go微服务框架,包含大量微服务相关框架及工具)

B站目前使用及封装的中间件的详细介绍在Gopher China 2017 B站的分享有提到原理和使用情况.
https://mp.weixin.qq.com/s/4uA6iE7HC_SAfdIATAdrrA
bfs介绍
https://www.jianshu.com/p/923917220d23
B站运维体系发展
https://myslide.cn/slides/3840

### 回答1: 以下是一个基于 Golang 的开发技术栈案例: 1. Golang 语言 Golang 是 Google 推出的一门编程语言,它具有静态类型、高效性能、垃圾回收等特性,被广泛用于构建高性能、可靠的后端服务。 2. Gin 框架 Gin 是一个轻量级的 Web 框架,它基于 Golang 标准库实现,提供了路由、中间件、模板引擎等功能,可以帮助开发者快速构建 Web 应用。 3. GORM ORM 框架 GORM 是一个基于 Golang 的 ORM 框架,它提供了丰富的查询 API 和关系映射功能,可以让开发者更加方便地操作数据库。 4. Redis 数据库 Redis 是一个高性能的内存键值数据库,它支持多种数据结构和丰富的操作命令,可以用于缓存、消息队列等场景。 5. Docker 容器化技术 Docker 是一种流行的容器化技术,它可以将应用程序及其依赖打包成容器镜像,并在不同的环境中快速部署和运行。 6. Kubernetes 容器编排平台 Kubernetes 是一种开源的容器编排平台,它可以自动化地管理和调度多个容器实例,支持容器的弹性伸缩、容错等功能,可以大大简化应用程序的部署和运维工作。 7. Grafana 监控工具 Grafana 是一个流行的开源监控工具,它支持多种数据源和图表展示方式,可以帮助开发者实时监控应用程序的运行状态,快速发现和解决问题。 以上是一个基于 Golang 的开发技术栈案例,可以用于构建高性能、可靠的后端服务,并实现容器化部署和自动化运维。 ### 回答2: Golang开发技术栈是指用于开发Golang应用程序的技术工具集合。在Golang开发中,常用的技术栈包括以下几个方面: 1. Golang语言:Golang是一种开源的编程语言,具有高效、简洁、并发性强等特点。通过使用Golang语言进行开发,可以快速构建高性能的应用程序。 2. Gin框架:Gin是一个轻量级的Web框架,适用于快速开发RESTful API。借助Gin框架,可以方便地创建路由、中间件,处理HTTP请求和响应等。 3. GORM:GORM是Golang中的ORM(对象关系映射)库,用于处理应用程序与数据库之间的数据映射关系。它提供了简单的API,使得开发者可以通过代码对象操作数据库,而不需要直接编写SQL语句。 4. Redis:Redis是一种开源的内存数据库,用于缓存和存储应用程序的数据。在Golang开发中,可以使用Redis作为缓存层,提高应用程序的性能和响应速度。 5. MySQL:MySQL是一种广泛使用的关系型数据库,用于存储和管理应用程序的数据。Golang开发技术栈中,可以使用MySQL作为主要的持久化存储层。 6. Docker:Docker是一种容器化平台,用于快速部署和管理应用程序。通过使用Docker,可以将应用程序及其依赖的环境打包成容器,并在不同的环境中快速部署和运行。 通过使用以上的Golang开发技术栈,可以快速构建高性能、可扩展和易维护的应用程序。其中,Golang语言提供了高效的编程能力,而Gin框架、GORM、Redis、MySQL和Docker等技术工具则提供了丰富的功能和支持,使得开发者可以更加便捷地进行开发工作。 ### 回答3: Golang是一种快速、高效、并发、可靠的编程语言,它非常适合用于构建大规模、高并发的网络服务。下面是一个关于Golang开发技术栈的案例: 我们公司在构建一个在线购物平台,决定采用Golang作为我们的开发技术栈。以下是我们的技术架构。 1. Web框架:我们选择使用Gin框架作为我们的后端服务框架。Gin是一个轻量级、高性能的Web框架,具有快速路由和中间件支持,能够帮助我们快速地搭建起我们的后端服务。 2. 数据库:我们使用MySQL作为我们的主要数据库存储引擎。Golang提供了许多MySQL的驱动程序,我们选择了go-sql-driver/mysql作为我们的数据库驱动。 3. 缓存:我们使用Redis作为我们的缓存服务。Golang提供了一些很好的Redis客户端库,我们选择了go-redis作为我们的Redis客户端库。 4. 消息队列:我们使用RabbitMQ作为我们的消息队列服务,用于处理我们的高并发消息传递需求。Golang提供了一些很好的RabbitMQ客户端库,我们选择了streadway/amqp作为我们的RabbitMQ客户端库。 5. 身份验证和授权:我们使用JWT(JSON Web Token)作为我们的身份验证和授权机制。Golang提供了一些很好的JWT库,我们选择了dgrijalva/jwt-go作为我们的JWT库。 这个技术栈使得我们能够高效、快速地构建起一个高并发、可靠的在线购物平台。Golang简洁的语法、高效的并发模型以及丰富的开发库,使我们的开发工作变得更加便捷和高效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值