-
Notifications
You must be signed in to change notification settings - Fork 108
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
nftables and firewall issues on Synology/QNAP NAS #16
Comments
I just updated the latest tag of image to the newest warp version. Could you please try it out and see if there are still any problems?
It's better not to do this. Binding the dbus inside the container to the host's system socket gives the container excessive privileges. While running WARP, we may trust Cloudflare, but it could be dangerous when running other things. Just adding the following two lines in
If you still encounter a firewall or nft error, please let me know. |
Same problem. Another change you should do in entrypoint.sh: |
Found a possibly related discussion: https://forum.openwrt.org/t/22-02-firewall-fw4-issue/149323/3 Try run |
Seems to work nft -i. nft -inft> Any other idea ? Thanks. |
I'm sorry, I cannot find any other information about this issue. Cloudflare does not even provide the release notes for warp-cli, so I do not know what happened between the two versions. What is currently known is that the issue was caused by nft (nftables), which resulted in WARP being unable to change firewall settings. But I am still not clear on what caused nftables to malfunction. This may be due to the extremely old version of the Linux kernel of Synology, but I have no evidence. If anyone can provide additional information, I would be grateful. |
A workaround for having Cloudflare Warp on Synology devices:
Maybe this's useful for somebody. |
After I added
|
Thank you for the information you provided! I used to think that docker would provide default values for sysctl inside the container, but it seems that this is incorrect. The network namespace inside the container inherits from the init network namespace (not the host namespace, init namespace defaults is compiled into kernel).1 WARP wants to change this setting, but programs inside the container do not have this permission. Due to different kernel compilation settings, we may need to find all the settings required by Cloudflare and set them in the docker-compose file. I will wait for a few days, and if your settings work properly, I will merge this change into the code. Footnotes |
This kernel parameter does not take effect. |
Do you mean that the |
Switching the WARP mode to Local Proxy and updating the GOST params to route traffic via this local proxy does the trick. Running in that mode it seems that WARP doesn't try to mess with nft so the issue is sidestepped. Necessary changes below:
Dockerfile
I hope this helps (at least until we figure out the nft issue)! |
@davide with the improvements you suggest, can you share how you configure your container with Synology? I am currently trying this, but the container still stops: |
Ok, reached here tying to get warp connector running, which it's only supported by official client at this moment. IMHO, problem seems to be that warp-svc uses nftables to override firewall config, so docker images running on both, Synology or QNAP will fail. Only solutions are:
|
Hello,
With latest image I get this error on a Synology NAS:
2024-03-04T10:36:29.807Z DEBUG firewall: Firewall allow managed network endpoints managed_network_endpoints=[]
2024-03-04T10:36:29.807Z INFO firewall: Firewall starting
2024-03-04T10:36:29.813Z WARN firewall::linux: Failed to set firewall rules via stdin. Retrying using temporary file exit_code=ExitStatus(unix_wait_status(256))
2024-03-04T10:36:29.824Z ERROR firewall::linux: Failed to start firewall with exit code: exit status: 1
2024-03-04T10:36:29.824Z WARN firewall: fw.apply_rules failed e=ApplyError("nft command failed with return code: 256")
2024-03-04T10:36:29.825Z WARN main_loop: warp::warp_service: Unable to update firewall on disconnect e=ApplyError("nft command failed with return code: 256")
2024-03-04T10:36:29.825Z DEBUG main_loop: warp::warp_service: Determining disconnected reason from connectivity state net_info=IPv4: [eth0; 172.18.0.15; Ethernet]; DNS servers:; 127.0.0.11:53;
power_state=None disconnect_reason=None
2024-03-04T10:36:29.825Z WARN main_loop: warp::warp_service: Disconnecting, but reason is unknown
2024-03-04T10:36:29.825Z WARN main_loop: warp::warp_service: Reconnect on settings change failed error=FirewallUpdateFailed(ApplyError("nft command failed with return code: 256"))
With previous caomingjun/warp:2023-07-18 everything is ok.
I search for error "nft command failed with return code: 256" but I can't figure out how to fix it.
Seems that with latest version now it's necessary to add this volume:
/run/dbus/system_bus_socket:/run/dbus/system_bus_socket
I tried to build my own Dockerfile based on latest Ubuntu or Debian, delete Gost proxy, but nft error is still here.
Can you help me ? Thanks.
The text was updated successfully, but these errors were encountered: