mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-12 07:41:04 +01:00
Stop using process/filesystem-based checks to determine if daemons are running
Summary: We currently check if daemons are running using the filesystem and process list. These checks reach the wrong result for a lot of users because their webservers can't read the filesystem or process list. They also reach the wrong result for daemons running on other machines. Instead, query the active daemon list to see if daemons are running. This should be significantly more reliable. (We didn't do this before because the running daemon list mechanism didn't exist when the check was written, and at the time it was more complex than doing a simple filesystem/process list thing.) Test Plan: Viewed `/repositories/` with and without daemons running, saw appropriate warning or lack of warning. Reviewers: btrahan Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D6722
This commit is contained in:
parent
262475d151
commit
a0f0ba6acd
2 changed files with 28 additions and 26 deletions
|
@ -8,6 +8,7 @@ final class PhabricatorDaemonLogQuery
|
||||||
|
|
||||||
private $ids;
|
private $ids;
|
||||||
private $status = self::STATUS_ALL;
|
private $status = self::STATUS_ALL;
|
||||||
|
private $daemonClasses;
|
||||||
|
|
||||||
public static function getTimeUntilUnknown() {
|
public static function getTimeUntilUnknown() {
|
||||||
return 3 * PhutilDaemonOverseer::HEARTBEAT_WAIT;
|
return 3 * PhutilDaemonOverseer::HEARTBEAT_WAIT;
|
||||||
|
@ -27,6 +28,11 @@ final class PhabricatorDaemonLogQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withDaemonClasses(array $classes) {
|
||||||
|
$this->daemonClasses = $classes;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function loadPage() {
|
public function loadPage() {
|
||||||
$table = new PhabricatorDaemonLog();
|
$table = new PhabricatorDaemonLog();
|
||||||
$conn_r = $table->establishConnection('r');
|
$conn_r = $table->establishConnection('r');
|
||||||
|
@ -109,6 +115,13 @@ final class PhabricatorDaemonLogQuery
|
||||||
$this->getStatusConstants());
|
$this->getStatusConstants());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->daemonClasses) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'daemon IN (%Ls)',
|
||||||
|
$this->daemonClasses);
|
||||||
|
}
|
||||||
|
|
||||||
$where[] = $this->buildPagingClause($conn_r);
|
$where[] = $this->buildPagingClause($conn_r);
|
||||||
return $this->formatWhereClause($where);
|
return $this->formatWhereClause($where);
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,15 +22,14 @@ abstract class PhabricatorRepositoryController extends PhabricatorController {
|
||||||
}
|
}
|
||||||
|
|
||||||
private function isPullDaemonRunning() {
|
private function isPullDaemonRunning() {
|
||||||
// TODO: This is yuck, fix it.
|
$daemons = id(new PhabricatorDaemonLogQuery())
|
||||||
$control = new PhabricatorDaemonManagementListWorkflow();
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
||||||
$daemons = $control->loadRunningDaemons();
|
->withStatus(PhabricatorDaemonLogQuery::STATUS_ALIVE)
|
||||||
foreach ($daemons as $daemon) {
|
->withDaemonClasses(array('PhabricatorRepositoryPullLocalDaemon'))
|
||||||
if ($daemon->isRunning() &&
|
->setLimit(1)
|
||||||
$daemon->getName() == 'PhabricatorRepositoryPullLocalDaemon')
|
->execute();
|
||||||
return true;
|
|
||||||
}
|
return (bool)$daemons;
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function renderDaemonNotice() {
|
protected function renderDaemonNotice() {
|
||||||
|
@ -47,24 +46,14 @@ abstract class PhabricatorRepositoryController extends PhabricatorController {
|
||||||
"repositories. For instructions on starting the daemon, see %s.",
|
"repositories. For instructions on starting the daemon, see %s.",
|
||||||
phutil_tag('strong', array(), $documentation));
|
phutil_tag('strong', array(), $documentation));
|
||||||
|
|
||||||
try {
|
|
||||||
$daemon_running = $this->isPullDaemonRunning();
|
$daemon_running = $this->isPullDaemonRunning();
|
||||||
if ($daemon_running) {
|
if ($daemon_running) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
$title = "Repository Daemon Not Running";
|
$title = "Repository Daemon Not Running";
|
||||||
$message = hsprintf(
|
$message = hsprintf(
|
||||||
"<p>The repository daemon is not running on this machine. %s</p>",
|
"<p>The repository daemon is not running. %s</p>",
|
||||||
$common);
|
$common);
|
||||||
} catch (Exception $ex) {
|
|
||||||
$title = "Unable To Verify Repository Daemon";
|
|
||||||
$message = hsprintf(
|
|
||||||
"<p>Unable to determine if the repository daemon is running on this ".
|
|
||||||
"machine. %s</p>".
|
|
||||||
"<p><strong>Exception:</strong> %s</p>",
|
|
||||||
$common,
|
|
||||||
$ex->getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
$view = new AphrontErrorView();
|
$view = new AphrontErrorView();
|
||||||
$view->setSeverity(AphrontErrorView::SEVERITY_WARNING);
|
$view->setSeverity(AphrontErrorView::SEVERITY_WARNING);
|
||||||
|
|
Loading…
Reference in a new issue