The renv package (pronounced "R" "env") helps you create reproducible environments for your R projects. Use renv to make your R projects more:
Isolated: Installing a new or updated package for one project won't break your other projects, and vice versa. That's because renv gives each project its own private library.
Portable: Easily transport your projects from one computer to another, even across different platforms. renv makes it easy to install the packages your project depends on.
Reproducible: renv records the exact package versions you depend on, and ensures those exact versions are the ones that get installed wherever you go.
Install the latest version of renv from CRAN with:
install.packages("renv")
Use renv::init()
to initialize renv with a new or existing project.
This will set up your project with a private library, containing all the packages you're currently using.
The packages (and all the metadata needed to reinstall them) are also recorded into a lockfile, renv.lock
.
As you work in your project, you will install and upgrade packages.
After you've confirmed your code works as expected, call renv::snasphot()
to record their versions in the lockfile.
Later, if you need to share your code with someone else or run your code on new machine, you can call renv::restore()
to reinstall the specific package versions recorded in the lockfile.
If this is your first time using renv, we strongly recommend reading the Introduction to renv vignette.
If you have a question about renv, please first check the FAQ to see whether your question has already been addressed. If it hasn't, please feel free to ask on the RStudio Community forums.
If you believe you've found a bug in renv, please file a bug (and, if possible, a reproducible example) at https://github.com/rstudio/renv/issues.