Skip to content

Commit

Permalink
Merge pull request #4 from mybuilder/apcu-dns-cache
Browse files Browse the repository at this point in the history
Add APCu host DNS cache
  • Loading branch information
tomcant authored Nov 12, 2021
2 parents 527c4db + e7e6304 commit e14b5ef
Showing 1 changed file with 28 additions and 1 deletion.
29 changes: 28 additions & 1 deletion runtime/lib/Propel.php
Original file line number Diff line number Diff line change
Expand Up @@ -683,7 +683,7 @@ public static function initConnection($conparams, $name, $defaultClass = Propel:
}

try {
$con = new $classname($dsn, $user, $password, $driver_options);
$con = new $classname(self::resolveCachedDsnHost($dsn), $user, $password, $driver_options);
$con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$con->setAttribute(PropelPDO::PROPEL_ATTR_CONNECTION_NAME, $name);

Expand Down Expand Up @@ -944,6 +944,33 @@ public static function isInstancePoolingEnabled()
{
return self::$instancePoolingEnabled;
}

/**
* Within Lambda we are unable to easily cache DNS records as we do on conventional servers.
* As each request creates a new connection, the amount of DNS queries we perform can mount up.
* This adds an application-level cache for storing the resolved IP of the desired host (env: CACHE_PDO_HOST_DNS).
*/
private static function resolveCachedDsnHost(string $dsn, int $ttlInSeconds = 300): string
{
$hostname = \getenv('PROPEL_CACHE_PDO_HOST_DNS');

if (!$hostname || false === \strpos($dsn, $hostname)) {
return $dsn;
}

if (false === \function_exists('apcu_entry')) {
return $dsn;
}

$ip = \apcu_entry($hostname, function (string $name): string {
if (\class_exists('\MyBuilder\Bundle\LogBundle\Metrics')) {
\MyBuilder\Bundle\LogBundle\Metrics::increment('pdo.dns-cache.miss', ['host' => $name]);
}
return \gethostbyname($name);
}, $ttlInSeconds);

return \str_replace($hostname, $ip, $dsn);
}
}

// Since the Propel class is not a true singleton, this code cannot go into the __construct()
Expand Down

0 comments on commit e14b5ef

Please sign in to comment.