Msvsmon.exe Microsoft

  понедельник 30 марта
      33
Msvsmon.exe Microsoft Average ratng: 4,1/5 9101 reviews
-->

The msvsmon.exe is an executable file on your computer's hard drive. This file contains machine code. If you start the software Microsoft® Visual Studio® 2005 on your PC, the commands contained in msvsmon.exe will be executed on your PC. Error: The Microsoft Visual Studio Remote Debugging Monitor (MSVSMON.EXE) does not appear to be running on the remote computer.

You can debug a Visual Studio application that has been deployed on a different computer. To do so, you use the Visual Studio remote debugger.

For in-depth instructions on remote debugging, see these topics.

ScenarioLink
Azure App ServiceSnapshot Debugger or Remote debug ASP.NET on Azure
Azure VMRemote debug ASP.NET on Azure
Azure Service FabricDebug an Azure Service Fabric application
ASP.NETRemote debug ASP.NET Core or Remote Debug ASP.NET
C# or Visual BasicRemote debug a C# or Visual Basic project
C++Remote debug a C++ project
Universal Windows Apps (UWP)Run UWP apps on a remote machine or Debug an installed app package

If you just want to download and install the remote debugger and don't need any additional instructions for your scenario, follow the steps in this article.

Download and Install the remote tools

On the remote device or server that you want to debug on, rather than the Visual Studio machine, download and install the correct version of the remote tools from the links in the following table.

  • Download the most recent remote tools for your version of Visual Studio. The latest remote tools version is compatible with earlier Visual Studio versions, but earlier remote tools versions aren't compatible with later Visual Studio versions. (For example, if you are using Visual Studio 2017, download the latest update of the remote tools for Visual Studio 2017. In this scenario, do not download the remote tools for Visual Studio 2019.)
  • Download the remote tools with the same architecture as the machine you're installing them on. For example, if you want to debug a 32-bit app on a remote computer running a 64-bit operating system, install the 64-bit remote tools.
VersionLinkNotes
Visual Studio 2019Remote toolsCompatible with all Visual Studio 2019 versions. Download the version matching your device operating system (x86, x64, or ARM64). On Windows Server, see Unblock the file download for help downloading the remote tools.
Visual Studio 2017Remote toolsCompatible with all Visual Studio 2017 versions. Download the version matching your device operating system (x86, x64, or ARM64). On Windows Server, see Unblock the file download for help downloading the remote tools.
Visual Studio 2015Remote toolsRemote tools for Visual Studio 2015 are available from My.VisualStudio.com. If prompted, join the free Visual Studio Dev Essentials program, or sign in with your Visual Studio subscription ID. On Windows Server, see Unblock the file download for help downloading the remote tools.
Visual Studio 2013Remote toolsDownload page in Visual Studio 2013 documentation
Visual Studio 2012Remote toolsDownload page in Visual Studio 2012 documentation
VersionLinkNotes
Visual Studio 2017Remote toolsCompatible with all Visual Studio 2017 versions. Download the version matching your device operating system (x86, x64, or ARM64). On Windows Server, see Unblock the file download for help downloading the remote tools. For the most recent version of the remote tools, open the Visual Studio 2019 doc.
Visual Studio 2015Remote toolsRemote tools for Visual Studio 2015 are available from My.VisualStudio.com. If prompted, join the free Visual Studio Dev Essentials program, or sign in with your Visual Studio subscription ID. On Windows Server, see Unblock the file download for help downloading the remote tools.
Visual Studio 2013Remote toolsDownload page in Visual Studio 2013 documentation
Visual Studio 2012Remote toolsDownload page in Visual Studio 2012 documentation

You can run the remote debugger by copying msvsmon.exe to the remote computer, rather than installing the remote tools. However, the Remote Debugger Configuration Wizard (rdbgwiz.exe) is available only when you install the remote tools. You may need to use the wizard for configuration if you want to run the remote debugger as a service. For more information, see (Optional) Configure the remote debugger as a service.

