This repository has been archived by the owner on Dec 13, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* docs: add example and architecture imgs * docs: add zh-CN support
- Loading branch information
Showing
7 changed files
with
190 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
# tiktok | ||
|
||
[English](../README.md) | 简体中文 | ||
|
||
tiktok 是一个基于HTTP和RPC协议, 分布式架构的简单抖音后端. 它使用到了 Kitex、Hertz、etcd、MySQL、Jaeger、Docker、Thrift、Prometheus、Grafana、Elasticsearch和Kibana | ||
|
||
# 特性 | ||
|
||
- 极度容易的上手和部署 | ||
- 相对完善的持续集成/持续部署工作六 | ||
- 相对高的代码质量 | ||
- 安全性考量 | ||
- 对于接口的性能优化 | ||
|
||
# 架构 | ||
|
||
data:image/s3,"s3://crabby-images/96940/96940b683e52388614cda956372c046b57eab987" alt="architecture" | ||
|
||
# 快速启动 | ||
|
||
我们将介绍如何使用Docker快速启动这个项目, 如果你需要本地构建并运行(Standalone), 请访问: [手动构建(英文)](./start-by-local.md) | ||
|
||
这个项目已经通过脚本大大的简化了流程, 你只需要使用下面这些命令就可以快速拉起环境并以容器化方式运行程序 | ||
|
||
```bash | ||
make env-up # 拉起环境, 可以使用env-down关闭环境 | ||
make docker # 构建docker镜像 | ||
sh docker-run.sh # 启动所有服务 | ||
|
||
# 如果你只是想启动其中一个服务, 指明即可 | ||
sh docker-run.sh api # 或者其他服务 | ||
``` | ||
|
||
之后你可以发送HTTP请求到 `localhost:10001` 来测试接口 | ||
|
||
# 快速部署 | ||
|
||
我们使用完全自动化的流程来简化工作负载, 因此您可以使用我们打包有最新代码的Docker镜像 | ||
|
||
您可以直接复制我们这个项目的`deploy`文件夹到您期望部署的服务器, 这个文件夹结构大致如下 | ||
|
||
```bash | ||
deploy | ||
├── config | ||
│ ├── config.yaml # 基础配置 | ||
│ ├── prometheus.yml # prometheus配置 | ||
│ ├── words.txt # 敏感词文件 | ||
│ └── sql # mysql初始化 | ||
│ ├── init.sql | ||
│ └── user.sql | ||
├── docker-compose.yml # 环境搭建 | ||
└── restart-service.sh # 部署脚本 | ||
``` | ||
|
||
这个脚本会自动从阿里云ACR中拉取最新的镜像,查找并删除正在运行的容器,并使用最新的镜像重新运行它们。 | ||
|
||
如果您需要有关如何使用它的具体教程,请访问: [部署文档(英文)](../deploy/README.md) | ||
|
||
# 项目结构 | ||
|
||
## 整体 | ||
```bash | ||
. | ||
├── Dockerfile | ||
├── LICENSE | ||
├── Makefile # 一些有用的命令 | ||
├── README.md | ||
├── cmd # 微服务 | ||
├── config # 配置 | ||
├── deploy # 部署 | ||
├── docker-compose.ci.yml # 用于持续集成环境部署 | ||
├── docker-compose.yml | ||
├── docker-run.sh # 用于本地启动docker容器 | ||
├── docs | ||
├── go.mod | ||
├── go.sum | ||
├── idl # 接口定义 | ||
├── kitex_gen | ||
├── pkg | ||
│ ├── constants # 存储一些常量 | ||
│ ├── errno # 定制化错误 | ||
│ ├── middleware # 常用的中间件 | ||
│ ├── tracer # 链路追踪 | ||
│ └── utils # 有用的功能 | ||
└── test | ||
``` | ||
|
||
## 网关/API模块 | ||
|
||
```bash | ||
. | ||
├── Makefile | ||
├── biz | ||
│ ├── handler # 请求处理、包装返回数据 | ||
│ ├── middleware | ||
│ ├── model | ||
│ ├── pack # 打包 | ||
│ ├── router # 路由 | ||
│ └── rpc # 发送RPC请求 | ||
├── build.sh | ||
├── main.go | ||
├── output # 二进制文件 | ||
├── router.go | ||
├── router_gen.go | ||
└── script | ||
``` | ||
|
||
## 微服务 | ||
```bash | ||
. | ||
├── Makefile # 有用的命令 | ||
├── build.sh # 构建脚本 | ||
├── dal | ||
│ ├── cache # redis | ||
│ ├── db # MySQL | ||
│ └── mq # RabbitMQ | ||
├── handler.go | ||
├── kitex_info.yaml | ||
├── main.go | ||
├── output # 构建好的二进制文件 | ||
├── pack # 打包返回数据 | ||
├── rpc # 给其他RPC服务发送请求 | ||
├── script | ||
├── coverage # 覆盖率测试结果(部分没有) | ||
└── service | ||
``` | ||
|
||
|
||
# 测试 | ||
|
||
你可以把 `.postman/tiktok.openapi.json` 丢到Postman中然后开始测试 | ||
|
||
# 可视化样例 | ||
|
||
## Jaeger | ||
|
||
data:image/s3,"s3://crabby-images/99d13/99d13b0c9a830510a557c770dedda9a2301c6db4" alt="jaeger" | ||
data:image/s3,"s3://crabby-images/2cdb5/2cdb5680a695bd003aa1b2d1af32b9d0fc5de754" alt="jaeger-dag" | ||
|
||
## Kibana + Elasticsearch | ||
data:image/s3,"s3://crabby-images/e3b60/e3b60d7f9cf35e6eccd51df202db048342ca2a54" alt="kibana" | ||
|
||
## Grafana + Prometheus | ||
data:image/s3,"s3://crabby-images/692dc/692dc1f4cf353ce018808a38624c93c9c2402e64" alt="grafana" | ||
|
||
|
||
# 贡献者 | ||
|
||
福州大学西二在线工作室golang团队 | ||
|
||
- [ozline](https://github.com/ozline) | ||
- [XZ0730](https://github.com/XZ0730) | ||
- [wushiling50](https://github.com/wushiling50) | ||
- [jiuxia211](https://github.com/jiuxia211) | ||
- [notacommonperson](https://github.com/notacommonperson) | ||
- [jkskj](https://github.com/jkskj) |