使用 Docker Compose 部署 Mix Space
Intro
此前已经讲过如何部署 Mix Space,现在有了更为方便的方法,分享一下。
这里只包括部署的内容,可到 此前 的文章中查看更为详细的内容。
安装 Docker
如果你的服务器在国内,建议使用阿里云的镜像加速,安装命令如下:
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
在国外,可以直接使用官方脚本安装:
curl -fsSL https://get.docker.com | bash -s docker
如果您成功安装了 Docker 和 Docker-Compose,可以通过以下命令查看版本:
docker -v
docker compose version
Mix Space Core 部署
- 拉取配置文件
cd && mkdir -p $HOME/mix-space/core && cd $_ # 拉取 docker-compose.yml 文件
wget https://fastly.jsdelivr.net/gh/mx-space/core@master/docker-compose.yml
- 创建环境变量
vi .env
- 填入以下内容后,按
ESC
键,输入:wq
保存退出
JWT_SECRET= #JWT 密钥:需要填写长度不小于 16 个字符,不大于 32 个字符的字符串,用于加密用户的 JWT,务必保存好自己的密钥,不要泄露给他人。
ALLOWED_ORIGINS= #被允许的域名:需要填写被允许的域名,通常是前端的域名,如果允许多个域名访问,用英文逗号,分隔。
ENCRYPT_ENABLE= #如果你确定要开启加密,将 false 改为 true,开启加密后,你需要在下方填写加密密钥。
ENCRYPT_KEY= #如果你不知道这是什么,那么不建议开启此功能,具体内容可参考 https://mx-space.js.org/usage/security.html
启动后端
docker compose up -d
前端部署
- 拉取配置文件
cd && mkdir -p $HOME/mix-space/core && cd $_ # 拉取 docker-compose.yml 文件
wget https://raw.githubusercontent.com/Innei/Shiro/main/docker-compose.yml
- 拉取环境变量,并更改内容
wget https://raw.githubusercontent.com/Innei/Shiro/main/.env.template .env
启动后端
docker compose up -d
Nginx 反向代理
将域名解析至服务器。
申请证书
curl https://get.acme.sh | sh; apt install socat -y || yum install socat -y; ~/.acme.sh/acme.sh --set-default-ca --server letsencrypt ~/.acme.sh/acme.sh --issue -d xxu.do --standalone -k ec-256 --force --insecure mkdir -p /etc/pki/xxu.do ~/.acme.sh/acme.sh --installcert -d xxu.do --key-file /etc/pki/xxu.do/server.key --fullchain-file /etc/pki/xxu.do/server.crt service postfix reload;service dovecot reload;service nginx reload #重载服务
设置反向代理:
vi /etc/nginx/nginx.conf
修改下面示例中的域名及证书路径,添加到配置文件中:
更新
进入 core 或是前段所在文件夹,然后
docker compose pull && docker compose up -d