Note

  • To debug Windows 10 apps on ARM devices, use ARM64, which is available with the latest version of the remote tools.
  • To debug Windows 10 apps on Windows RT devices, use ARM, which is available only in the Visual Studio 2015 remote tools download.

Requirements

Supported Operating Systems

The remote computer must be running one of the following operating systems:

  • Windows 10 (not phone)

  • Windows 8 or 8.1 (not phone)

  • Windows 7 Service Pack 1

  • Windows Server 2016

  • Windows Server 2012 or Windows Server 2012 R2

  • Windows Server 2008 Service Pack 2, Windows Server 2008 R2 Service Pack 1

Note

Windows Phone requires a USB connection to debug (it does not require the remote tools).

Supported Hardware Configurations

  • 1.6 GHz or faster processor

  • 1 GB of RAM (1.5 GB if running on a virtual machine)

  • 1 GB of available hard disk space

  • 5400-RPM hard drive

  • DirectX 9-capable video card running at 1024 x 768 or higher display resolution

Network configuration

The remote computer and the Visual Studio computer must be connected over a network, workgroup, or homegroup, or else connected directly through an Ethernet cable. Debugging between two computers connected through a proxy is not supported. Debugging over a high latency or low bandwidth connection, such as dialup Internet, or over the Internet across countries is not recommended and may fail or be unacceptably slow.

(Optional) To run the remote debugger from a file share

You can find the remote debugger (msvsmon.exe) on a computer with Visual Studio Community, Professional, or Enterprise already installed. For some scenarios, the easiest way to set up remote debugging is to run the remote debugger (msvsmon.exe) from a file share. For usage limitations, see the remote debugger's Help page (Help > Usage in the remote debugger).

  1. Find msvsmon.exe in the directory matching your version of Visual Studio:

    Program Files (x86)Microsoft Visual Studio2019EnterpriseCommon7IDERemote Debuggerx86msvsmon.exe

    Program Files (x86)Microsoft Visual Studio2019EnterpriseCommon7IDERemote Debuggerx64msvsmon.exe

    Program Files (x86)Microsoft Visual Studio2017EnterpriseCommon7IDERemote Debuggerx86msvsmon.exe

    Program Files (x86)Microsoft Visual Studio2017EnterpriseCommon7IDERemote Debuggerx64msvsmon.exe

  2. Share the Remote Debugger folder on the Visual Studio computer.

  3. On the remote computer, run msvsmon.exe from the shared folder. Follow the setup instructions.

Tip

For command line installation and command line reference, see the Help page for msvsmon.exe by typing msvsmon.exe /? in the command line on the computer with Visual Studio installed (or go to Help > Usage in the remote debugger).

Set up the remote debugger

  1. On the remote computer, find and start the Remote Debugger from the Start menu.

    If you don't have administrative permissions on the remote computer, right-click the Remote Debugger app and select Run as administrator. Otherwise, just start it normally.

    If you are planning to attach to a process which is running as an administrator, or is running under a different user account (such as IIS), right-click the Remote Debugger app and select Run as administrator. For more information, see Run the remote debugger as an administrator.

  2. The first time you start the remote debugger (or before you have configured it), the Remote Debugging Configuration dialog box appears.

  3. If the Windows Web Services API is not installed, which happens only on Windows Server 2008 R2, select the Install button.

  4. Select at least one network type you want to use the remote tools on. If the computers are connected through a domain, you must choose the first item. If the computers are connected through a workgroup or homegroup, choose the second or third item as appropriate.

  5. Select Configure remote debugging to configure the firewall and start the remote debugger.

  6. When configuration is complete, the Remote Debugger window appears.

    The remote debugger is now waiting for a connection. Use the server name and port number shown to set the remote connection configuration in Visual Studio.

To stop the remote debugger, select File > Exit. You can restart it from the Start menu, or from the command line:

Configure the remote debugger

