diff options
author | Joas Schilling <nickvergessen@owncloud.com> | 2016-05-20 11:14:47 +0200 |
---|---|---|
committer | Joas Schilling <nickvergessen@owncloud.com> | 2016-05-21 01:59:25 +0200 |
commit | 92c21fd6f456d083af8fa64a713c9a0e8d59d1c1 (patch) | |
tree | 2e8bcaabea3e9671127880ccc0eda63ac81ae5a9 | |
parent | d0a2fa050694232554242c6344439915f3f09d12 (diff) | |
download | nextcloud-server-92c21fd6f456d083af8fa64a713c9a0e8d59d1c1.tar.gz nextcloud-server-92c21fd6f456d083af8fa64a713c9a0e8d59d1c1.zip |
Do not lock the cron anymore so we can have multiple workers
-rw-r--r-- | config/config.sample.php | 11 | ||||
-rw-r--r-- | cron.php | 27 |
2 files changed, 0 insertions, 38 deletions
diff --git a/config/config.sample.php b/config/config.sample.php index a2bc8e4343c..f3c1845c5c2 100644 --- a/config/config.sample.php +++ b/config/config.sample.php @@ -615,17 +615,6 @@ $CONFIG = array( 'cron_log' => true, /** - * Location of the lock file for cron executions can be specified here. - * Default is within the tmp directory. The file is named in the following way: - * owncloud-server-$INSTANCEID-cron.lock - * where $INSTANCEID is the string specified in the ``instanceid`` field. - * Because the cron lock file is accessed at regular intervals, it may prevent - * enabled disk drives from spinning down. A different location for this file - * can solve such issues. - */ -'cron.lockfile.location' => '', - -/** * Enables log rotation and limits the total size of logfiles. The default is 0, * or no rotation. Specify a size in bytes, for example 104857600 (100 megabytes * = 100 * 1024 * 1024 bytes). A new logfile is created with a new name when the @@ -100,34 +100,11 @@ try { } } - $instanceId = $config->getSystemValue('instanceid'); - $lockFileName = 'owncloud-server-' . $instanceId . '-cron.lock'; - $lockDirectory = $config->getSystemValue('cron.lockfile.location', sys_get_temp_dir()); - $lockDirectory = rtrim($lockDirectory, '\\/'); - $lockFile = $lockDirectory . '/' . $lockFileName; - - if (!file_exists($lockFile)) { - touch($lockFile); - } - // We call ownCloud from the CLI (aka cron) if ($appMode != 'cron') { \OCP\BackgroundJob::setExecutionType('cron'); } - // open the file and try to lock it. If it is not locked, the background - // job can be executed, otherwise another instance is already running - $fp = fopen($lockFile, 'w'); - $isLocked = flock($fp, LOCK_EX|LOCK_NB, $wouldBlock); - - // check if backgroundjobs is still running. The wouldBlock check is - // needed on systems with advisory locking, see - // http://php.net/manual/en/function.flock.php#45464 - if (!$isLocked || $wouldBlock) { - echo "Another instance of cron.php is still running!" . PHP_EOL; - exit(1); - } - // Work $jobList = \OC::$server->getJobList(); @@ -155,10 +132,6 @@ try { } } - // unlock the file - flock($fp, LOCK_UN); - fclose($fp); - } else { // We call cron.php from some website if ($appMode == 'cron') { |