后端部署可以查看:GitHub Actions & Docker实现自动化部署 | Jin’s Blog (isjinhu.github.io)
Docker + Nginx部署前端项目
此处省略Docker安装步骤。
1
| sudo docker run --rm hello-world # 使用该命令可以测试docker是否安装成功
|
Step 1: 拉取Nginx镜像
1
| docker pull nginx # 拉取镜像,没有指定版本会默认下载最新
|
Step 2: 创建挂载目录
1 2 3 4 5 6
| # 注意当前路径切换 mkdir -p nginx/html mkdir -p nginx/logs mkdir -p nginx/conf cd nginx chomd 777 html logs conf
|
Step 3: 启动一个不挂载的容器
1
| docker run -d --name nginx -p 1000:80 nginx
|
--name nginx
:指定容器名称
-p 1000:80
映射端口(宿主机:容器)
- 这里可以自选端口,使用
lsof -i:1000
查看端口是否被占用
-d
守护进程运行
Step 4: 拷贝容器内默认配置
1 2 3
| docker cp nginx:/etc/nginx/nginx.conf nginx/conf/nginx.conf docker cp nginx:/etc/nginx/conf.d nginx/conf/conf.d docker cp nginx:/usr/share/nginx/html nginx/
|
Step 5: 停止、删除容器
1 2 3
| docker stop nginx # 停止容器 docker rm nginx # 删除容器 docker ps -a # 查看所有容器
|
Step 6: 部署前端项目
Step 7: 运行镜像,其中-p指定对应的端口映射。
1 2 3 4 5 6 7 8 9
| docker run \ -p 1000:80 \ -p 1001:1001 \ --name nginx \ -v /home/ubuntu/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \ -v /home/ubuntu/nginx/conf/conf.d:/etc/nginx/conf.d \ -v /home/ubuntu/nginx/logs:/var/log/nginx \ -v /home/ubuntu/nginx/html:/usr/share/nginx/html \ -d nginx:latest
|