1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 15:21:03 +01:00

Improve robustness of cluster version bookkeeping

Summary:
Ref T4292. Small fixes:

  - There was a bug with the //first// write, where we'd write 1 but expect 0. Fix this.
  - Narrow the window where we hold the `isWriting` lock: we don't need to wait for the client to finish.
  - Release the lock even if something throws.
  - Use a more useful variable name.

Test Plan:
  - Made new writes to a fresh cluster repository.
  - Made sequential writes.
  - Made concurrent writes.
  - Made good writes and bad writes.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T4292

Differential Revision: https://secure.phabricator.com/D15747
This commit is contained in:
epriestley 2016-04-18 08:16:22 -07:00
parent 595f203816
commit 368d2d1ddb
3 changed files with 31 additions and 17 deletions

View file

@ -21,22 +21,30 @@ final class DiffusionGitReceivePackSSHWorkflow extends DiffusionGitSSHWorkflow {
if ($this->shouldProxy()) { if ($this->shouldProxy()) {
$command = $this->getProxyCommand(); $command = $this->getProxyCommand();
$is_proxy = true; $did_synchronize = false;
} else { } else {
$command = csprintf('git-receive-pack %s', $repository->getLocalPath()); $command = csprintf('git-receive-pack %s', $repository->getLocalPath());
$is_proxy = false;
$did_synchronize = true;
$repository->synchronizeWorkingCopyBeforeWrite(); $repository->synchronizeWorkingCopyBeforeWrite();
} }
$command = PhabricatorDaemon::sudoCommandAsDaemonUser($command);
$future = id(new ExecFuture('%C', $command)) $caught = null;
->setEnv($this->getEnvironment()); try {
$err = $this->executeRepositoryCommand($command);
} catch (Exception $ex) {
$caught = $ex;
}
$err = $this->newPassthruCommand() // We've committed the write (or rejected it), so we can release the lock
->setIOChannel($this->getIOChannel()) // without waiting for the client to receive the acknowledgement.
->setCommandChannelFromExecFuture($future) if ($did_synchronize) {
->execute(); $repository->synchronizeWorkingCopyAfterWrite();
}
if ($caught) {
throw $caught;
}
if (!$err) { if (!$err) {
$repository->writeStatusMessage( $repository->writeStatusMessage(
@ -45,11 +53,20 @@ final class DiffusionGitReceivePackSSHWorkflow extends DiffusionGitSSHWorkflow {
$this->waitForGitClient(); $this->waitForGitClient();
} }
if (!$is_proxy) {
$repository->synchronizeWorkingCopyAfterWrite();
}
return $err; return $err;
} }
private function executeRepositoryCommand($command) {
$repository = $this->getRepository();
$command = PhabricatorDaemon::sudoCommandAsDaemonUser($command);
$future = id(new ExecFuture('%C', $command))
->setEnv($this->getEnvironment());
return $this->newPassthruCommand()
->setIOChannel($this->getIOChannel())
->setCommandChannelFromExecFuture($future)
->execute();
}
} }

View file

@ -2410,9 +2410,6 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
private function shouldEnableSynchronization() { private function shouldEnableSynchronization() {
// TODO: This mostly works, but isn't stable enough for production yet.
return false;
$device = AlmanacKeys::getLiveDevice(); $device = AlmanacKeys::getLiveDevice();
if (!$device) { if (!$device) {
return false; return false;

View file

@ -82,7 +82,7 @@ final class PhabricatorRepositoryWorkingCopyVersion
$table, $table,
$repository_phid, $repository_phid,
$device_phid, $device_phid,
1, 0,
1); 1);
} }