Organize Your Chickens - NuGet for the EnterpriseMaarten Balliauw@maartenballiauwRealDolmen
Organize Your Chickens     NuGet for the Enterprise
Who am I?•   Maarten Balliauw•   Antwerp, Belgium•   www.realdolmen.com•   Focus on web    – ASP.NET, ASP.NET MVC, PHP, Az...
Agenda• NuGet• Scenarios  –   Host your own NuGet repository   Chickens?!  –   Continuous Package Integration  –   Abusing...
NuGet
Welcome to Dependency Hell             frustration“A term for the                 of software users who haveinstalled soft...
Cause and Effect• Reinventing the wheel   – We don’t need that dependency   – “If they can do it, we can do it, but better...
Package Management• NuGet to the Rescue!  “NuGet is a Visual Studio extension that makes  it easy to install and update op...
DEMOFinding & consuming a NuGet package
DEMOpublishing a NuGet packageCreating &
Semantic Versioning• Think about your versioning! (semver.org)   Major      Breaking changes   Minor      Backwards compat...
Hosting a repository
Hosting your own repository• NuGet = public feed  – Privacy  – Intellectual property• NuGet maintained by package authors ...
Solutions•   Folder / File share•   NuGet.Server package•   NuGet Gallery (or Orchard Gallery)•   MyGet
DEMONuGet.Server
NuGet.Server limitations• Only 1 feed per installation• No UI   – up to you to build it• No granular security   – only 1 A...
Meet MyGet• www.myget.org• NaaS  – Register and off you go!• Supports Enterprise scenarios  – Granular security  – Package...
DEMOMyGet
Continuous PackageIntegration
Typical source control...• Contains /References (if you are lucky)  – ...and also    Project/_bin_deployable_assemblies  –...
Dependencies• Software has dependencies. Deal with it.• But are those YOUR intellectual property?  – YOUR reason to build ...
Continuous Package Integration• Can I get rid of all these referenced assemblies  duplicated all-over my source control sy...
DEMOPackage Restore
3rd parties don’t belong in your VCS• Replace them with NuGet packages• Do commit packagesrepositories.config file• Use En...
Problem!• NuGet feed is subject to change...  – PackageSource msbuild property to the rescue  (NuGet.settings.targets in $...
Organize your chickens• Feed structuring  – Scoped by quality: Build, QA, Production, …  – Scoped by audience: public, res...
Guidance• Publishing a package brings great  responsibility  – Breaking changes in your packages should be    versioned ac...
Guidance• Package Integration ≠ Integration Testing  – CI builds reflect output of source control input  – Same input alwa...
Abusing NuGet
Abusing NuGet?Change of perspective                  NuGet is a package manager                  NuGet is a protocol for  ...
NuGet as a Protocol
Automate deployments• Build results in .nupkg• Octopus deploys to its tentacles  – Test tentacles  – Staging tentacles  – ...
Chocolatey• NuGet  – developer library packages• Chocolatey  – applications and tools packager  – “yum” or “apt-get” for W...
DEMOChocolatey
Build                  Continuous     Test                         Delivery of the                         MyGet website  ...
ConclusionDependencies & people are chickens     Deal with them! NuGet can help Set up your own NuGet repository  Continuo...
http://blog.maartenballiauw.be                               @maartenballiauw  THANK YOU!      http://amzn.to/pronuget    ...
Organize your chickens: NuGet for the enterprise
Upcoming SlideShare
Loading in...5
×

Organize your chickens: NuGet for the enterprise

6,301

Published on

Managing software dependencies, whether those created in-house or from third parties can be a pain in the behind. Whether dependencies feel like wild chickens or people run around like chickens dealing with dependencies, the NuGet package manager can be a cure. Let us guide you to creating enterprise (chicken) NuGets and dealing with them in a structured, easy-to-maintain manner. From developer workstation to build server, NuGet tastes great! We'll provide you the dip sauce.

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
6,301
On Slideshare
0
From Embeds
0
Number of Embeds
5
Actions
Shares
0
Downloads
15
Comments
0
Likes
0
Embeds 0
No embeds

No notes for slide
  • Maarten
  • Xavier: Terugverwijzen naar “Marketing versioning”
  • Start with empty MVC template + addNuGet.ServerpkgRun siteDrop pkgs in packages folderRefresh browserFeed toevoegen in VS & show pkgs
  • Inloggen en feed aanmakenPackage pushen vanuit NPEFeed toevoegen aan VSOp MyGet feed security instellenPackage installen in VS en tonen dat er basic auth bijkomtPackage van NuGet toevoegen op MyGet en tonen dat je alle dependencies kan meepakken, mirroring, … en dat je ook gewoon van uw packages.config kan toevoegen
  • - Het feit dat NuGet.org geen garanties biedt op content- Wat als mensen packages verwijderen? BUILD breaks, DEVS unhappy again
  • Now isnot the time to take a nap (NaaP) NuGet is more than a package (system), it’s a protocol to:Distributesfunctionality (automateanything!, cfrScaffolding!)Distribute websites (akadeployments!)Distribute software in general 
  • Maarten
  • Maarten
  • Xavier
  • XavierMaartenXavierMaarten
  • Organize your chickens: NuGet for the enterprise

    1. 1. Organize Your Chickens - NuGet for the EnterpriseMaarten Balliauw@maartenballiauwRealDolmen
    2. 2. Organize Your Chickens NuGet for the Enterprise
    3. 3. Who am I?• Maarten Balliauw• Antwerp, Belgium• www.realdolmen.com• Focus on web – ASP.NET, ASP.NET MVC, PHP, Azure, … – MVP Windows Azure (formerly ASP.NET)• http://blog.maartenballiauw.be• @maartenballiauw• Author: Pro NuGet - http://amzn.to/pronuget
    4. 4. Agenda• NuGet• Scenarios – Host your own NuGet repository Chickens?! – Continuous Package Integration – Abusing NuGet – NuGet Inception• Conclusion
    5. 5. NuGet
    6. 6. Welcome to Dependency Hell frustration“A term for the of software users who haveinstalled software packages which have dependencies onspecific versions of other software packages.” (Wikipedia)
    7. 7. Cause and Effect• Reinventing the wheel – We don’t need that dependency – “If they can do it, we can do it, but better”  What happened to reuse of components?• Marketing-Driven Versioning – People are waiting for v2 to buy – Let’s call it v4 Platform Update SP3 November Edition KB2348063 RTW Refresh  We lost ownership of AssemblyVersion ?
    8. 8. Package Management• NuGet to the Rescue! “NuGet is a Visual Studio extension that makes it easy to install and update open source libraries and tools in Visual Studio.”• Simple concept – Find Packages – (Re)Use Packages – Produce Packages
    9. 9. DEMOFinding & consuming a NuGet package
    10. 10. DEMOpublishing a NuGet packageCreating &
    11. 11. Semantic Versioning• Think about your versioning! (semver.org) Major Breaking changes Minor Backwards compatible API additions/changes Patch Bugfixes not affecting the API – Always specify lowerbound – Use a version range (lowerbound + upperbound) when versioning of package you depend on is messed up
    12. 12. Hosting a repository
    13. 13. Hosting your own repository• NuGet = public feed – Privacy – Intellectual property• NuGet maintained by package authors – Author removes v1.0.45 and you depend on it
    14. 14. Solutions• Folder / File share• NuGet.Server package• NuGet Gallery (or Orchard Gallery)• MyGet
    15. 15. DEMONuGet.Server
    16. 16. NuGet.Server limitations• Only 1 feed per installation• No UI – up to you to build it• No granular security – only 1 API-key for entire feed• Conclusion: requires you to develop if you want something more useful
    17. 17. Meet MyGet• www.myget.org• NaaS – Register and off you go!• Supports Enterprise scenarios – Granular security – Package mirroring – Proxying
    18. 18. DEMOMyGet
    19. 19. Continuous PackageIntegration
    20. 20. Typical source control...• Contains /References (if you are lucky) – ...and also Project/_bin_deployable_assemblies – ...and also /References/old – ...and also /..././../.././References• Usually references GAC-ed assemblies
    21. 21. Dependencies• Software has dependencies. Deal with it.• But are those YOUR intellectual property? – YOUR reason to build software? – YOUR product?• No. They are dependencies. And they don’t belong in source control.
    22. 22. Continuous Package Integration• Can I get rid of all these referenced assemblies duplicated all-over my source control system? Yes!• Do I need to install and maintain NuGet on all my build agents? No!
    23. 23. DEMOPackage Restore
    24. 24. 3rd parties don’t belong in your VCS• Replace them with NuGet packages• Do commit packagesrepositories.config file• Use Enable-PackageRestore
    25. 25. Problem!• NuGet feed is subject to change... – PackageSource msbuild property to the rescue (NuGet.settings.targets in $(SolutionDir).nuget folder)• Now what... – Host your own feed and mirror packages – Or use MyGet for that 
    26. 26. Organize your chickens• Feed structuring – Scoped by quality: Build, QA, Production, … – Scoped by audience: public, restricted access – Other: • Scoped by product version, milestone… • Scoped by target platform
    27. 27. Guidance• Publishing a package brings great responsibility – Breaking changes in your packages should be versioned accordingly! – Consumers might choose to no longer consume any packages you published
    28. 28. Guidance• Package Integration ≠ Integration Testing – CI builds reflect output of source control input – Same input always produces same output  Do not auto-update packages during automated builds
    29. 29. Abusing NuGet
    30. 30. Abusing NuGet?Change of perspective NuGet is a package manager NuGet is a protocol for distributing packages
    31. 31. NuGet as a Protocol
    32. 32. Automate deployments• Build results in .nupkg• Octopus deploys to its tentacles – Test tentacles – Staging tentacles – Production tentacles• www.octopusdeploy.com
    33. 33. Chocolatey• NuGet – developer library packages• Chocolatey – applications and tools packager – “yum” or “apt-get” for Windows• www.chocolatey.org
    34. 34. DEMOChocolatey
    35. 35. Build Continuous Test Delivery of the MyGet website Package using: Push  TeamCity  NuGet Release / Publish  MyGet Deploy  OctopusDEMO DeliveryContinuous
    36. 36. ConclusionDependencies & people are chickens Deal with them! NuGet can help Set up your own NuGet repository Continuous package integration NuGet is a package manager NuGet is a protocol
    37. 37. http://blog.maartenballiauw.be @maartenballiauw THANK YOU! http://amzn.to/pronuget or Install-Package ProNuGet#tdvs
    1. A particular slide catching your eye?

      Clipping is a handy way to collect important slides you want to go back to later.

    ×