-
Notifications
You must be signed in to change notification settings - Fork 678
Troubleshooting: 'The .NET Core SDK cannot be located.' errors
This page contains more information about the error:
The .NET Core SDK cannot be located. .NET Core debugging will not be enabled. Make sure the .NET Core SDK is installed and is on the path.
What this error means is that this extension ran the command dotnet
and dotnet
was NOT found on the PATH
within the extension's process.
If you don't have the .NET Core SDK installed, fixing this error is usually simple enough: visit https://dot.net/core-sdk-vscode to download the .NET Core SDK.
If you do have the .NET Core SDK installed, then this means that the directory containing dotnet
(Linux and macOS) or dotnet.exe
(Windows) is not on your PATH
, at least in this extension's process. The rest of this page will provide advice on understanding why.
Before we get to a list of troubleshooting steps, lets first enumerate a few known reasons why this error happens:
- If you just installed the .NET SDK --
- If you had Visual Studio Code open at the time you installed the .NET SDK, and you haven't restarted it, you should do so.
- On Windows, on some machines, environment variable changes don't immediately take effect. Restart your computer to see if that resolves this problem.
- If the .NET SDK was installed through Linux snap - see Linux snap instructions
The first step in troubleshooting this problem is to see if this problem also happens is a terminal/shell. After you have launched a terminal or shell, type in which dotnet
.
If which dotnet
produces a PATH, then the .NET SDK was able to successfully modify the PATH, but VS Code isn't picking it up. VS Code attempts to scrape the environment by launching the default shell. But this process can be fragile. You can attempt to work around this by starting VS Code from your Terminal. Alternatively, you can attempt to debug VS Code to understand what is going wrong -- at this time at least, the function to debug is getUnixShellEnvironment
.
If which dotnet
produces no output, then this means the .NET SDK wasn't able to modify the PATH
or add a symbolic link, or the .NET SDK for your platform doesn't do so. You can fix this by either adding a symbolic link yourself (example: sudo ln -s /usr/share/dotnet/dotnet /usr/bin/dotnet
where /usr/share/dotnet/dotnet
should be replaced with wherever the .NET SDK installer for your platform was installed to), or by modifying your PATH
yourself.
The first step in troubleshooting this problem is to see if this problem also happens is a command prompt:
- Start a command prompt:
- Hit
WinKey+R
to bring up the Windows run dialog - Type in
cmd.exe
- Hit
- When the command prompt starts, type in
where.exe dotnet
.
If the result of running where.exe
is that a path to dotnet.exe is printed (example: C:\Program Files\dotnet\dotnet.exe
) then the .NET SDK has successfully added itself to the Windows Path. There are no known reasons why PATH wouldn't be propagated to the VS Code process. You could try starting VS Code from the command prompt to see if that helps.
If the result of running where.exe
is a message like INFO: Could not find files for the given pattern(s).
then the .NET SDK wasn't able to add itself to the PATH. You could try uninstalling and reinstalling the .NET SDK. You could also try examining the default path with the following steps:
- Bring up System Properties:
- Windows 10 - On the Start Menu, search for 'This PC' and bring up properties
- Before - On the Start Menu, search for 'My Computer' and bring up properties
- Go to the Advanced settings
- Click the button for 'Environment Variables'
- Find 'Path' in either the user or system list
- See if the dotnet.exe directory (example:
C:\Program Files\dotnet
) is in the list. If not you could add it. - If it is in the list, you could see if maybe another directory has added it self incorrectly (example: added an opening quote without a trailing quote), or if the set of environment variables has grown very large -- there is a limit of 32,767 total characters.
TODO
Configuration
- Configuring Snap installs of dotnet-sdk
- Configuring Arch Linux for Unity development
- Configuring Arch Linux for Razor development
- Installing the .NET Core Debugger on Arch Linux
Debugger
- Overview
- launch.json Help
- Feature List
- Enable Logging
- Portable PDBs
- Troubleshoot Breakpoints
- Attaching to remote processes
- Remote Debugging On Linux-Arm
- Windows Subsystem for Linux
- Diagnosting 'Debug adapter process has terminated unexpectedly'
- Testing libicu compatibility on Linux
- Debugging into the .NET Runtime itself
- Debugging x64 processes on an arm64 computer
Documentation
- Change Log
- Branches and Releases
- Installing Beta Releases
- Installing without internet connectivity
- Linux Support
- Run/Debug Unit Tests
- Troubleshooting: 'The .NET Core SDK cannot be located.' errors
Developer Guide