mirror of
https://github.com/friendica/friendica
synced 2024-11-19 23:03:41 +00:00
Revert "Avoid double update runs"
This commit is contained in:
parent
c7702a4c7a
commit
a2ec9e676e
1 changed files with 57 additions and 69 deletions
|
@ -24,15 +24,19 @@ class Update
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$build = self::getBuild();
|
$build = Config::get('system', 'build');
|
||||||
$current = intval(DB_UPDATE_VERSION);
|
|
||||||
|
if (empty($build)) {
|
||||||
|
Config::set('system', 'build', DB_UPDATE_VERSION - 1);
|
||||||
|
$build = DB_UPDATE_VERSION - 1;
|
||||||
|
}
|
||||||
|
|
||||||
// We don't support upgrading from very old versions anymore
|
// We don't support upgrading from very old versions anymore
|
||||||
if ($build < NEW_UPDATE_ROUTINE_VERSION) {
|
if ($build < NEW_UPDATE_ROUTINE_VERSION) {
|
||||||
die('You try to update from a version prior to database version 1170. The direct upgrade path is not supported. Please update to version 3.5.4 before updating to this version.');
|
die('You try to update from a version prior to database version 1170. The direct upgrade path is not supported. Please update to version 3.5.4 before updating to this version.');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($build < $current ) {
|
if ($build < DB_UPDATE_VERSION) {
|
||||||
if ($via_worker) {
|
if ($via_worker) {
|
||||||
// Calling the database update directly via the worker enables us to perform database changes to the workerqueue table itself.
|
// Calling the database update directly via the worker enables us to perform database changes to the workerqueue table itself.
|
||||||
// This is a fallback, since normally the database update will be performed by a worker job.
|
// This is a fallback, since normally the database update will be performed by a worker job.
|
||||||
|
@ -64,26 +68,26 @@ class Update
|
||||||
Lock::release('dbupdate', true);
|
Lock::release('dbupdate', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$current = intval(DB_UPDATE_VERSION);
|
$build = Config::get('system', 'build');
|
||||||
$stored = self::getBuild();
|
|
||||||
|
|
||||||
if ($stored < $current || $force) {
|
if (empty($build) || ($build > DB_UPDATE_VERSION)) {
|
||||||
|
$build = DB_UPDATE_VERSION - 1;
|
||||||
|
Config::set('system', 'build', $build);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($build != DB_UPDATE_VERSION || $force) {
|
||||||
require_once 'update.php';
|
require_once 'update.php';
|
||||||
|
|
||||||
|
$stored = intval($build);
|
||||||
|
$current = intval(DB_UPDATE_VERSION);
|
||||||
|
if ($stored < $current || $force) {
|
||||||
Config::load('database');
|
Config::load('database');
|
||||||
|
|
||||||
Logger::log('Update from \'' . $stored . '\' to \'' . $current . '\' - starting', Logger::DEBUG);
|
Logger::log('Update from \'' . $stored . '\' to \'' . $current . '\' - starting', Logger::DEBUG);
|
||||||
|
|
||||||
// Compare the current structure with the defined structure
|
// Compare the current structure with the defined structure
|
||||||
// If the Lock is acquired, never release it automatically to avoid double updates
|
// If the Lock is acquired, never release it automatically to avoid double updates
|
||||||
if (Lock::acquire('dbupdate', 0, Cache::INFINITE)) {
|
if (Lock::acquire('dbupdate', 120, Cache::INFINITE)) {
|
||||||
|
|
||||||
// recheck again in case we accidentally spawned multiple updates
|
|
||||||
$stored = self::getBuild();
|
|
||||||
if ($stored >= $current) {
|
|
||||||
Lock::release('dbupdate');
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
// run the pre_update_nnnn functions in update.php
|
// run the pre_update_nnnn functions in update.php
|
||||||
for ($x = $stored + 1; $x <= $current; $x++) {
|
for ($x = $stored + 1; $x <= $current; $x++) {
|
||||||
|
@ -127,6 +131,7 @@ class Update
|
||||||
Lock::release('dbupdate');
|
Lock::release('dbupdate');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
@ -288,21 +293,4 @@ class Update
|
||||||
//try the logger
|
//try the logger
|
||||||
Logger::log("Database structure update successful.", Logger::TRACE);
|
Logger::log("Database structure update successful.", Logger::TRACE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the current build number of the instance
|
|
||||||
*
|
|
||||||
* @return int the build number
|
|
||||||
*/
|
|
||||||
private static function getBuild()
|
|
||||||
{
|
|
||||||
$build = Config::get('system', 'build');
|
|
||||||
|
|
||||||
if (empty($build) || ($build > DB_UPDATE_VERSION)) {
|
|
||||||
$build = DB_UPDATE_VERSION - 1;
|
|
||||||
Config::set('system', 'build', $build);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (is_int($build) ? intval($build) : DB_UPDATE_VERSION - 1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue