若依部署Nginx和Tomcat全過程
Nginx部署
第一步:打包
# 構(gòu)建測(cè)試環(huán)境 npm run build:stage # 構(gòu)建生產(chǎn)環(huán)境 npm run build:prod
第二步:將生成的dist文件 中的
拉到
第三步:配置nginx.conf
#user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; location / { index index.html; # 這里的配置 是防止 刷新后 找不到路徑 try_files $uri $uri/ @router; } # 這里的配置 是防止 刷新后 找不到路徑 location @router { rewrite ^.*$ /index.html last; } # 只寫了 生產(chǎn) 環(huán)境 location /prod-api/{ proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header REMOTE-HOST $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://localhost:8080/; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
后端部署
可以直接打成jar包,雙擊或者命令運(yùn)行
Tomcat部署
第一步:前端打包
# 構(gòu)建測(cè)試環(huán)境 npm run build:stage # 構(gòu)建生產(chǎn)環(huán)境 npm run build:prod
第二步:拉到webapps
第三步:訪問測(cè)試
訪問:http://localhost:8080/dist/
可以看到已經(jīng) 可以訪問 若依的頁面了
問題:一直等待
解決方法
將靜態(tài)文件拉到webapps下面
效果
第四步:后端打包war
maven打包
或者去Maven本地倉庫
第五步:放在webapps下面
第六步:?jiǎn)?dòng)tomcat看效果 訪問:http://localhost:8080/ruoyi-admin/
訪問:http://localhost:8080/dist 前后端無法通信
可以清楚看到驗(yàn)證碼獲取不到,說明前后端無法通信
解決方法 將原本的war包名字修改掉
以為前端訪問的是prod-api這個(gè)請(qǐng)求路徑
或者在打包前修改
測(cè)試環(huán)境:
或者
后端:
第七步:重啟tomcat
可以正常訪問了
出現(xiàn)問題:點(diǎn)擊刷新404
問題出現(xiàn)在,若依采用的vue中的單頁面,頁面的變換是根據(jù)路由(routes)來變換的,在點(diǎn)擊刷新時(shí)走的tomcat的目錄路徑,所以404
解決方案
第一步:前端打包時(shí)設(shè)置路由
export default new Router({ mode: 'history', // 去掉url中的# base: '/apps/', // -----------設(shè)置這里 和 前端 打包后的包名一直,不一致 等打包成功修改包名 scrollBehavior: () => ({ y: 0 }), routes: constantRoutes })
第二步:添加文件
在項(xiàng)目中添加WEB-INF文件夾,并在WEB-INF文件下創(chuàng)建web.xml
添加如下配置
<?xml version="1.0" encoding="ISO-8859-1"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0" metadata-complete="true"> <display-name>webapp</display-name> <description> webapp </description> <error-page> <error-code>404</error-code> <location>/index.html</location> </error-page> </web-app>
重啟后即可
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
nginx+lua(openresty)實(shí)現(xiàn)黑/白名單權(quán)限控制的示例
本文介紹了如何使用Openresty進(jìn)行權(quán)限控制和灰度發(fā)布,具體通過定時(shí)器定期更新黑名單數(shù)據(jù),進(jìn)行用戶過濾和權(quán)限管控,具有一定的參考價(jià)值,感興趣的可以了解一下2024-09-09Nginx配置多個(gè)訪問路徑的實(shí)現(xiàn)
本文主要介紹了Nginx配置多個(gè)訪問路徑的實(shí)現(xiàn),Nginx通過配置多個(gè)service就可以實(shí)現(xiàn)多訪問路徑,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10Nginx服務(wù)器設(shè)置網(wǎng)站驗(yàn)證訪問的方法
這篇文章主要介紹了Nginx服務(wù)器設(shè)置網(wǎng)站驗(yàn)證訪問的方法,通過設(shè)置密碼來要求登錄網(wǎng)站目錄的用戶進(jìn)行驗(yàn)證,需要的朋友可以參考下2015-07-07nginx鏡像構(gòu)建的知識(shí)點(diǎn)及方法步驟詳解
這篇文章主要為大家介紹了nginx鏡像構(gòu)建的知識(shí)點(diǎn)詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Nginx限制搜索引擎爬蟲頻率、禁止屏蔽網(wǎng)絡(luò)爬蟲配置示例
這篇文章主要介紹了Nginx限制搜索引擎爬蟲頻率、禁止屏蔽網(wǎng)絡(luò)爬蟲配置示例,限制爬蟲頻率用于一些無良爬蟲,禁止爬蟲用于一些不需要收錄的網(wǎng)站,需要的朋友可以參考下2014-07-07Nginx配置文件(nginx.conf)配置詳解(總結(jié))
本篇文章主要介紹了Nginx配置文件(nginx.conf)配置詳解,這對(duì)初學(xué)者有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12詳解Nginx服務(wù)器的配置中開啟文件Gzip壓縮的方法
這篇文章主要介紹了Nginx服務(wù)器的配置中開啟文件Gzip壓縮的方法,可以對(duì)CSS和JavaScript以及各種圖片等web傳輸?shù)奈募M(jìn)行壓縮,需要的朋友可以參考下2016-01-01