nano.Listen(":3250", nano.WithIsWebsocket(true), nano.WithPipeline(pip), nano.WithCheckOriginFunc(func(_ *http.Request) bool {
return true }), nano.WithWSPath("/nano"), nano.WithDebugMode(), nano.WithSerializer(json.NewSerializer()), // override default serializer nano.WithComponents(components), )
实际上Option是个函数类型,
type Option func(*cluster.Options)
由于cluster.Options
暴露在外面,是可以很清楚看到支持哪些选项的.
以下是刨根问底:
Listen只是简单地将将opts跑一遍,生成已设置的选项集合
func Listen(addr string, opts ...Option) {
// ... ... opt := cluster.Options{
Components: &component.Components{
}, } for _, option := range opts {
option(&opt) } // ... ... }
而WithXXX函数只是设置了单一的选项,然后返回匿名函数,来给Listen函数生成选项集合。
func WithPipeline(pipeline pipeline.Pipeline) Option {
return func(opt *cluster.Options) {
opt.Pipeline = pipeline } }
今天的文章
观摩一下Nano实现的Options——lonng/nano分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ji-chu/92354.html