67 lines
1.9 KiB
Bash
67 lines
1.9 KiB
Bash
#!/bin/bash
|
|
|
|
# 检查参数
|
|
if [ -z "$1" ]; then
|
|
echo "Usage: $0 <env_file_path>"
|
|
exit 1
|
|
fi
|
|
|
|
ENV_FILE=$1
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
echo "Nginx path: $SCRIPT_DIR"
|
|
|
|
# 检查环境变量文件是否存在
|
|
if [ ! -f "$ENV_FILE" ]; then
|
|
echo "Error: Environment file $ENV_FILE not found"
|
|
exit 1
|
|
fi
|
|
|
|
# 读取环境变量
|
|
source "$ENV_FILE"
|
|
|
|
# 配置Nginx
|
|
configure_nginx() {
|
|
echo "Configuring Nginx..."
|
|
|
|
NGINX_TEMPLATE="$SCRIPT_DIR/default"
|
|
echo "reading $NGINX_TEMPLATE ..."
|
|
TEMP_NGINX=$(mktemp)
|
|
|
|
# 读取模板并替换变量
|
|
while IFS= read -r line || [ -n "$line" ]; do
|
|
# 替换server_name
|
|
if [[ $line =~ ^[[:space:]]*server_name[[:space:]]+ ]]; then
|
|
echo " server_name $NGINX_SERVER_NAME www.$NGINX_SERVER_NAME;"
|
|
# 替换SSL证书路径
|
|
elif [[ $line =~ ^[[:space:]]*ssl_certificate[[:space:]]+ ]]; then
|
|
echo " ssl_certificate $NGINX_SSL_CERT;"
|
|
# 替换SSL密钥路径
|
|
elif [[ $line =~ ^[[:space:]]*ssl_certificate_key[[:space:]]+ ]]; then
|
|
echo " ssl_certificate_key $NGINX_SSL_KEY;"
|
|
# 精确匹配前端构建路径设置行
|
|
elif [[ $line =~ ^[[:space:]]*set[[:space:]]+\$frontend_build_root[[:space:]]+ ]]; then
|
|
echo " set \$frontend_build_root $NGINX_FRONTEND_ROOT;"
|
|
# 简单替换端口号
|
|
elif [[ $line =~ localhost:3001 ]]; then
|
|
echo "${line/localhost:3001/localhost:$BACKEND_PORT}"
|
|
else
|
|
echo "$line"
|
|
fi
|
|
done < "$NGINX_TEMPLATE" > "$TEMP_NGINX"
|
|
|
|
# 复制配置文件到目标位置
|
|
cp "$TEMP_NGINX" /etc/nginx/sites-available/
|
|
# cp "$TEMP_NGINX" default
|
|
rm "$TEMP_NGINX"
|
|
}
|
|
|
|
# 执行配置
|
|
configure_nginx
|
|
|
|
# # 测试Nginx配置
|
|
cp nginx.conf /etc/nginx
|
|
nginx -t
|
|
|
|
/etc/init.d/nginx restart
|
|
|
|
echo "Nginx configuration completed." |