kopia lustrzana https://github.com/bugout-dev/moonstream
Merge pull request #695 from bugout-dev/systems-deploy
Deployment upgrades to work with systemspull/696/head
commit
eadb8aa8ac
|
@ -23,11 +23,9 @@ PIP="${PYTHON_ENV_DIR}/bin/pip"
|
||||||
SCRIPT_DIR="$(realpath $(dirname $0))"
|
SCRIPT_DIR="$(realpath $(dirname $0))"
|
||||||
SECRETS_DIR="${SECRETS_DIR:-/home/ubuntu/moonstream-secrets}"
|
SECRETS_DIR="${SECRETS_DIR:-/home/ubuntu/moonstream-secrets}"
|
||||||
PARAMETERS_ENV_PATH="${SECRETS_DIR}/app.env"
|
PARAMETERS_ENV_PATH="${SECRETS_DIR}/app.env"
|
||||||
AWS_SSM_PARAMETER_PATH="${AWS_SSM_PARAMETER_PATH:-/moonstream/prod}"
|
|
||||||
PARAMETERS_SCRIPT="${SCRIPT_DIR}/parameters.py"
|
|
||||||
|
|
||||||
# API server service file
|
# API server service file
|
||||||
SERVICE_FILE="${SCRIPT_DIR}/moonstreamapi.service"
|
MOONSTREAM_API_SERVICE_FILE="${SCRIPT_DIR}/moonstream.service"
|
||||||
|
|
||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
|
@ -41,12 +39,6 @@ echo
|
||||||
echo -e "${PREFIX_INFO} Installing Python dependencies"
|
echo -e "${PREFIX_INFO} Installing Python dependencies"
|
||||||
"${PIP}" install -e "${APP_BACKEND_DIR}/"
|
"${PIP}" install -e "${APP_BACKEND_DIR}/"
|
||||||
|
|
||||||
echo
|
|
||||||
echo
|
|
||||||
echo -e "${PREFIX_INFO} Retrieving deployment parameters"
|
|
||||||
mkdir -p "${SECRETS_DIR}"
|
|
||||||
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" "${PYTHON}" "${PARAMETERS_SCRIPT}" "${AWS_SSM_PARAMETER_PATH}" -o "${PARAMETERS_ENV_PATH}"
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
echo -e "${PREFIX_INFO} Install checkenv"
|
echo -e "${PREFIX_INFO} Install checkenv"
|
||||||
|
@ -55,13 +47,12 @@ HOME=/root /usr/local/go/bin/go install github.com/bugout-dev/checkenv@latest
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
echo -e "${PREFIX_INFO} Retrieving addition deployment parameters"
|
echo -e "${PREFIX_INFO} Retrieving addition deployment parameters"
|
||||||
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" /root/go/bin/checkenv show aws_ssm+Product:moonstream >> "${PARAMETERS_ENV_PATH}"
|
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" /root/go/bin/checkenv show aws_ssm+moonstream:true > "${PARAMETERS_ENV_PATH}"
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
echo -e "${PREFIX_INFO} Replacing existing Moonstream API service definition with ${SERVICE_FILE}"
|
echo -e "${PREFIX_INFO} Replacing existing Moonstream API service definition with ${MOONSTREAM_API_SERVICE_FILE}"
|
||||||
chmod 644 "${SERVICE_FILE}"
|
chmod 644 "${SCRIPT_DIR}/${MOONSTREAM_API_SERVICE_FILE}"
|
||||||
cp "${SERVICE_FILE}" /etc/systemd/system/moonstreamapi.service
|
cp "${SCRIPT_DIR}/${MOONSTREAM_API_SERVICE_FILE}" "/home/ubuntu/.config/systemd/user/${MOONSTREAM_API_SERVICE_FILE}"
|
||||||
systemctl daemon-reload
|
XDG_RUNTIME_DIR="/run/user/1000" systemctl --user daemon-reload
|
||||||
systemctl restart moonstreamapi.service
|
XDG_RUNTIME_DIR="/run/user/1000" systemctl --user restart "${MOONSTREAM_API_SERVICE_FILE}"
|
||||||
systemctl status moonstreamapi.service
|
|
||||||
|
|
|
@ -1,14 +1,16 @@
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=moonstreamapi-service
|
Description=moonstreamapi-service
|
||||||
After=network.target
|
After=network.target
|
||||||
|
StartLimitIntervalSec=300
|
||||||
|
StartLimitBurst=3
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
User=ubuntu
|
|
||||||
Group=www-data
|
|
||||||
WorkingDirectory=/home/ubuntu/moonstream/backend
|
WorkingDirectory=/home/ubuntu/moonstream/backend
|
||||||
EnvironmentFile=/home/ubuntu/moonstream-secrets/app.env
|
EnvironmentFile=/home/ubuntu/moonstream-secrets/app.env
|
||||||
|
Restart=on-failure
|
||||||
|
RestartSec=15s
|
||||||
ExecStart=/home/ubuntu/moonstream-env/bin/uvicorn --proxy-headers --forwarded-allow-ips='127.0.0.1' --host 127.0.0.1 --port 7481 --workers 8 moonstreamapi.api:app
|
ExecStart=/home/ubuntu/moonstream-env/bin/uvicorn --proxy-headers --forwarded-allow-ips='127.0.0.1' --host 127.0.0.1 --port 7481 --workers 8 moonstreamapi.api:app
|
||||||
SyslogIdentifier=moonstreamapi
|
SyslogIdentifier=moonstream
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
|
@ -22,9 +22,7 @@ PYTHON="${PYTHON_ENV_DIR}/bin/python"
|
||||||
PIP="${PYTHON_ENV_DIR}/bin/pip"
|
PIP="${PYTHON_ENV_DIR}/bin/pip"
|
||||||
SECRETS_DIR="${SECRETS_DIR:-/home/ubuntu/moonstream-secrets}"
|
SECRETS_DIR="${SECRETS_DIR:-/home/ubuntu/moonstream-secrets}"
|
||||||
PARAMETERS_ENV_PATH="${SECRETS_DIR}/app.env"
|
PARAMETERS_ENV_PATH="${SECRETS_DIR}/app.env"
|
||||||
AWS_SSM_PARAMETER_PATH="${AWS_SSM_PARAMETER_PATH:-/moonstream/prod}"
|
|
||||||
SCRIPT_DIR="$(realpath $(dirname $0))"
|
SCRIPT_DIR="$(realpath $(dirname $0))"
|
||||||
PARAMETERS_SCRIPT="${SCRIPT_DIR}/parameters.py"
|
|
||||||
|
|
||||||
# Service files
|
# Service files
|
||||||
MOONCRAWL_SERVICE_FILE="mooncrawl.service"
|
MOONCRAWL_SERVICE_FILE="mooncrawl.service"
|
||||||
|
@ -86,12 +84,6 @@ echo
|
||||||
echo -e "${PREFIX_INFO} Installing Python dependencies"
|
echo -e "${PREFIX_INFO} Installing Python dependencies"
|
||||||
"${PIP}" install -e "${APP_CRAWLERS_DIR}/mooncrawl/"
|
"${PIP}" install -e "${APP_CRAWLERS_DIR}/mooncrawl/"
|
||||||
|
|
||||||
echo
|
|
||||||
echo
|
|
||||||
echo -e "${PREFIX_INFO} Retrieving deployment parameters"
|
|
||||||
mkdir -p "${SECRETS_DIR}"
|
|
||||||
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" "${PYTHON}" "${PARAMETERS_SCRIPT}" extract -p "${AWS_SSM_PARAMETER_PATH}" -o "${PARAMETERS_ENV_PATH}"
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
echo -e "${PREFIX_INFO} Install checkenv"
|
echo -e "${PREFIX_INFO} Install checkenv"
|
||||||
|
@ -100,7 +92,7 @@ HOME=/root /usr/local/go/bin/go install github.com/bugout-dev/checkenv@latest
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
echo -e "${PREFIX_INFO} Retrieving addition deployment parameters"
|
echo -e "${PREFIX_INFO} Retrieving addition deployment parameters"
|
||||||
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" /root/go/bin/checkenv show aws_ssm+Product:moonstream >> "${PARAMETERS_ENV_PATH}"
|
AWS_DEFAULT_REGION="${AWS_DEFAULT_REGION}" /root/go/bin/checkenv show aws_ssm+moonstream:true > "${PARAMETERS_ENV_PATH}"
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo
|
echo
|
||||||
|
|
Ładowanie…
Reference in New Issue