You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
kratos/doc/wiki-cn/blademaster-quickstart.md

1.8 KiB

准备工作

推荐使用kratos tool快速生成项目,如我们生成一个叫kratos-demo的项目。

生成目录结构如下:

├── CHANGELOG.md
├── CONTRIBUTORS.md
├── LICENSE
├── README.md
├── cmd
│   ├── cmd
│   └── main.go
├── configs
│   ├── application.toml
│   ├── grpc.toml
│   ├── http.toml
│   ├── log.toml
│   ├── memcache.toml
│   ├── mysql.toml
│   └── redis.toml
├── go.mod
├── go.sum
└── internal
    ├── dao
    │   └── dao.go
    ├── model
    │   └── model.go
    ├── server
    │   └── http
    │       └── http.go
    └── service
        └── service.go

路由

创建项目成功后,进入internal/server/http目录下,打开http.go文件,其中有默认生成的blademaster模板。其中:

engine = bm.DefaultServer(hc.Server)
initRouter(engine)
if err := engine.Start(); err != nil {
    panic(err)
}

是bm默认创建的engine及启动代码,我们看initRouter初始化路由方法,默认实现了:

func initRouter(e *bm.Engine) {
	e.Ping(ping) // engine自带的"/ping"接口,用于负载均衡检测服务健康状态
	g := e.Group("/kratos-demo") // e.Group 创建一组 "/kratos-demo" 起始的路由组
	{
		g.GET("/start", howToStart) // g.GET 创建一个 "kratos-demo/start" 的路由,默认处理Handler为howToStart方法
	}
}

bm的handler方法,结构如下:

func howToStart(c *bm.Context) // handler方法默认传入bm的Context对象

扩展阅读

bm模块说明 bm中间件 bm基于pb生成


文档目录树