-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issues with NEST 7. “The stream with Id and Tag is disposed." #4168
Comments
After switching to .net core 2.2 I can't reproduce the issue. |
That's good to hear @andrx. Would still liked to dig into this but it's unlikely to be this week |
If switching to netcore 2.2 has solved this, I'm going to close this issue. You may want to move to netcore 3.0 or 3.1, now that 2.2 is coming to EOL on December 23, 2019 👍 |
We did update those to .net core 3. No issues. Thank you! |
Hello, @andrx the issue is gone when you updated to .net core 3 and it did not appear again? I got exactly what you described here, but I'm using .netcore3.1. But in my case stream Id is bit odd:
This is my set up: NEST/Elasticsearch.Net version: NEST 7.7.0 / Elasticsearch.Net 7.7.0 running on centos 7 Elasticsearch version: 7.7.0 (running in docker) |
Hey @kuleshov-aleksei I checked what we have currently. It's NEST 7.5.1 running against ES 7.9.1 all running on vms centos7. Fortunately or unfortunately :) we haven't had enough time for refactoring these apps and decided to switch to .net 5 once it's ready. so the apps are still on .net 3.0. Been running without any issue so far. I think your case is unrelated to libcurl because .net core 3+ doesn't use it. newer apps we've built handle less traffic than the use case started this issue but they run on latest .net core 3.1 on debian on k8s. also no issues. Share your stack trace. It should lead to the answer |
Hmm.. This is strange because, I have CurlResponseStream too: In my case I do not execute search request, only update.
Maybe this case does not relate to elasticsearch, but it is some problem with libcurl in centos-7? |
Maybe you have or wrong dotnet version it's built or running with? check dotnet version inside the container |
Oh, yeah, I will try to set Thank you! |
@kuleshov-aleksei good luck |
Initially asked question here but as mentioned would be better to track it on github.
NEST/Elasticsearch.Net version:
7.3.1 .net core 2.0 on centos7
Elasticsearch version:
7.3.2 basic on centos7
Description of the problem including expected versus actual behavior:
After update to Nest7 (basically nuget, no other changes) occasionally getting this error for a process that usually runs for 15 minutes.
Sometimes it happens during updating documents by id, sometimes bulk operations.
The problem disappeared when I turned off parallel processing ParallelOptions { MaxDegreeOfParallelism = 1 } so, basically lowered the load.
Have never had the issue with Nest6. IElasticClient is registered as singleton via DI.
The client talks directly to ES by IPs set in StaticConnectionPool
without DisableDirectStreaming() stacktrace looks a bit different:
Both exceptions led me here and here.
Seems a problem related to CurlResponseStream and libcurl.
That's what i see on the box:
As @russcam mentioned Nest6 as well as Nest7 (.net core >=2.1) uses SocketsHttpHandler.
Checked if
UseSocketsHttpHandler
is set tofalse
. It's not.Currently checking if the app converted to .net core 2.2 + updated libs on AMI will fix the problem.
Will let you know.
Steps to reproduce:
short/simplified example looks like this
let me know if you need better example. I'll try to get something even closer if this is not enough.
Some numbers according to logs during stress tests:
If this process runs for two hours it can fetch 3,712,029 documents from ES and around 95% of them will be sent for bulk update.
Max response size (300 docs) for this loader is about 6MB.
Two other loaders that have the same structure also get exception on Search. but there is one where it happens on Update.
Provide
ConnectionSettings
(if relevant):The text was updated successfully, but these errors were encountered: