脚本宝典收集整理的这篇文章主要介绍了带你十天轻松搞定 Go 微服务系列(七),脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我们通过一个系列文章跟大家详细展示一个 go-zero 微服务示例,整个系列分十篇文章,目录结构如下:
期望通过本系列带你在本机利用 Docker 环境利用 go-zero 快速开发一个商城系统,让你快速上手微服务。
完整示例代码:https://github.com/nivin-studio/go-zero-mall
首先,我们来看一下整体的服务拆分图:
在前面几章我们已经分别实现了 user
product
order
pay
的 rpc
服务和 api
服务。在 api
服务中我们使用 go-zero
框架自带的 jwt
实现鉴权验证。那么接下里我们就说说 rpc
服务的 auth
验证。
go-zero
框架 rpc
服务的 auth
验证原理是,客户端访问 rpc
服务需要携带 App
标识以及 Token
值,rpc
服务会从指定的 Redis
服务中验证 App
标识和 Token
值是否正确。所以客户端的 App
标识,Token
值,是需要提前打入 Redis
服务中。
rpc
服务 auth
验证下面我们以 user rpc
服务,和 user api
服务为例,来开启并使用 rpc
服务的 auth
验证
$ cd mall/service/user
user rpc
user.yaml 配置文件$ vim rpc/etc/user.yaml
Name: user.rpc
ListenOn: 0.0.0.0:9000
...
Auth: true # 是否开启 Auth 验证
StrictControl: true # 是否开启严格模式
Redis: # 指定 Redis 服务
Key: rpc:auth:user # 指定 Key 应为 hash 类型
Host: redis:6379
Type: node
Pass:
user api
user.yaml 配置文件$ vim api/etc/user.yaml
Name: User
Host: 0.0.0.0
Port: 8000
...
UserRpc:
App: userapi # App 标识
Token: 6jKNZbEpYGeUMAifz10gOnmoty3TV # Token 值
Etcd:
Hosts:
- etcd:2379
Key: user.rpc
将 App
标识, Token
值写入 Redis
服务
App
标识作为 rpc
指定 key
的 hash key
,Token
值作为 hash key
的值。
$ cd mall/service/user/rpc
$ go run user.go -f etc/user.yaml
Starting rpc server at 127.0.0.1:9000...
$ cd mall/service/user/api
$ go run user.go -f etc/user.yaml
Starting server at 0.0.0.0:8000...
rpc
服务 auth
验证访问 user api
的 login
接口,我们可以看到接口能正常的返回结果值。
那么我们修改,user api
user.yaml 配置文件中的 Token
值再次请求接口试试。
提示:修改 yaml 配置文件需要重启服务才有效
我们可以从返回的结果中看出,rpc
服务报错了,未经认证,拒绝访问。
大家可以自己再尝试修改 user rpc
user.yaml 配置文件中 StrictControl
为 false
看看效果。
https://github.com/zeromicro/go-zero
欢迎使用 go-zero
并 star 支持我们!
关注『微服务实践』公众号并点击 交流群 获取社区群二维码。
以上是脚本宝典为你收集整理的带你十天轻松搞定 Go 微服务系列(七)全部内容,希望文章能够帮你解决带你十天轻松搞定 Go 微服务系列(七)所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。