我试图通过apache在Solaris上运行Phabricator。该网站正在运行,但所有cli脚本都没有。例如,phd
。
第一个问题是,它没有将参数传递给它调用的underling manage-daemons.php
脚本。查看phd
文件,这并不让我感到惊讶:
$> cat phd
../scripts/daemon/manage_daemons.php
现在,鉴于我的默认shell是bash
,这不会传递我的参数。为此,我修改了脚本:
#! /bin/bash
../scripts/daemon/manage_daemons.php $*
现在这将传递参数,但它现在无法通过相对路径找到它需要的转换脚本:
./phd start
Preparing to launch daemons.
NOTE: Logs will appear in '/var/tmp/phd/log/daemons.log'.
Launching daemon "PhabricatorRepositoryPullLocalDaemon".
[2014-05-09 19:29:59] EXCEPTION: (CommandException) Command failed with error #127!
COMMAND
exec ./phd-daemon 'PhabricatorRepositoryPullLocalDaemon' --daemonize --log='/var/tmp/phd/log/daemons.log' --phd='/var/tmp/phd/pid'
STDOUT
(empty)
STDERR
./phd-daemon: line 1: launch_daemon.php: not found
at [/XXX/XXX/libphutil/src/future/exec/ExecFuture.php:398]
#0 ExecFuture::resolvex() called at [/XXX/XXX/phabricator/src/applications/daemon/management/PhabricatorDaemonManagementWorkflow.php:167]
#1 PhabricatorDaemonManagementWorkflow::launchDaemon(PhabricatorRepositoryPullLocalDaemon, Array , false) called at [/XXX/XXX/phabricator/src/applications/daemon/management/PhabricatorDaemonManagementWorkflow.php:246]
#2 PhabricatorDaemonManagementWorkflow::executeStartCommand() called at [/XXX/XXX/phabricator/src/applications/daemon/management/PhabricatorDaemonManagementStartWorkflow.php:18]
#3 PhabricatorDaemonManagementStartWorkflow::execute(Object PhutilArgumentParser) called at [/XXX/XXX/libphutil/src/parser/argument/PhutilArgumentParser.php:396]
#4 PhutilArgumentParser::parseWorkflowsFull(Array of size 9 starting with: { 0 => Object PhabricatorDaemonManagementListWorkflow }) called at [/XXX/XXX/libphutil/src/parser/argument/PhutilArgumentParser.php:292]
#5 PhutilArgumentParser::parseWorkflows(Array of size 9 starting with: { 0 => Object PhabricatorDaemonManagementListWorkflow }) called at [/XXX/XXX/phabricator/scripts/daemon/manage_daemons.php:30]
注意我使用XXX
模糊了我的路径,因为它们会泄露敏感信息。
现在,显然我不应该修改这些脚本。这表明某些先决条件未正确设置。
我很清楚,Phabricator正在对我的设置做出一些(大胆的)假设。但我不太确定是什么......?
答案 0 :(得分:1)
这些应该是符号链接。例如,如果你看看" phd"在GitHub的存储库中,您可以看到文件类型是"符号链接":
https://github.com/facebook/phabricator/blob/master/bin/phd
您环境中的某些内容错误地将符号链接转换为普通文件。我不知道任何可能导致这种情况的Git配置,尽管可能存在某些问题。我发现这种情况的一种情况是克隆工作副本,然后使用rsync
之类的东西复制而没有适当的标记来保留符号链接。