【rust-grpc-proxy】自定义metadata

前言

没有废话

原理

grpc可以通过metadata(元数据)实现类似http header的效果。
grpc底层使用http2通讯,而metadata通常会放在http2的header中传输,这也是本文支持的方式。
trailer 方式也能传输metadata,但我不常用,且处理较为麻烦,如无必要,则不支持。(绝对不承认自己懒)

实践

目标服务

首先修改一下我们之前的echo服务,增加一个拦截器,会将我们设置的metadata回显回来。

func metadataInterceptor() grpc.UnaryServerInterceptor {
	return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) {
		md, ok := metadata.FromIncomingContext(ctx)
		header := metadata.New(map[string]string{})
		if ok {
			for k, v := range md {
				if k == "content-type" || k == "content-length" {
					continue
				}
				header.Set(k, v[0])
			}
		}
		resp, err = handler(ctx, req)
		if err != nil {
			return nil, err
		}
		err = grpc.SetHeader(ctx, header)
		return resp, err
	}
}

将上面的代码加入到任何带有反射的grpc服务中,或者用项目中的测试程序目录是:example/metadata/server 环境需要mac才行

cd example/metadata

//会启动一个目标服务,并监听1234端口
./example.sh server

生成配置

运行命令生成配置

//example/metadata
./example.sh config 

可以看到配置中的内容

[metadata_filters]
prefix = ["echo-","greet-"]
match = ["use-name","use-id"]
  • prefix 前缀匹配,配置为空则默认["md-"]
  • match 完全匹配

运行程序

用如下命令运行代理

//mac系统 dir:example/metadata
./rust-grpc-proxy run -c config.toml

//或者在根目录运行
cargo run -- run -c ./example/metadata/config.toml

测试请求

curl --location --request GET 'http://127.0.0.1:6789/api/v1/echo/hello/get?query=666' \
--header 'echo-hello: world' \
--header 'md-hello: md-world' \
--header 'use-name: mynameiswd'

可以在response 的header看到 回显内容。表明测试成功

尾语

目前基础功能已经完成的差不了。根据计划,之后会完善使用体验上的内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要配置rust-analyzer的代码提示,你可以按照以下步骤进行操作: 1. 确保已经在你的项目中安装了rust-analyzer插件。你可以在VSCode的插件市场中搜索并安装"rust-analyzer"插件。 2. 打开VSCode的设置(可以通过菜单栏的"文件" -> "首选项" -> "设置"或者使用快捷键Ctrl + ,打开设置)。 3. 在设置页面的搜索框中输入"rust-analyzer",找到相关的设置选项。 4. 根据你的需求,配置下列常用的代码提示相关的设置: - "rust-analyzer.enable": 设置为true以启用rust-analyzer插件。 - "rust-analyzer.completion.enable": 设置为true以启用代码补全功能。 - "rust-analyzer.completion.addCallArgumentSnippets": 设置为true以自动添加函数调用时的参数提示。 - "rust-analyzer.completion.addCallParenthesis": 设置为true以自动添加函数调用时的括号。 - "rust-analyzer.completion.postfix.enable": 设置为true以启用后缀代码补全功能,例如`.if`、`.let`等。 - "rust-analyzer.hover.enable": 设置为true以启用悬停提示功能。 - "rust-analyzer.inlayHints.enable": 设置为true以启用内联提示功能。 5. 根据你的需求,可以进一步自定义配置rust-analyzer的代码提示行为。你可以在设置中找到更多相关的选项,并根据注释进行配置。 6. 保存设置,并重启VSCode使更改生效。 通过以上步骤,你可以根据自己的喜好和需求来配置rust-analyzer的代码提示功能。请注意,具体的配置选项可能会因rust-analyzer插件版本的不同而有所差异,请参考插件的官方文档或参考其它资源获取更多定制化的配置信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值