You can change some aspects of the configuration of the remote debugger after you have started it for the first time.

  • If you need to add permissions for other users to connect to the remote debugger, choose Tools > Permissions. You must have administrator privileges to grant or deny permissions.

    Important

    You can run the remote debugger under a user account that differs from the user account you are using on the Visual Studio computer, but you must add the different user account to the remote debugger's permissions.

    Alternatively, you can start the remote debugger from the command line with the /allow <username> parameter: msvsmon /allow <username@computer>.

  • If you need to change the Authentication mode or the port number, or specify a timeout value for the remote tools: choose Tools > Options.

    For a listing of the port numbers used by default, see Remote Debugger Port Assignments.

    Warning

    You can choose to run the remote tools in No Authentication mode, but this mode is strongly discouraged. There is no network security when you run in this mode. Choose the No Authentication mode only if you are sure that the network is not at risk from malicious or hostile traffic.

(Optional) Configure the remote debugger as a service

For debugging in ASP.NET and other server environments, you must either run the remote debugger as an Administrator or, if you want it always running, run the remote debugger as a service.

If you want to configure the remote debugger as a service, follow these steps.

  1. Find the Remote Debugger Configuration Wizard (rdbgwiz.exe). (This is a separate application from the Remote Debugger.) It is available only when you install the remote tools. It is not installed with Visual Studio.

  2. Start running the configuration wizard. When the first page comes up, click Next.

  3. Check the Run the Visual Studio 2015 Remote Debugger as a service checkbox.

  4. Add the name of the user account and password.

    You may need to add the Log on as a service user right to this account (Find Local Security Policy (secpol.msc) in the Start page or window (or type secpol at a command prompt). When the window appears, double-click User Rights Assignment, then find Log on as a service in the right pane. Double-click it. Add the user account to the Properties window and click OK). Click Next.

  5. Select the type of network that you want the remote tools to communicate with. At least one network type must be selected. If the computers are connected through a domain, you should choose the first item. If the computers are connected through a workgroup or homegroup, you should choose the second or third items. Click Next.

  6. If the service can be started, you will see You have successfully completed the Visual Studio Remote Debugger Configuration Wizard. If the service cannot be started, you will see Failed to complete the Visual Studio Remote Debugger Configuration Wizard. The page also gives some tips to follow to get the service to start.

  7. Click Finish.

    At this point the remote debugger is running as a service. You can verify this by going to Control Panel > Services and looking for Visual Studio 2015 Remote Debugger.

    You can stop and start the remote debugger service from Control Panel > Services.

Set up debugging with remote symbols

You should be able to debug your code with the symbols you generate on the Visual Studio computer. The performance of the remote debugger is much better when you use local symbols. Short answer study guide questions macbeth. If you must use remote symbols, you need to tell the remote debugging monitor to look for symbols on the remote machine.

Starting in Visual Studio 2013 Update 2, you can use the following msvsmon command-line switch to use remote symbols for managed code: Msvsmon /FallbackLoadRemoteManagedPdbs

For more information, please see the remote debugging help (press F1 in the remote debugger window, or click Help > Usage). You can find more information at .NET Remote Symbol Loading Changes in Visual Studio 2012 and 2013

See also

This page contains tips for better debugging of Concord extensions in particular, and, to some degree at least, Visual Studio all up.

Extensions will load into an msvsmon.exe process if either: (1) they are configured to load into a worker process -or- (2) they are monitor components (components with a component level less than 100,000) and the target process is 64-bit.

The best way to debug these:

  1. Install the Microsoft Child Process Debugging Power Tool into Visual Studio using the Extension Manager.
  2. Configure your startup project (example: vsix.csproj) to use either native-only or native+managed (interop) debugging. If your startup project is already a VC project (.vcxproj), this is the default. If your startup project is a C# project, see below.
  3. Open 'Debug->Other Debug Targets->Child Process Debugging Settings' to configure the child process debugger.
  4. Check the checkbox to 'Enable Child Process Debugging'
  5. Set the '<All other processes>' action to 'Do not debug'
  6. Click the blank row in the process list, and add an entry for msvsmon.exe
  7. Set the 'Debugger Type' value to what is appropriate for your extension (example: 'Managed (v4.6, v4.5, v4.0)' if your extension is implemented in managed code). You may want to enable 'Managed + Native' debugging to prevent msvsmon from timing out.
  8. Hit F5 to start debugging

