一:部署到服務(wù)器上
前提:nuxt是基于nodejs運(yùn)行的偎血,安裝node是第一步,因此確保已經(jīng)安裝 Node.js
(1) nuxt項(xiàng)目打包
詳細(xì)請(qǐng)移步nuxt官網(wǎng)
第一步、在本地 npm run build,會(huì)在.nuxt文件夾下生成dist文件;
第二步镀裤、把本地文件的.nuxt,static,package.json,nuxt.config.js,這四個(gè)文件夾放到服務(wù)器目錄文件下
比如我在服務(wù)器上創(chuàng)建了C:\inetpub\nuxt路徑卿樱。
第三步僚害、用cmd進(jìn)入目錄文件夾,安裝依賴
npm install -production
第四步繁调、運(yùn)行
npm start
此時(shí)運(yùn)行的是 http://localhost:1818;
目錄以及項(xiàng)目文件如下:
目錄及文件
此時(shí)項(xiàng)目在服務(wù)器的本地已經(jīng)可以訪問了萨蚕,但在外部網(wǎng)絡(luò)是無法進(jìn)行訪問的靶草。這時(shí)Nginx就可以出場了。
目的是通過域名訪問到nuxt服務(wù)(此處測試的域名為www.wfaceboss.top)
二:Nginx
(1) Nginx安裝
第一步岳遥、Nginx 的安裝步驟比較簡單奕翔,安裝在windows上推薦使用壓縮包的安裝方式,下載地址;(選擇穩(wěn)定版本)
第二步浩蓉、下載完成之后派继,進(jìn)行解壓可以看到如下文件結(jié)構(gòu)
第三步、雙擊nginx.exe 就啟動(dòng)了
在頁面輸入localhost妻往。出現(xiàn)如下界面則表示安裝成功互艾。默認(rèn)監(jiān)聽80端口號(hào)
第四步、若你的服務(wù)器上80端口被占用讯泣,則需要修改端口纫普,操作如下:(我這里是將80修改成81,注意修改的端口需要服務(wù)器后臺(tái)已經(jīng)開放)
修改nginx安裝目錄/conf/nginx.conf中的server配置
#user nobody;
worker_processes 4;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 40960;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
map $time_iso8601 $logdate {
'~^(?<ymd>\\d{4}-\\d{2}-\\d{2})' $ymd;
default 'date-not-found';
}
include vhosts/*.conf;
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
client_max_body_size 50m;
client_body_buffer_size 60k;
client_body_timeout 60;
client_header_buffer_size 64k;
client_header_timeout 60;
error_page 400 /error/400.html;
error_page 403 /error/403.html;
error_page 404 /error/404.html;
error_page 500 /error/500.html;
error_page 501 /error/501.html;
error_page 502 /error/502.html;
error_page 503 /error/503.html;
error_page 504 /error/504.html;
error_page 505 /error/505.html;
error_page 506 /error/506.html;
error_page 507 /error/507.html;
error_page 509 /error/509.html;
error_page 510 /error/510.html;
keepalive_requests 100;
large_client_header_buffers 4 64k;
reset_timedout_connection on;
send_timeout 60;
sendfile_max_chunk 512k;
server_names_hash_bucket_size 256;
// 主要就是這個(gè)好渠,不用看上面的(上面是默認(rèn)配置)
upstream nodenuxt {
server 127.0.0.1:3000; # nuxt 項(xiàng)目監(jiān)聽PC端端口
keepalive 64;
}
}
error_log "D:/Program Files/phpstudy_pro/WWW" crit;
worker_rlimit_nofile 100000;
(2)Nginx啟動(dòng)
在nginx根目錄下打開cmd命令窗口昨稼,啟動(dòng)Nginx
start nginx
www.wfaceboss.top_80.conf文件(配置線上網(wǎng)站的nginx)
server {
listen 80;
server_name www.wfaceboss.top;
root "路徑";
location / { // 主要是這里
proxy_pass http://nodenuxt;
}
location ~ \.php(.*)$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
include fastcgi_params;
}
}
其他命令
nginx -s reload //重新載入nginx(當(dāng)配置信息發(fā)生修改時(shí))
nginx -s quit //停止ngix
nginx -h 查看幫助信息
完成以上配置,當(dāng)你打開瀏覽器 輸入http://www.wfaceboss.top即可訪問到nuxt服務(wù)了拳锚。
注意:若是多次修改/conf/nginx.conf文件 后重啟nginx 假栓,在windows可能會(huì)出現(xiàn)多個(gè)nginx 進(jìn)程服務(wù),需要結(jié)束這些進(jìn)程霍掺,然后重啟方可解決匾荆。
通過上述的操作我們已經(jīng)實(shí)現(xiàn)用域名訪問nuxt服務(wù)了,但關(guān)閉服務(wù)器上nuxt運(yùn)行黑窗口時(shí)杆烁,服務(wù)就斷了牙丽,我們不能實(shí)時(shí)盯著他吧,因此就需要PM2進(jìn)行守護(hù)了兔魂。
三:pm2進(jìn)程管理
(1) pm2需要全局安裝
npm install -g pm2
(2) pm2啟動(dòng)nuxt項(xiàng)目(啟動(dòng)的是api)
--cd 到項(xiàng)目目錄
--啟動(dòng)
pm2 start ./node_modules/nuxt/bin/nuxt.js --name 項(xiàng)目名稱 (項(xiàng)目目錄的node_modules包)
// 如果是打包后上傳到服務(wù)器的
pm2 start ./server/index.js --name 項(xiàng)目名稱 (api入口文件)
注意:xxx是項(xiàng)目名稱烤芦,即package.json中的name
比如我當(dāng)前為:
pm2啟動(dòng)nuxt.png
(3) pm2其他命令
pm2 list
pm2 show 0 #查看進(jìn)程詳細(xì)信息,0為PM2進(jìn)程id
pm2 stop all #停止PM2列表中所有的進(jìn)程
pm2 stop 0 #停止PM2列表中進(jìn)程為0的進(jìn)程
pm2 reload all #重載PM2列表中所有的進(jìn)程
pm2 reload 0 #重載PM2列表中進(jìn)程為0的進(jìn)程
pm2 delete 0 #刪除PM2列表中進(jìn)程為0的進(jìn)程
pm2 delete all #刪除PM2列表中所有的進(jìn)程
原文鏈接:https://blog.csdn.net/java_zdc/article/details/116939719