Surge Troubleshooting Guide
If you encounter problems while using Surge, please refer to this guide for troubleshooting.
Before you start, you may want to read “Official Guidance:Understanding Surge” to learn more about the underlying mechanisms of Surge.
Before proceeding with detailed troubleshooting, please try restarting your Mac or iPhone to see if this resolves the issue. If the problem disappears after a restart and does not reappear, it’s typically a system-level occasional bug and can be ignored.
If this guide fails to resolve your issue, please contact [email protected], and remember to include the output of any test commands provided in this guide.
Analyzing the Source of the Problem
As a local network forwarding tool, common issues with Surge fall into two broad categories: failing to successfully take over network requests, and failing to successfully forward network traffic. These two types require fundamentally different troubleshooting approaches.
First, open the Request Viewer (Dashboard) in Surge Mac, or the Recent Requests page in Surge iOS. Then open a browser and visit a common site such as https://bing.com. Observe whether the request appears in the request list.
If the request does not appear in the list, it is a takeover issue. If the request appears, it is a forwarding issue.
If You Do Not See the Request - Takeover Issues
Surge Mac has two main takeover modes: system proxy and enhanced mode (NE VIF). Go to the Overview page to confirm whether these modes are enabled and functioning. Enabling either mode allows takeover of browser requests.
Confirming System Proxy
If this shows as normal, you can further verify via command line. Run scutil --proxy in Terminal to print the current active system proxy settings. If Surge has correctly set the system proxy, the result should be:
<dictionary> {
  ExcludeSimpleHostnames : 1
  HTTPEnable : 1
  HTTPPort : 6152
  HTTPProxy : 127.0.0.1
  HTTPSEnable : 1
  HTTPSPort : 6152
  HTTPSProxy : 127.0.0.1
}The value of ExcludeSimpleHostnames does not matter. If any other fields differ, it means Surge failed to set the system proxy successfully. Check if other similar software has taken over the system proxy.
Confirming Enhanced Mode
Go to System Settings › Network › VPN settings to check if Surge is enabled. If not, enhanced mode activation has failed, and you should see a clear error in the Surge interface. If other VPN entries are enabled, another app has taken over system VPN usage.
You can also test via command line. Run ping apple.com. If it works and the target IP is 198.18.x.x, Surge’s enhanced mode is working. You can further check with curl -vvv https://apple.com.
If enhanced mode is not functioning, and a restart does not help, go to Surge Mac’s More › Settings › System Permissions Overview, remove the network extension and VPN configuration. Then reboot and try enabling enhanced mode again.
If You See the Request - Forwarding Issues
Click into the specific request and switch to the Notes tab, where the cause of failure will be detailed. Usually, failures are due to policy server faults. Common errors include:
- Connection refused: Proxy setup error or server fault 
- Connection timeout: Proxy setup error or server fault 
- No upstream DNS server: No valid DNS server defined in Surge profile; adjust your profile 
- No route to host: Proxy setup error, or the device has no network 
Last updated
