influxdb内存过大和占用过多端口

2 篇文章 0 订阅
2 篇文章 0 订阅

1、influxdb占用内存过多
主要是索引方式导致的,直接使用tsi1即可,如下配置可解决此问题

    ## 禁用向官方报告
    reporting-disabled = true
    [meta]
      dir = "/var/lib/influxdb/meta"
    [data]
      dir = "/var/lib/influxdb/data"
      ## 设置索引版本
      index-version = "tsi1"
      engine = "tsm1"
      trace-logging-enabled = false
      wal-dir = "/var/lib/influxdb/wal"
    [monitor]
      store-enabled = false
    [http]
      flux-enabled = true
      log-enabled = false

2、通过客户端“github.com/influxdata/influxdb/client/v2”访问服务端会导致服务端端口占用过多
这个主要是每次调用后服务端链接会进入wati_timeout状态而不是直接关闭,所以时间长后会导致无法访问服务端。此时在client.go中添加3行代码,如下所示

	tr := &http.Transport{
		TLSClientConfig: &tls.Config{
			InsecureSkipVerify: conf.InsecureSkipVerify,
		},
		Proxy:               conf.Proxy,
		DialContext:         conf.DialContext,
		IdleConnTimeout:     conf.IdleConnTimeout,	// 设置空闲链接超时
		MaxIdleConns:        conf.MaxIdleConns,		// 设置最大idle连接数
		MaxIdleConnsPerHost: conf.MaxIdleConnsPerHost,// 设置最大idle连接数
	}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 完成端口(IOCP)是一种用于性能和可伸缩网络应用程序的输入输出(IO)模型。完成端口基于事件驱动模型,能够处理大量并发连接,因此将Socket设置为异步是必要的。 异步Socket指的是通过异步操作来执行Socket通信,即发送和接收数据不会阻塞主线程,而是通过回调函数或事件处理程序来通知主线程数据的到达或发送的完成。 设置Socket为异步的好处有如下几点: 1. 提性能:异步Socket允许应用程序在等待数据到达时执行其他操作,而不是被一次阻塞。这样可以充分利用系统资源,并提网络应用程序的吞吐量和并发处理能力。 2. 增加可伸缩性:异步Socket允许处理大量并发连接而无需为每个连接创建一个线程。相比之下,同步Socket需要为每个连接创建一个线程,当并发连接数增加时,线程数量会呈指数级增长,导致系统资源消耗过大和性能下降。 3. 简化编程模型:异步Socket能够通过回调函数或事件处理程序来处理数据到达或发送完成的通知,这样可以简化编程模型,避免了繁琐的线程管理和同步机制。 总之,为了充分利用完成端口性能和可伸缩性特点,我们需要将Socket设置为异步。这样可以提网络应用程序的性能、并发处理能力和可伸缩性,同时简化编程模型,使得应用程序更加效和稳定。 ### 回答2: 完成端口(Completion Port)是一种在Windows平台上实现异步IO操作的机制。在使用完成端口时,可以使用异步套接字(Asynchronous Socket)来实现异步通信。 异步套接字是将套接字操作请求发送给操作系统后立即返回,而不等待操作完成的一种套接字编程方式。相比于同步套接字,异步套接字能够极大地提系统的并发性能和响应速度。 完成端口是完成套接字IO操作的一种机制,在异步通信中扮演着重要的角色。完成端口通过绑定到IOCP对象(IO Completion Port)上将套接字操作请求提交给操作系统进行处理。当套接字操作完成后,操作系统将通过调用注册的回调函数通知应用程序,从而实现套接字的异步操作。 设置套接字为异步模式,需要调用相关的API函数,如WSAIoctl或WSAEventSelect,并指定一个完成端口来处理套接字的异步操作。这样一来,套接字的读、写、连接等操作就可以在后台进行,而不会对主线程造成阻塞。同时,完成端口还允许应用程序同时处理多个套接字的异步操作,有效地提系统的吞吐量和并发性能。 总之,完成端口是一种能够实现异步套接字IO操作的机制,在并发性能和响应速度方面具有明显的优势。通过设置套接字为异步模式,并将其与完成端口绑定,可以实现套接字的异步操作,提升系统的性能和可扩展性。 ### 回答3: 完成端口(Completion Port)是一种多线程消息处理模式,常用于效地处理大量并发的I/O操作。而在完成端口中,socket通信可以设置为异步操作。 在Socket通信中,传统上的阻塞式方式会导致一个线程一直等待I/O操作完成,无法同时执行其它任务,效率较低。而异步操作可以将I/O请求提交给操作系统后就立即返回,不需要等待操作完成。这样可以在等待数据传输的同时继续处理其他任务,提系统的并发性能。 设置Socket为异步操作需要使用特定的函数和参数来完成。首先,通过调用CreateIoCompletionPort函数创建一个完成端口对象,并将Socket的句柄与其关联。然后,使用WSAIoctl或WSAEventSelect函数将Socket设置为非阻塞模式。接下来,使用专门的异步I/O函数(如WSASend、WSARecv)来发起异步操作,操作完成后会以消息的形式通知完成端口对象。可以通过GetQueuedCompletionStatus函数从完成端口中获取已完成的异步操作,并进行相应的处理。 异步Socket通信的优点是能够提系统的并发性能,充分利用多核处理器的能力,并且能够更好地处理突发的大量请求。但是需要注意的是,异步编程相对于同步编程更为复杂,需要合理地管理资源和处理回调,以避免出现竞态条件、内存泄漏等问题。 总之,完成端口Socket通过设置为异步操作可以提系统的并发性能,在处理大量并发的I/O操作时更为效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值