部署 Vue3 应用
构建
npm run build
上传到服务器
笔记喵这里使用的是 WSL 上传的:
scp -r "/mnt/c/Users/anie/Desktop/github/abc/dist" "[email protected]:/tmp"
使用 nginx
先把项目拷贝到 nginx 目录下:
sudo mv /tmp/dist /var/www/html/dist
创建 nginx 配置文件:$sudo vim /etc/nginx/sites-available/abc
,abc
随便取:
# web socket
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
server {
listen 443 ssl;
server_name example.com;
ssl_certificate example.com_bundle.crt;
ssl_certificate_key example.com.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_prefer_server_ciphers on;
location / {
root /var/www/html/dist;
index index.html;
try_files $uri $uri/ /index.html;
}
location /api/ {
include proxy_params;
client_max_body_size 10m;
client_body_buffer_size 128k;
proxy_pass http://127.0.0.1:8000;
}
location /api/chat/ws {
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
proxy_pass http://127.0.0.1:8000/api/chat/ws;
}
}
server {
listen 80;
server_name example.com;
return 301 https://$host$request_uri;
}
然后建立一个软链接:
ln -s /etc/nginx/sites-available/abc /etc/nginx/sites-enabled/abc
说明:如果需要使用 https,需要把你的证书拷贝到 /etc/nginx
目录下(省略其他文件),配置如上:
root@ubuntu:~$ tree /etc/nginx/
/etc/nginx/
├── conf.d
├── sites-available
│ ├── default
│ └── abc
├── sites-enabled
│ ├── default -> /etc/nginx/sites-available/default
│ └── abc -> /etc/nginx/sites-available/abc
├── example.com_bundle.crt #<---------证书
├── example.com.key #<---------