Msvsmon timeout while debugging

If you debug the devenv.exe process with a native debugger and either don't debug msvsmon.exe, or you debug msvsmon.exe with a non-native debugger, and if you sit in break state for more than three minutes msvsmon will timeout and abort. You can work around this problem be either:

  1. In child process debug settings, enable 'Managed + Native' debugging for msvsmon.exe instead of managed-only debugging

-or-

  1. If you are in break state for msvsmon, but you are only attaching to devenv.exe for use by the child process debugger than you can work around this problem by going to Tools->Options->Debugging->General, uncheck 'Break all processes when one process breaks'. This will keep the debugger from breaking into the devenv.exe process when the debugger is stopped for managed debugging msvsmon.exe.

Enabling native debugging if you have a .csproj as your startup project

If you have a .csproj as your startup project it is still sometimes useful to launch Visual Studio with native debugging enabled. There are three ways to do this:

Option #1: Enable both managed and native debugging at the same time

Right click on your startup project and bring up project properties. Then switch to the 'Debug' tab and check the 'Enable native code debugging' checkbox. This setting is probably the best option as long as the performance of Visual Studio is acceptable in this mode. Note that if you find things are running too slow, two things that might help in addition to the other options here:

  • Review your Just My Code settings
  • If your target VS is doing something very intensive (example: loading a large .vcxproj) consider if there are ways to avoid this such as opening the build executable an an exe project instead of the real project.

Option #2: Hand edit your .csproj to enable native-only debugging

  • Right click on the startup project and unload it
  • Right click again and edit it
  • Inside a <PropertyGroup> add:
  • Right click on your project and reload it + set it as the startup project

This approach is best as long as you don't need to debug any managed code running in devenv.exe, and you aren't frequently wanting to switch back and forth between managed-only and native-only debugging.

Option #3: Add a dummy .vcxproj to your solution just for debugging

  • Add a new C++ console app to your solution. Call it something like 'NativeDebugDevenv'.
  • Right click on your new project, and go to Build Dependencies->Project Dependencies, and make your new project dependent on your current startup project (ex: vsix.csproj). This will make it so your real project will build as part of F5.
  • Right click on the project again and open project properties. Go to the 'Debugging' tab, and make these changes:
    • Change 'Command' to $(DevEnvDir)devenv.exe
    • Change 'Command arguments' to /rootsuffix Exp
    • Change 'Working directory' to $(DevEnvDir)
  • Make this new project your startup project.

Now you can quickly toggle between managed-only debugging and native-only debugging just by switching your startup project.

If your are managed debugging, there are two Tools->Options->Debugging->General settings that can have a pretty significant impact on debugging experience:

  • Enable Just My Code
  • Suppress JIT optimizations on module load (Managed only)

For best performance, you want to leave these in the default state -- Just My Code (JMC) checked, suppress JIT optimizations unchecked. This will also break, by default, if your code raises an exceptions to Visual Studio. This isn't always what you want -- sometimes your extension is probably supposed to throw an exception. But it is usually a good default and you can configure the specific exception types that you don't want to stop on, such as maybe 'NotImplementedException' to stop breaking when the exception is 'User Unhandled'.

If your are investigating a failure that is happening in some other part of Visual Studio it can be useful to temporarily change both of these -- uncheck JMC and check suppress JIT optimizations. Now the output window will show you all the exceptions raised, and you can configure the debugger to break on ones that you think might be causing your problem.

If you haven't already looked at method logs you might want to do so. For some problems, like understanding why your component isn't getting called, logs are better than debugging.