66
votes

I installed .net core from this site. Playing with it led to a number of related package management questions:

  1. The dotnet restore command proceeded to "install" .net core NuGet packages. Where were those packages "installed"? A new folder was not created.
  2. The dotnet restore for the "hello world" minimal example required about a hundred NuGet packages, where 99% were presumably irrelevant to the "hello world" app. Granted, a .net native build will remove all that is not needed - but I expected that the restore also would have grabbed very little (three or four packages, not a hundred). Why this behavior?
  3. I created a second "hello world" project and again ran dotnet restore. This time no packages were installed at all. It seems all the packages installed the first time-around went into some global location to be shared. I thought .Net Core didn't work that way. I thought .Net Core projects kept all their dependencies locally. The only framework I targeted was dnxcore50. Why this behavior?
  4. I would like to "uninstall" all these global packages, and try again (just for learning purposes). How might that be accomplished? Remember, as stated in question #1, I don't know where all those files were installed.
  5. Almost all of the packages installed via the restore command were listed as beta. Odd. I thought .Net Core was in RC1, not beta. Confused by this. Why this behavior?

I'm also curious of what documentation could/would have explained all this to me. I tried googling for each of these questions, and found nothing (perhaps just horrible google-fu?).

3
"I thought .Net Core projects kept all their dependencies locally." is not covered by any of the answers. Simply speaking, those dependencies become local only when you use dotnet publish to generate deployment packages. The self-contained deployment mode would grab all dependencies to the same folder, docs.microsoft.com/en-us/dotnet/core/deploying This thread was unfortunately posted before Microsoft created the new Docs site, so any future reader should go and check out the new Docs.Lex Li

3 Answers

55
votes

Update:

  1. The nuget packages are installed in a global location. By default it used to be ..\Users\[YourUserFolder]\.dnx\packages but it appeared to have changed to ..\Users\[YourUserFolder]\.nuget\packages

In NuGet 3+, you can use the NuGet CLI's following command to get the global-packages folder location

nuget locals global-packages -list

Check out following links for more details about NuGet


  1. The default ASP.Net template has so many packages. Since you tried first time, it tried get all those 100s of packages

  2. You already had those packages in your nuget global locations, it skipped the restore.

  3. Delete all contents under packages folder (location indicated in 1)

  4. Some of the beta packages are there. You can go to project.json file (available under the web root) and play with the dependencies section.

15
votes

I just found out that there's another location for NuGet packages used in .NET core projects. Its located at:

C:\Users\[User]\.nuget\packages

I think that this location contains regular .NET Framework packages.

Update: Thanks to brappleye3, here's a link to the documentation regarding dotnet restore.

2
votes

I'm working with .Net Core 2.x and, I think, NuGet 4.x. Found Package locations here:

C:\Program Files (x86)\Microsoft SDKs\NuGetPackages\