How does NuGet decide whether to use local package

2020-05-26 10:57发布

Today I've faced with a strange behavior of NuGet when installing a package.

A brief description: as a result of my build script there's a NuGet package. I don't change the version each time, so each and every build produces MyPackage.1.0.0.nupkg. As the final step of the build, I push the package to the NuGet server deployed inside the local network.

Now, on a different machine, I run nuget install MyPackage -Source http://myserver/nuget, which obviously installs the NuGet package.

The problem comes into play when I push another update of MyPackage - still of version 1.0.0. When I try to re-install it on client machine, I get the previous version of the package.

I found out it is the local cache to be blamed: if the package was installed, it gets into the local cache and the next time the package of the same version is installed, it is taken from cache. Fair enough!

But, on the other hand, there's a -NoCache option of the nuget install command, and I expect it to ignore the local cache.

However, this is not true. The first time I run it with -NoCache, it updates the cache and installs the true latest version. But, the next time the package is still taken from cache, even with -NoCache option.

Is it expected? Is it because of the version not being changed?

Just in case: all NuGet operations are done with NuGet.exe and from PowerShell session.

UPDATE: I observe strange behavior I can only explain by cache expiration. When the package is cached, all subsequent calls to nuget install pull the package from cache, until some time passes. I didn't notice the exact period, but it's definitely more than an hour. After this, nuget install updates the package in the cache, and the situation becomes the same...

2条回答
在下西门庆
2楼-- · 2020-05-26 11:23

Yan,

I push another update of MyPackage - still of version 1.0.0.

You should not be pushing more than one package with a particular version: packages should be immutable. If you've changed something in the package, increment the build number a.b.C and push a new version of the package.

The behaviour you experience is a side effect of NuGet expecting to be able to cache a given package version essentially indefinitely.

查看更多
forever°为你锁心
3楼-- · 2020-05-26 11:36

Yan,

NuGet caches the packages it downloads on your local hard drive. For my windows 7 machine the cache is located at C:\Users\jmelosegui\AppData\Local\NuGet\Cache. So you can delete the nuget package you want to forget from the local cache directory. Then the next time you install the package you will get the lastest version from the server.

BTW: I am agree with @matthew-skelton.

You should not be pushing more than one package with a particular version: packages should be immutable. If you've changed something in the package, increment the build number a.b.C and push a new version of the package.

I hope this aproach fit in your scenario

查看更多
登录 后发表回答