Is there anything like VirtualEnv for Java?

Gautam picture Gautam · Sep 4, 2011 · Viewed 19.9k times · Source

Is there anything similar to Python virtualenv for Java or JVM Languages?

Answer

Joachim Sauer picture Joachim Sauer · Sep 4, 2011

From what I understand, virtualenv enables you to have separate library installation paths, effectively separate "virtual" Python installations.

Java doesn't have the concept of a "system-wide installed" library(*): It always searches the classpath for the libraries to be loaded. Since the classpath can be (and needs to be!) defined for each application, each application can pick-and-choose which libraries and which versions it wants to load.

If you go down one level deeper and have a single application that somehow needs two different versions of the same library at the same time, then you can do even that with some classpath trickery. It can get complicated, but it's definitely possible (OSGi is one example where this is supported, even Tomcat with two separate webapplications does this).

I've seens some references to security in the virtualenv description: Java has a pretty thorough security system built in. In server applications it's often turned off because it's just easier to configure this way, but you can easily configure what exactly a Java application is allowed to do.

(*) Almost, there are extensions or extension libraries, but they aren't used a lot and even those can easily be loaded from arbitrary directories.