登录
首页 >  Golang >  Go问答

保持与之前部署的 ECS 集群长期连接的 ElasticClient Olivere 包维护

来源:stackoverflow

时间:2024-03-03 11:48:26 385浏览 收藏

一分耕耘,一分收获!既然都打开这篇《保持与之前部署的 ECS 集群长期连接的 ElasticClient Olivere 包维护》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

问题内容

我们目前正在 api 中创建一个 olivere 弹性客户端,如下所示:

2882​​81742411

然后,单实例客户端将用于所有传入的 api 请求。

但是,重新部署新的 elastic 集群后,连接似乎仍然指向旧实例,因为 elasticsearchurl 仅在初始连接中使用了一次。

这会在部署新的弹性集群时产生问题,因为需要新的连接。

使用此库重新连接到新的 elastic search 集群的最佳方式是什么?


解决方案


原因是 golang 默认使用长连接。您可以通过在 transport 中设置 disablekeepalives 来禁用它。

var httpClient = &http.Client{
        Timeout: 60 * time.Second,
        Transport: &http.Transport{
            // Disabel long-live connection
            DisableKeepAlives: true,
            // This is to avoid the time_wait in connections
            MaxIdleConnsPerHost: -1,
        },
    }

elasticClient, err = elastic.NewClient(
            elastic.SetURL(elasticSearchUrl),
            elastic.SetSniff(false),
            elastic.SetHttpClient(httpClient),
        )
   ...

今天关于《保持与之前部署的 ECS 集群长期连接的 ElasticClient Olivere 包维护》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>