-
Notifications
You must be signed in to change notification settings - Fork 204
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
sftp.put hangs after creating the file #247
Comments
I don't think it is the same issue as the one identified with
fastPut/fastGet, but cannot guarantee that for certain.
Can you downgrade to latest v12 of node and see if the issue persists?
If it doesn't, then either it is the same issue or something similar
peculiar to v14.
Until the identified issues with fastPut/fastGet are resolved when using
v14 of node, I would avoid using it. The node v14 change log states
there have been some fundamental changes to some of the stream APIs and
I am not confident there are not issues which still need to be resolved
in that version.
|
Thanks for your response @theophilusx |
Hi @theophilusx I'll be conducting more tests tomorrow with Node 14.0 & upward to see if the issue is indeed introduced by v14.1 as reported in the other issue. |
That is beginning to sound like it might be related to the same issue as
for fastPut/fastGet.
You might find some of the scripts in the example directory of the git
repo useful. These scripts only use the underlying ssh2 and ssh2-streams
libraries. If you are able to reproduce the issue just using ssh2 and
ssh2-streams, then it means the issue is in those upstream modules and
needs to be addressed there.
|
I can confirm this is working on v14.0.0 and not on v14.1.0 with a big enough file. |
I've also been able to reproduce the behavior with both On Node >= 14.1 |
OK, thanks. That looks like it is most likely related to the previously
identified issue with the upstream dependency on ssh2/ssh2-streams. What
we need now is a minimal test case which only uses those dependencies
(no ssh2-sftp-client) and then log an issue with the upstream developer.
I should be able to find time to put together a test script before the
end of the week. However, if I do, it would be great if you can log the
issue as I'm hoping if another issue is logged by someone else, it might
gain some more traction (does not seem to have been much action on my
original issue).
I'll let you know when I've done the test script and uploaded it.
|
I have added the script tools/lowlevel-put.js which does a 'put' of a
file to a remote server just using ssh2. I was unable to reproduce any
errors with any node version using this script. It uses a stream to read
the source file and pipe to send it to a remote stream (how
ssh2-sft-client does it). The script expects to command line arguments,
a path to a local source file and the remote path to upload the file to
(including filename). I tested with small and large files (e.g. 500Mb).
I also tested on two different servers with different sftp server
configurations.
I'll create another script which uses a buffer rather than a read stream
as the source to eliminate that as the problem.
|
OK, added the script tools/lowlevel-buffer-put.js, which generates a
buffer of requested size and puts it up to the remote server. This time,
I was able to reproduce the issue using just the ssh2/ssh2-streams libs.
The issue is intermittent - so running the script with the same
parameters can work a couple of times and then fails. (hangs with 0 byte
file on server). The script expects 2 params - size (number of kbytes)
and destination file path.
Will see if I can dig further and will try different ways of handling
the buffer to see if that makes a difference. Seems the problem is
specific to using a buffer for input. Could not reproduce it using a
stream.
|
Hi @theophilusx
while running v14.7.0
The difference being the |
Good work. I was going to do essentially the same and compare what
events are emitted.
What we should get (and which we need to verify) is whether we see a
'finish' event. What should be issued is a finish event after the close
event. This is what the code is waiting on (according to the docs,
'finish' is emitted once all resources have been released and close has
been emitted).
The thing which has me frustrated is that I'm finding the results are
intermittent. For example, I ran the script with a size of 200 and it
worked fine, but when I ran it with a size of 150, it failed and then
running with 200 failed. I've not been able to determine why sometimes
it works and sometimes it fails with the same sizes. Once it fails, it
appears to fail consistently for a time, but then if you wait and try
again, it might work fine.
I'm going to modify the scripts to repeat tests multiple times with
increasing sizes and see if I can find a repeatable case. All I have
been able to verify so far is no errors with versions 14.0 or less.
|
I don't think the missing 'close' event has any relevance. The hanging
issue exists with buffers written directly via write() without an
intermediate readStream. I have added another script
tools/lowlevel-buffer-put-test.js which also turns on ssh2 debugging. It
looks like, for some unknown reason, at times, ssh2/ssh2-streams is not
returning a STATUS after data is written to the sftp writeStream. This
doesn't appear to always happen, but can be reliably triggered if you
start with a buffer size of at least 200k. Weird thing is that if I
start with a buffer size of 90k and then repeatably put buffers with
increasing sizes (by 10k), it won't fail at 200k - in fact, I've not
been able to get it to fail when starting at 90 and increasing up 1000 times!.
The new script takes 3 arguments: starting size in k, number of runs and
path to remote directory to write the files. It will generate a new
buffer for each run, increasing the size by 10k each time. When I run
the script as follows
lowlevel-buffer-put-test.js 100 20 /remote/dir -> works
lowlevel-buffer-put-test.js 200 20 /remote/dir -> hangs
lowlevel-buffer-put-test.js 300 20 /remote/dir -> works
lowlevel-buffer-put-test.js 400 20 /remote/dir -> hangs
lowlevel-buffer-put-test.js 500 20 /remote/dir -> works
lowlevel-buffer-put-test.js 600 20 /remote/dir -> hangs
Notice that with 20 runs and an increase of 10k each run, there is
overlap in sizes between the different runs when increasing starting
size by 100k.
I've also noticed that if it keeps working and I cannot generate an
error, even with sizes which previously generated an error, deleting all
the files from the remote directory already uploaded seems to 'reset'
things and the error will happen again.
To muddy the waters further, if a script hangs and I kill it and then
run it again immediately, more often than not it will then work or work
after 4 or 5 attempts. I also tried testing with a destination of
localhost and was not able to reproduce the error with any buffer size.
With node v14.1 or less, it works reliably every time. With 14.2 ->
14.7, I see the hanging behaviour. I'm testing against a virtual box
image running Arch Linux and a remote sftp server running RedHat on a
remote network. The hanging behaviour is observed on both systems.
I'm going to try testing with some of the other connection options set
e.g. force ipv4, ipv6, compression, no compression etc and see if
anything else shows up.
If you are also seeing errors with the above script, would you mind
logging an issue against ssh2-streams? I will update the issue I already
have logged. Need to stress the issue is intermittent. I wouldn't be
surprised if you find different sizes reliably trigger the issue to the
ones I've observed.
|
Seems the root cause could be here nodejs/node#32887 (comment) |
The ssh2 module is being re-written to address this and some other limitations of that module. The ssh2-streams module is also being deprecated. This means a re-write of ssh2-sftp-client will be necessary to work with the updated ssh2 module. I have created the branch version-6, which will be used to do the re-write. |
Thanks for the heads up, I might have some free time in the coming weeks if you want a hand in doing so I'd be happy to help. |
Update: I have recently tested against the new ssh2 version. While the issues specific to fastPut and fastGet appear to be resolved in the new ssh2 version, there are still some issues with put/get which appear to be related to streams. The seems to still be a bit of work required on the new version of ssh2 before it will be ready for a release. I have tested the existing 0.8.9 version of ssh2 against latest node v15.4.0. The changes introduced in node v14.x which caused problems with ssh2 have been rolled back. This means that ssh2 and ssh2-sftp-client seems to work OK with node version 15.4.0. However, the changes which were rolled back did provide significant performance improvements in other areas, so it is likely that at some point they will be re-applied in one fashion or another. Hopefully, the new version of ssh2 will be released before this occurs. |
A new version of ssh2 has been released which addresses the underlying issue which caused this issue. I will be releasing ssh2-sftp-client 7.0.0 in a week. The new version works with all known versions of node >= v10. I'm closing this issue as it has been resolved upstream with the new ssh2 version. |
Hi,
I'm trying to do a simple upload of a small CSV file I'm generating on the fly.
Here is the relevant portion of the code
When doing so, most of the time the upload will hang, with logs showing:
and it will stay like so forever
Sometime, completely at random, it will go through and in thise case the logs will be like that:
I'm currently running Node v14.4.0, so I'm wondering if this could be linked to mscdex/ssh2-streams#156 ?
You mention in this issue that using a concurrency of 1 it's working all the time, and my understanding was that
client.put
is running in the same configuration which is why I'm opening this issue here as I'm not sure it's the same.Do you have any idea what I could do to ensure a more consistent result while running Node >= v14.1.0 ?
Thanks
The text was updated successfully, but these errors were encountered: