Nginx反向代理springboot的jar包過程解析
springboot項目部署到服務器常見的方式就是打成war包部署Tomcat或者打成jar包直接使用內置容易運行,很多人現在都打成war包部署到tomcat,這種方式雖然沒問題 但是后期維護比較麻煩。從官方的說明中 打成jar部署是最好的方式,但是這樣又有個問題 如果同時部署多個spring-boot項目 端口不一樣 怎么通過域名來訪問呢,接下來就需要Nginx出手了,Nginx 是一個高性能的HTTP和反向代理服務器,也是一個IMAP/POP3/SMTP服務器。很適合部署springboot,Nginx的安裝這里不在做教程 給出主要nginx.conf的配置
樣例一;
server { listen 80; server_name 127.0.0.1; access_log logs/book.log; error_log logs/book.error; #將/wx-service請求轉發(fā)給http://127.0.0.1:8011/wx-service處理 location /wx-service { proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:8011/wx-service; } #將/bootdo請求轉發(fā)給http://127.0.0.1:8012/bootdo處理 location /bootdo { proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:8012/bootdo; } #將/xcloud-service請求轉發(fā)給http://127.0.0.1:8013/xcloud-api處理 location /xcloud-service { proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:8013/xcloud-api; } #將/eureka-service請求轉發(fā)給http://127.0.0.1:8081/eureka-service處理 location /eureka-service { proxy_pass http://127.0.0.1:8081/eureka-service; #這里的端口記得改成項目對應的哦 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Port $server_port; } #將/xcloud-api請求轉發(fā)給http://127.0.0.1:8082/xcloud-api處理 location /xcloud-api { proxy_pass http://127.0.0.1:8082/xcloud-api; #這里的端口記得改成項目對應的哦 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Port $server_port; } }
樣例二:
server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm index.php; } #將/wvv請求轉發(fā)給http://127.0.0.1:1992/wvv處理 location /wvv { proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:1992/wvv; } }
如果是部署多個SpringBoot項目,則可以多次添加如下配置,只要修改成不一樣的路徑即可
#將/wvv請求轉發(fā)給http://127.0.0.1:1991/project處理
location /project{ proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:1991/project; }
將nginx的端口改成80端口 域名就可以直接訪問 service_name可以為localhost 代表本機 localtion /XXX這塊就是配置nginx端口轉發(fā) 不輸了幾個項目就配置幾個 也可以將tomcat中的項目配置在這 也是沒問題的 根據上述配置 在sbin目錄執(zhí)行 ./nginx -s reload 刷新nginx配置就會生效了
在這提供一個spring-boot快速重啟shell腳本 親測有效
export JAVA_HOME=/usr/local/java/jdk1.8.0_162 export PATH=$JAVA_HOME/bin:$PATH export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar Port=8081 JarName=clouddo-server.jar LogsPatch=./logs_$Port ID=`ps -ef | grep $Port | grep -v "grep" | awk '{print $2}'` echo $ID echo "---------------" for id in $ID do kill -s 9 $id echo "killed $id" done echo "---------------" rm -rf $LogsPatch mkdir $LogsPatch export LANG=zh_CN.UTF-8 set -m nohup java -jar -Dlogging.path=$LogsPatch $JarName>$LogsPatch/catlina.out 2>&1 & tail -f $LogsPatch/catlina.out
保存命名為xx.sh
建議在nginx下建立一個單獨的文件夾以項目名命名,然后將jar包放入其中,再啟動jar包。
java -jar revenue-1.0.jar >revenue.txt &
記住 springboot項目得在配置文件中配置
server:
context-path: /xcloud-api
Spring boot默認是/ 這樣直接通過http://ip:port/就可以訪問到index頁面 但是我們要通過nginx配置多項目的話就要給每一個項目單獨指定context-path
在服務器目錄根據個人喜好新建一個文件夾 專門用來存放spring-boot打包成的jar 和重啟腳本 類似這樣
這樣方便管理 logs目錄是啟動腳本之后生成的日志文件夾 忽略 一個項目對應一個文件夾 里面包含項目jar和一個重啟shell腳本
這樣就可以同時后臺啟動多個springboot項目并且通過一個域名來訪問這些項目 如果要實時查看日志 請進入到每個項目文件的logs-目錄執(zhí)行
tail -f catlina.out就可以查看了 如有不足請指出 多多諒解......
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
版權聲明:本站文章來源標注為YINGSOO的內容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內容來源于網友推薦、互聯(lián)網收集整理而來,僅供學習參考,不代表本站立場,如有內容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。