我在为 Azure 应用服务网站执行其他命令时遇到困难。
我已经使用 kuduscript --php -y
生成了一个基本的 PHP 部署脚本。
每当我从本地 git 存储库推送时,脚本都会执行,但在第一步失败,验证是否安装了 Composer。
当我通过 SSH 连接到服务器并执行 composer --version
时,它返回版本 2.0.12,因为这是我全局安装的版本。我也尝试将 composer.phar 文件添加到我的项目的根目录,但错误仍然存在。
我还注意到,调用诸如 php bin/console cache:clear
之类的 php 脚本会返回 (php) command not found
,但是当我直接在服务器上执行相同的命令时,这也能正常工作。然而 Yarn 命令在 Kudu 脚本中工作正常。
我的 deploy.sh 如下所示:
#!/bin/bash
# ----------------------
# KUDU Deployment Script
# Version: 1.0.17
# ----------------------
# Helpers
# -------
exitWithMessageOnError () {
if [ ! $? -eq 0 ]; then
echo "An error has occurred during web site deployment."
echo $1
exit 1
fi
}
# Prerequisites
# -------------
# Verify node.js installed
hash node 2>/dev/null
exitWithMessageOnError "Missing node.js executable, please install node.js, if already installed make sure it can be reached from current environment."
# Setup
# -----
SCRIPT_DIR="${BASH_SOURCE[0]%\\*}"
SCRIPT_DIR="${SCRIPT_DIR%/*}"
ARTIFACTS=$SCRIPT_DIR/../artifacts
KUDU_SYNC_CMD=${KUDU_SYNC_CMD//\"}
DISABLE_HUGO_BUILD=true
if [[ ! -n "$DEPLOYMENT_SOURCE" ]]; then
DEPLOYMENT_SOURCE=$SCRIPT_DIR
fi
if [[ ! -n "$NEXT_MANIFEST_PATH" ]]; then
NEXT_MANIFEST_PATH=$ARTIFACTS/manifest
if [[ ! -n "$PREVIOUS_MANIFEST_PATH" ]]; then
PREVIOUS_MANIFEST_PATH=$NEXT_MANIFEST_PATH
fi
fi
if [[ ! -n "$DEPLOYMENT_TARGET" ]]; then
DEPLOYMENT_TARGET=$ARTIFACTS/wwwroot
else
KUDU_SERVICE=true
fi
if [[ ! -n "$KUDU_SYNC_CMD" ]]; then
# Install kudu sync
echo Installing Kudu Sync
npm install kudusync -g --silent
exitWithMessageOnError "npm failed"
if [[ ! -n "$KUDU_SERVICE" ]]; then
# In case we are running locally this is the correct location of kuduSync
KUDU_SYNC_CMD=kuduSync
else
# In case we are running on kudu service this is the correct location of kuduSync
KUDU_SYNC_CMD=$APPDATA/npm/node_modules/kuduSync/bin/kuduSync
fi
fi
# PHP Helpers
# -----------
initializeDeploymentConfig() {
if [ ! -e "$COMPOSER_ARGS" ]; then
COMPOSER_ARGS="--no-interaction --prefer-dist --optimize-autoloader --no-progress --no-dev --verbose"
echo "No COMPOSER_ARGS variable declared in App Settings, using the default settings"
else
echo "Using COMPOSER_ARGS variable declared in App Setting"
fi
echo "Composer settings: $COMPOSER_ARGS"
}
##################################################################################################################################
# Deployment
# ----------
echo PHP deployment
# 1. KuduSync
if [[ "$IN_PLACE_DEPLOYMENT" -ne "1" ]]; then
"$KUDU_SYNC_CMD" -v 50 -f "$DEPLOYMENT_SOURCE" -t "$DEPLOYMENT_TARGET" -n "$NEXT_MANIFEST_PATH" -p "$PREVIOUS_MANIFEST_PATH" -i ".git;.hg;.deployment;deploy.sh"
exitWithMessageOnError "Kudu Sync failed"
fi
# 2. Verify composer installed
hash composer 2>/dev/null
exitWithMessageOnError "Missing composer executable"
# 3. Initialize Composer Config
initializeDeploymentConfig
# 4. Use composer
echo "$DEPLOYMENT_TARGET"
if [ -e "$DEPLOYMENT_TARGET/composer.json" ]; then
php -v
echo "Found composer.json"
pushd "$DEPLOYMENT_TARGET"
composer install $COMPOSER_ARGS
exitWithMessageOnError "Composer install failed"
popd
fi
# 5. Install and build yarn
if [ -e "$DEPLOYMENT_TARGET/package.json" ]; then
echo "Found package.json"
pushd "$DEPLOYMENT_TARGET"
yarn install
exitWithMessageOnError "Yarn install failed"
yarn build
exitWithMessageOnError "Yarn build failed"
popd
fi
##################################################################################################################################
echo "Finished successfully."
在搜索了几个小时没有任何成功之后,我真的希望这里的任何人都对此提出建议/解决方案。
亲切的问候,
凯文