diff --git a/lib/private/Config.php b/lib/private/Config.php
index cbdbc5b2e64db7c5ec3a894b3fd882651b69514c..0a868be783284577c30e2895c7b6648a45aba72e 100644
--- a/lib/private/Config.php
+++ b/lib/private/Config.php
@@ -47,6 +47,8 @@ class Config {
 
 	/** @var array Associative array ($key => $value) */
 	protected $cache = [];
+	/** @var array */
+	protected $envCache = [];
 	/** @var string */
 	protected $configDir;
 	/** @var string */
@@ -88,9 +90,9 @@ class Config {
 	 * @return mixed the value or $default
 	 */
 	public function getValue($key, $default = null) {
-		$envValue = getenv(self::ENV_PREFIX . $key);
-		if ($envValue !== false) {
-			return $envValue;
+		$envKey = self::ENV_PREFIX . $key;
+		if (isset($this->envCache[$envKey])) {
+			return $this->envCache[$envKey];
 		}
 
 		if (isset($this->cache[$key])) {
@@ -222,6 +224,8 @@ class Config {
 			flock($filePointer, LOCK_UN);
 			fclose($filePointer);
 		}
+
+		$this->envCache = getenv();
 	}
 
 	/**
diff --git a/tests/lib/ConfigTest.php b/tests/lib/ConfigTest.php
index db4efc7b15de2a22de7a8ce659f72be073a3f2a5..7c289472abd4ecd7ace8ddef2a9d51e016c6cd9f 100644
--- a/tests/lib/ConfigTest.php
+++ b/tests/lib/ConfigTest.php
@@ -8,6 +8,8 @@
 
 namespace Test;
 
+use OC\Config;
+
 class ConfigTest extends TestCase {
 	public const TESTCONTENT = '<?php $CONFIG=array("foo"=>"bar", "beers" => array("Appenzeller", "Guinness", "Kölsch"), "alcohol_free" => false);';
 
@@ -15,8 +17,6 @@ class ConfigTest extends TestCase {
 	private $initialConfig = ['foo' => 'bar', 'beers' => ['Appenzeller', 'Guinness', 'Kölsch'], 'alcohol_free' => false];
 	/** @var string */
 	private $configFile;
-	/** @var \OC\Config */
-	private $config;
 	/** @var string */
 	private $randomTmpDir;
 
@@ -26,7 +26,6 @@ class ConfigTest extends TestCase {
 		$this->randomTmpDir = \OC::$server->getTempManager()->getTemporaryFolder();
 		$this->configFile = $this->randomTmpDir.'testconfig.php';
 		file_put_contents($this->configFile, self::TESTCONTENT);
-		$this->config = new \OC\Config($this->randomTmpDir, 'testconfig.php');
 	}
 
 	protected function tearDown(): void {
@@ -34,54 +33,69 @@ class ConfigTest extends TestCase {
 		parent::tearDown();
 	}
 
+	private function getConfig(): Config {
+		return new \OC\Config($this->randomTmpDir, 'testconfig.php');
+	}
+
 	public function testGetKeys() {
 		$expectedConfig = ['foo', 'beers', 'alcohol_free'];
-		$this->assertSame($expectedConfig, $this->config->getKeys());
+		$this->assertSame($expectedConfig, $this->getConfig()->getKeys());
 	}
 
 	public function testGetValue() {
-		$this->assertSame('bar', $this->config->getValue('foo'));
-		$this->assertSame(null, $this->config->getValue('bar'));
-		$this->assertSame('moo', $this->config->getValue('bar', 'moo'));
-		$this->assertSame(false, $this->config->getValue('alcohol_free', 'someBogusValue'));
-		$this->assertSame(['Appenzeller', 'Guinness', 'Kölsch'], $this->config->getValue('beers', 'someBogusValue'));
-		$this->assertSame(['Appenzeller', 'Guinness', 'Kölsch'], $this->config->getValue('beers'));
+		$config = $this->getConfig();
+		$this->assertSame('bar', $config->getValue('foo'));
+		$this->assertSame(null, $config->getValue('bar'));
+		$this->assertSame('moo', $config->getValue('bar', 'moo'));
+		$this->assertSame(false, $config->getValue('alcohol_free', 'someBogusValue'));
+		$this->assertSame(['Appenzeller', 'Guinness', 'Kölsch'], $config->getValue('beers', 'someBogusValue'));
+		$this->assertSame(['Appenzeller', 'Guinness', 'Kölsch'], $config->getValue('beers'));
 	}
 
 	public function testGetValueReturnsEnvironmentValueIfSet() {
-		$this->assertEquals('bar', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('bar', $config->getValue('foo'));
+
 		putenv('NC_foo=baz');
-		$this->assertEquals('baz', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('baz', $config->getValue('foo'));
 		putenv('NC_foo'); // unset the env variable
 	}
 
 	public function testGetValueReturnsEnvironmentValueIfSetToZero() {
-		$this->assertEquals('bar', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('bar', $config->getValue('foo'));
+
 		putenv('NC_foo=0');
-		$this->assertEquals('0', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('0', $config->getValue('foo'));
 		putenv('NC_foo'); // unset the env variable
 	}
 
 	public function testGetValueReturnsEnvironmentValueIfSetToFalse() {
-		$this->assertEquals('bar', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('bar', $config->getValue('foo'));
+
 		putenv('NC_foo=false');
-		$this->assertEquals('false', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$this->assertEquals('false', $config->getValue('foo'));
 		putenv('NC_foo'); // unset the env variable
 	}
 
 	public function testSetValue() {
-		$this->config->setValue('foo', 'moo');
-		$this->assertSame('moo', $this->config->getValue('foo'));
+		$config = $this->getConfig();
+		$config->setValue('foo', 'moo');
+		$this->assertSame('moo', $config->getValue('foo'));
 
 		$content = file_get_contents($this->configFile);
 		$expected = "<?php\n\$CONFIG = array (\n  'foo' => 'moo',\n  'beers' => \n  array (\n    0 => 'Appenzeller',\n  " .
 			"  1 => 'Guinness',\n    2 => 'Kölsch',\n  ),\n  'alcohol_free' => false,\n);\n";
 		$this->assertEquals($expected, $content);
 
-		$this->config->setValue('bar', 'red');
-		$this->config->setValue('apps', ['files', 'gallery']);
-		$this->assertSame('red', $this->config->getValue('bar'));
-		$this->assertSame(['files', 'gallery'], $this->config->getValue('apps'));
+		$config->setValue('bar', 'red');
+		$config->setValue('apps', ['files', 'gallery']);
+		$this->assertSame('red', $config->getValue('bar'));
+		$this->assertSame(['files', 'gallery'], $config->getValue('apps'));
 
 		$content = file_get_contents($this->configFile);
 
@@ -92,27 +106,28 @@ class ConfigTest extends TestCase {
 	}
 
 	public function testSetValues() {
+		$config = $this->getConfig();
 		$content = file_get_contents($this->configFile);
 		$this->assertEquals(self::TESTCONTENT, $content);
 
 		// Changing configs to existing values and deleting non-existing once
 		// should not rewrite the config.php
-		$this->config->setValues([
+		$config->setValues([
 			'foo' => 'bar',
 			'not_exists' => null,
 		]);
 
-		$this->assertSame('bar', $this->config->getValue('foo'));
-		$this->assertSame(null, $this->config->getValue('not_exists'));
+		$this->assertSame('bar', $config->getValue('foo'));
+		$this->assertSame(null, $config->getValue('not_exists'));
 		$content = file_get_contents($this->configFile);
 		$this->assertEquals(self::TESTCONTENT, $content);
 
-		$this->config->setValues([
+		$config->setValues([
 			'foo' => 'moo',
 			'alcohol_free' => null,
 		]);
-		$this->assertSame('moo', $this->config->getValue('foo'));
-		$this->assertSame(null, $this->config->getValue('not_exists'));
+		$this->assertSame('moo', $config->getValue('foo'));
+		$this->assertSame(null, $config->getValue('not_exists'));
 
 		$content = file_get_contents($this->configFile);
 		$expected = "<?php\n\$CONFIG = array (\n  'foo' => 'moo',\n  'beers' => \n  array (\n    0 => 'Appenzeller',\n  " .
@@ -121,8 +136,9 @@ class ConfigTest extends TestCase {
 	}
 
 	public function testDeleteKey() {
-		$this->config->deleteKey('foo');
-		$this->assertSame('this_was_clearly_not_set_before', $this->config->getValue('foo', 'this_was_clearly_not_set_before'));
+		$config = $this->getConfig();
+		$config->deleteKey('foo');
+		$this->assertSame('this_was_clearly_not_set_before', $config->getValue('foo', 'this_was_clearly_not_set_before'));
 		$content = file_get_contents($this->configFile);
 
 		$expected = "<?php\n\$CONFIG = array (\n  'beers' => \n  array (\n    0 => 'Appenzeller',\n  " .
@@ -137,14 +153,14 @@ class ConfigTest extends TestCase {
 		file_put_contents($additionalConfigPath, $additionalConfig);
 
 		// Reinstantiate the config to force a read-in of the additional configs
-		$this->config = new \OC\Config($this->randomTmpDir, 'testconfig.php');
+		$config = new \OC\Config($this->randomTmpDir, 'testconfig.php');
 
 		// Ensure that the config value can be read and the config has not been modified
-		$this->assertSame('totallyOutdated', $this->config->getValue('php53', 'bogusValue'));
+		$this->assertSame('totallyOutdated', $config->getValue('php53', 'bogusValue'));
 		$this->assertEquals(self::TESTCONTENT, file_get_contents($this->configFile));
 
 		// Write a new value to the config
-		$this->config->setValue('CoolWebsites', ['demo.owncloud.org', 'owncloud.org', 'owncloud.com']);
+		$config->setValue('CoolWebsites', ['demo.owncloud.org', 'owncloud.org', 'owncloud.com']);
 		$expected = "<?php\n\$CONFIG = array (\n  'foo' => 'bar',\n  'beers' => \n  array (\n    0 => 'Appenzeller',\n  " .
 			"  1 => 'Guinness',\n    2 => 'Kölsch',\n  ),\n  'alcohol_free' => false,\n  'php53' => 'totallyOutdated',\n  'CoolWebsites' => \n  array (\n  " .
 			"  0 => 'demo.owncloud.org',\n    1 => 'owncloud.org',\n    2 => 'owncloud.com',\n  ),\n);\n";