Dependency Management at Scale
2020-10-03, 16:15–16:55 (America/Mexico_City), Best Practices
Language: Spanish

In an environment where software is constantly changing and new versions of a library should be distributed across thousands of projects, how can you know that your projects are using the right version of a given dependency? What if a OSS library introduces a security vulnerability and you need to make sure that no one is using it in your company? What if an internal library introduces a bad change and you need everyone to upgrade/downgrade? Automating these for hundreds or thousands of engineers is crucial.

At Netflix, engineers are not immune to the cost of dependency updates. Library owners publish new versions of their code without a comprehensive understanding of the organizational impact. Application owners ingest new library versions that can fail in obvious or subtle ways, leading to decreased confidence and slower organizational velocity. But these are problems we understand, and tooling can help.

After years of evolving our build, we've developed a few conceptual models of dependency management. Dependency management is hard, and in all cases there are compromises, and you the build owner should be conscious of which choices you're making and what else is available.

On this session, we'll introduce some tools we've developed at Netflix which attack dependency issues on a large scale to make it easier for every JVM engineer at Netflix and how we react to the scenarios mentioned above.

While most of our tooling is build around Gradle, the learnings from this talk can be applied to other build tools such as Maven.

Roberto is a Senior Software Engineer with focus in JVM build, continuous integration, continuous delivery, microservices and developer productivity. He has several years of experience using technologies for the JVM. He's an active maintainer of Netflix Nebula Plugins (https://nebula-plugins.github.io/) and occasionally contributor to Gradle build tool.

Currently works at Netflix as part of the Build Team in Engineering Tools and Services team focused in Developer Productivity.

The Build team acts as a centralized team to provide Netflix engineers with reliable and well maintained tooling to manage their builds. The team supports the systems and infrastructure to manage thousands of builds per day from thousands of repositories and hundreds of software engineers.