Configure Windows Firewall for remote debugging
On a network protected by Windows Firewall, the firewall must be configured to permit remote debugging. Visual Studio and the remote debugging tools try to open the correct firewall ports during installation or startup, but you might also need to open ports or allow apps manually.
This topic describes how to configure the Windows Firewall to enable remote debugging on Windows 10, 8/8.1, and 7; and Windows Server 2012 R2, 2012, and 2008 R2 computers. The Visual Studio and remote computer don't have to be running the same operating system. For example, the Visual Studio computer can run Windows 11, and the remote computer can run Windows Server 2012 R2.
Note
The instructions for configuring the Windows Firewall differ slightly on different operating systems, and for older versions of Windows. Windows 8/8.1, Windows 10 and newer versions, and Windows Server 2012 settings use the word app, while Windows 7 and Windows Server 2008 use the word program.
Configure ports for remote debugging
Visual Studio and the remote debugger try to open the correct ports during installation or startup. However, in some scenarios, such as a third-party firewall, you might need to open ports manually.
To open a port:
In Windows Start menu, search for and open Windows Firewall with Advanced Security. Starting in Windows 10, this is Windows Defender Firewall with Advanced Security.
For a new incoming port, select Inbound Rules and then select New Rule. For an outgoing rule, select Outbound Rules instead.
In the New Inbound Rule Wizard, select Port, and then select Next.
Select either TCP or UDP, depending on the port number from the following tables.
Under Specific local ports, enter a port number from the following tables, and select Next.
Select Allow the Connection, and then select Next.
Select one or more network types to enable, including the network type for the remote connection, and then select Next.
Add a name for the rule (for example,
msvsmon
,IIS
, orWeb Deploy
), and then select Finish.The new rule should appear and be selected in the Inbound Rules or Outbound Rules list.
To open a port using PowerShell:
For Windows Firewall, you can use PowerShell commands such as New-NetFirewallRule.
The following example opens port 4026 for the remote debugger on the remote computer. The port and path you need to use might be different.
New-NetFirewallRule -DisplayName "msvsmon" -Direction Inbound -Program "Program Files\Microsoft Visual Studio\2022\Enterprise\Common7\IDE\Remote Debugger\x64\msvsmon.exe" -LocalPort 4026 -Protocol TCP -Authentication Required -Action Allow
The following example opens port 4024 for the remote debugger on the remote computer. The path you need to use might be different.
New-NetFirewallRule -DisplayName "msvsmon" -Direction Inbound -Program "Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\IDE\Remote Debugger\x64\msvsmon.exe" -LocalPort 4024 -Protocol TCP -Authentication Required -Action Allow
Ports on the remote computer that enable remote debugging
For remote debugging, the following ports must be open on the remote computer:
Ports | Incoming/Outgoing | Protocol | Description |
---|---|---|---|
4026 | Incoming | TCP | For Visual Studio 2022. For more information, see Visual Studio remote debugger port assignments. |
4025 | Incoming | TCP | For Visual Studio 2022 and Microsoft Azure App Service. This port is only used to remote debug a 32-bit process from a 64-bit version of the remote debugger. For more information, see Visual Studio remote debugger port assignments. |
4024 | Incoming | TCP | For Microsoft Azure App Service. For more information, see Visual Studio remote debugger port assignments. |
3702 | Outgoing | UDP | (Optional) Required for remote debugger discovery. |
Ports | Incoming/Outgoing | Protocol | Description |
---|---|---|---|
4024 | Incoming | TCP | For Visual Studio 2019 and Microsoft Azure App Service. The port number increments by 2 for each Visual Studio version. For more information, see Visual Studio remote debugger port assignments. |
4025 | Incoming | TCP | For Visual Studio 2019 and Azure App Service. This port is only used to remote debug a 32-bit process from a 64-bit version of the remote debugger. For more information, see Visual Studio remote debugger port assignments. |
3702 | Outgoing | UDP | (Optional) Required for remote debugger discovery. |
If you select Use Managed Compatibility Mode under Tools > Options > Debugging, open these additional remote debugger ports. Debugger Managed Compatibility Mode enables a legacy, Visual Studio 2010 version of the debugger.
Ports | Incoming/Outgoing | Protocol | Description |
---|---|---|---|
135, 139, 445 | Outgoing | TCP | Required. |
137, 138 | Outgoing | UDP | Required. |
If your domain policy requires network communication to be performed through Internet Protocol Security (IPSec), you must open additional ports on both the Visual Studio and remote computers. To debug on a remote Internet Information Services (IIS) web server, open port 80 on the remote computer.
Ports | Incoming/Outgoing | Protocol | Description |
---|---|---|---|
500, 4500 | Outgoing | UDP | Required if your domain policy requires network communication to be performed through IPSec. |
80 | Outgoing | TCP | Required for web server debugging. |
To allow specific apps through the Windows Firewall, see Configure remote debugging through Windows Firewall.
Allow the remote debugger through Windows Firewall
When you configure the remote debugger, the configuration software should open the correct ports. However, in some scenarios you might need to manually allow the remote debugger through the firewall.
To allow the remote debugger through Windows Firewall:
In Windows Start menu, search for and open Windows Firewall, or Windows Defender Firewall.
Select Allow an app through Windows Firewall.
If Remote Debugger or Visual Studio Remote Debugger doesn't appear under Allowed apps and features, select Change settings, and then select Allow another app.
If the remote debugger app still isn't listed in the Add an app dialog, select Browse, and navigate to <Visual Studio installation directory>\Common7\IDE\Remote Debugger\<x86, x64, or Appx>, depending on the appropriate architecture for your app. Select msvsmon.exe, and then select Add.
In the Apps list, select the Remote Debugger that you just added. Select Network types, and then select one or more network types, including the network type for the remote connection.
Select Add, and then select OK.
Troubleshoot the remote debugging connection
If you can't attach to your app with the remote debugger, make sure the remote debugging firewall ports, protocols, network types, and app settings are all correct.
In the Windows Start menu, search for and open Windows Firewall, and select Allow an app through Windows Firewall. Make sure Remote Debugger or Visual Studio Remote Debugger appears in the Allowed apps and features list with a selected checkbox, and the correct network types are selected. If not, add the correct apps and settings.
In the Windows Start menu, search for and open Windows Firewall with Advanced Security. Make sure Remote Debugger or Visual Studio Remote Debugger appears under Inbound Rules (and optionally, Outbound Rules) with a green check mark icon, and that all settings are correct.
- To view or change the rule settings, right-click the Remote Debugger app in the list and select Properties. Use the Properties tabs to enable or disable the rule, or change port numbers, protocols, or network types.
- If the remote debugger app doesn't appear in the rules list, add and configure the correct ports.