Skip to content

filesystem-nio2 PutObject https response error 501 (Not Implemented) with rclone #816

@lukaszherman

Description

@lukaszherman

I'm trying to configure S3Proxy on Windows with Windows UNC/SMB path as backend.
Each file upload return 501, but files are properly stored on SMB location.
Am I missing some configuration part, or is rclone not compatybile with filesystem-nio2? (With filesystem provider there is no issue with this operation).

Some dubug logs from rclone:

2025/05/28 13:14:49 DEBUG : <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 2025/05/28 13:14:49 DEBUG : rclone.conf: Need to transfer - File not found at Destination 2025/05/28 13:14:49 DEBUG : S3 bucket testbucket2: Waiting for checks to finish 2025/05/28 13:14:49 DEBUG : S3 bucket testbucket2: Waiting for transfers to finish 2025/05/28 13:14:49 DEBUG : >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 2025/05/28 13:14:49 DEBUG : HTTP REQUEST (req 0xc000620640) 2025/05/28 13:14:49 DEBUG : **PUT /testbucket2/rclone.conf?x-id=PutObject HTTP/1.1** Host: s3-blah-blah-blah User-Agent: rclone/v1.69.3 Content-Length: 199 Accept-Encoding: identity Amz-Sdk-Invocation-Id: ebe990d9-c899-4fb2-9a3c-59f009b38c38 Amz-Sdk-Request: attempt=1; max=1 Content-Md5: Q+kV2k4879Z2gcacCaMP4g== Content-Type: application/octet-stream X-Amz-Content-Sha256: UNSIGNED-PAYLOAD X-Amz-Meta-Mtime: 1748409799.1783388 2025/05/28 13:14:49 DEBUG : >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 2025/05/28 13:14:49 DEBUG : <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 2025/05/28 13:14:49 DEBUG : HTTP RESPONSE (req 0xc000620640) 2025/05/28 13:14:49 DEBUG : **HTTP/2.0 501 Not Implemented** Content-Length: 0 Cache-Control: max-age=0 Date: Wed, 28 May 2025 11:14:49 GMT Server: Strict-Transport-Security: max-age=31536000 X-Amz-Request-Id: 4442587FB7D0A2F9 X-Powered-By: 2025/05/28 13:14:49 DEBUG : <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 2025/05/28 13:14:49 ERROR : rclone.conf: Failed to copy: operation error S3: PutObject, https response error StatusCode: 501, RequestID: 4442587FB7D0A2F9, HostID: , api error NotImplemented: Not Implemented 

s3proxy log:

[s3proxy] D 05-28 13:31:22.150 S3Proxy-Jetty-56 o.g.s.S3ProxyHandlerJetty:155 |::] UnsupportedOperationException: java.lang.UnsupportedOperationException: null	at java.base/sun.nio.fs.WindowsFileSystemProvider.readAttributes(Unknown Source)	at java.base/java.nio.file.Files.readAttributes(Unknown Source)	at java.base/java.nio.file.Files.getPosixFilePermissions(Unknown Source)	at org.gaul.s3proxy.nio2blob.AbstractNio2BlobStore.setBlobAccess(AbstractNio2BlobStore.java:812)	at org.gaul.s3proxy.nio2blob.AbstractNio2BlobStore.putBlob(AbstractNio2BlobStore.java:612)	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)	at java.base/java.lang.reflect.Method.invoke(Unknown Source)	at com.google.inject.internal.DelegatingInvocationHandler.invoke(DelegatingInvocationHandler.java:50)	at jdk.proxy2/jdk.proxy2.$Proxy63.putBlob(Unknown Source)	at org.gaul.s3proxy.S3ProxyHandler.handlePutBlob(S3ProxyHandler.java:2027)	at org.gaul.s3proxy.S3ProxyHandler.doHandle(S3ProxyHandler.java:765)	at org.gaul.s3proxy.S3ProxyHandlerJetty.handle(S3ProxyHandlerJetty.java:80)	at org.gaul.shaded.org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:122)	at org.gaul.shaded.org.eclipse.jetty.server.Server.handle(Server.java:563)	at org.gaul.shaded.org.eclipse.jetty.server.HttpChannel$RequestDispatchable.dispatch(HttpChannel.java:1598)	at org.gaul.shaded.org.eclipse.jetty.server.HttpChannel.dispatch(HttpChannel.java:753)	at org.gaul.shaded.org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:501)	at org.gaul.shaded.org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:287)	at org.gaul.shaded.org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:314)	at org.gaul.shaded.org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:100)	at org.gaul.shaded.org.eclipse.jetty.io.SelectableChannelEndPoint$1.run(SelectableChannelEndPoint.java:53)	at org.gaul.shaded.org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.runTask(AdaptiveExecutionStrategy.java:421)	at org.gaul.shaded.org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.consumeTask(AdaptiveExecutionStrategy.java:390)	at org.gaul.shaded.org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.tryProduce(AdaptiveExecutionStrategy.java:277)	at org.gaul.shaded.org.eclipse.jetty.util.thread.strategy.AdaptiveExecutionStrategy.run(AdaptiveExecutionStrategy.java:199)	at org.gaul.shaded.org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:411)	at org.gaul.shaded.org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:969)	at org.gaul.shaded.org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.doRunJob(QueuedThreadPool.java:1194)	at org.gaul.shaded.org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:1149)	at java.base/java.lang.Thread.run(Unknown Source) 

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions