SpringBoot+Vue項目部署上線的實現(xiàn)示例
部署前準備
注冊京東云
京東云: https://www.jdcloud.com/
117.72.32.65
vue本地部署
新建文件.env.development
VUE_APP_BASEURL='http://localhost:9191'
新建文件 .env.production
VUE_APP_BASEURL='http://117.72.32.65:9191'
main.js 設(shè)置全局變量$baseUrl
Vue.prototype.$baseUrl =process.env.VUE_APP_BASEURL
搜索
替換
替換request.js
const request = axios.create({ baseURL: process.env.VUE_APP_BASEURL, timeout: 5000 })
vue全局搜索localhost:9191 替換成$baseUrl
方式一:request.post(this.$baseUrl+"/role") 方式二::action="$baseUrl+'/file/upload'"
打包
添加插件
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.7.13</version> 可選 </plugin> </plugins> </build>
npm run build
SpringBoot部署
打包
mvn clean package
服務(wù)器
部署java項目
mkdir -p /home/server/ElectronicMallApi mkdir -p /home/server/ElectronicMallVue
上傳jar 包到服務(wù)器/home/server/ElectronicMallApi目錄
設(shè)置application.yml覆蓋
server: port: 9191 spring: datasource: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://${ip}:3306/electronic_mall username: root password: root servlet: multipart: max-file-size: 30MB redis: database: 0 host: ${ip} port: 6379 lettuce: pool: min-idle: 0 max-active: 8 max-idle: 8 max-wait: -1ms connect-timeout: 30000ms mybatis: mapper-locations: classpath:mapper/*.xml configuration: map-underscore-to-camel-case: true ip: 117.72.32.65
添加啟動和停止腳本
start.sh
NAME=ElectronicMallApi-0.0.1-SNAPSHOT.jar nohup java -jar $NAME > server.log 2>&1 & echo 'start success'
stop.sh
#!/bin/bash PID=$(ps -ef | grep "ElectronicMallApi-0.0.1-SNAPSHOT.jar" | grep -v grep | awk '{print $2}') if [ -z "$PID" ]; then echo "ElectronicMallApi-0.0.1-SNAPSHOT.jar 進程不存在" else kill -9 $PID echo "已停止 ElectronicMallApi-0.0.1-SNAPSHOT.jar 進程" fi
授權(quán)
chmod +x *
vue遠程部署
上傳dist 文件到服務(wù)器/home/server/ElectronicMallVue
安裝jdk 1.8
tar -zxvf /tmp/jdk-8u371-linux-x64.tar.gz -C /usr/local/ mv /usr/local/jdk1.8.0_371 /usr/local/java vi /etc/profile export JAVA_HOME=/usr/local/java export PATH=$JAVA_HOME/bin:$PATH source /etc/profile #讓配置文件生效 #驗證 java -version
安裝nginx
#安裝gcc yum install gcc - c++ #安裝PCRE pcre-devel yum install -y pcre pcre-devel #安裝zlib yum install -y zlib zlib-devel #安裝open SSL yum install -y openssl openssl-devel
下載nginx到/tmp
mkdir /usr/local/nginx tar -zxvf /tmp/nginx-1.24.0.tar.gz -C /usr/local/nginx cd /usr/local/nginx/nginx-1.24.0 #編譯安裝 ./configure --with-http_stub_status_module --with-http_ssl_module make && make install
nginx 命令
cd /usr/local/nginx/sbin ./nginx #啟動 ps -ef | grep nginx #查看 ./nginx -s stop #停止 ./nginx -s reload #重啟
訪問:http://117.72.32.65/
nginx.conf 配置
location / { root /home/server/ElectronicMallVue/dist; index index.html index.htm; try_files $uri $uri/ /index.html; #防止手動輸入項目地址報錯 }
重啟nginx
cd /usr/local/nginx/sbin ./nginx -s reload
安裝mysql
mkdir -p /data/mysql tar -zxvf /tmp/mysql-5.7.42-el7-x86_64.tar.gz -C /usr/local mv /usr/local/mysql-5.7.42-el7-x86_64 /usr/local/mysql #添加用戶組 groupadd mysql useradd -r -g mysql mysql chown -R mysql.mysql /usr/local/mysql chown -R mysql.mysql /data/mysql cd /usr/local/mysql /usr/local/mysql/bin/mysqld --user=mysql --basedir=/usr/local/mysql/ --datadir=/data/mysql --initialize 報錯:/usr/local/mysql/bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory 解決:yum install libaio-devel.x86_64 -y # 將mysql加入到服務(wù)中 cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql #mysql 快捷方式 ln -s /usr/local/mysql/bin/mysql /usr/bin ln -s /usr/lib64/libtinfo.so.6.1 /usr/lib64/libtinfo.so.5
/usr/local/mysql/bin/mysqld --user=mysql --basedir=/usr/local/mysql/
–datadir=/data/mysql --initialize執(zhí)行完
零時密碼:r4siIs:k(9Z7
mysql配置文件my.cnf
vi /etc/my.cnf
[mysqld] datadir=/data/mysql basedir=/usr/local/mysql socket=/tmp/mysql.sock user=mysql port=3306 character-set-server=utf8 symbolic-links=0 [mysqld_safe] log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid
報錯
vi my.cnf vi: error while loading shared libraries: libtinfo.so.5: cannot open shared object file: No such file or directory
解決
sudo yum update ncurses
啟動mysql: service mysql start 開機啟動: chkconfig mysql on 登錄mysql :mysql -uroot -p
修改密碼并設(shè)置 權(quán)限
set password = password('root'); use mysql; update user set host='%' where user='root' and host='localhost'; flush privileges;
開3306端口
Navicat連接
導(dǎo)入數(shù)據(jù)
安裝redis
mkdir /usr/local/redis tar -zxvf /tmp/redis-stable.tar.gz -C /usr/local/redis
編譯make
cd /usr/local/redis/redis-stable make
執(zhí)行完 make 命令后,redis-stable 的 src 目錄下會出現(xiàn)編譯后的 redis 服務(wù)程序 redis-server,還有用于測試的客戶端程序 redis-cli
默認啟動
cd src # 進入src目錄 ./redis-server
配置文件啟動
./redis-server ../redis.conf # 或用配置啟動
后臺進程方式啟動
修改redis.conf,將daemonize設(shè)置為yes
配置文件啟動
./redis-server ../redis.conf # 或用配置啟動
設(shè)置外網(wǎng)可以訪問
打開redis-conf
修改redis.conf配置
# 找到protected-mode 設(shè)置為no protected-mode no # bind 設(shè)置為0.0.0.0 bind 0.0.0.0 # 取消requirepass注釋,設(shè)置密碼 (可選) requirepass "password"
修改application.yml 里面的ip為服務(wù)器的公網(wǎng)ip
啟動java
cd /home/server/ElectronicMallApi ./start.sh
tail -100f server.log #查看日志 ps -ef | grep ElectronicMallApi-0.0.1-SNAPSHOT.jar
到此這篇關(guān)于SpringBoot+Vue項目部署上線的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)SpringBoot Vue項目部署上線內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis-Plus實現(xiàn)多表聯(lián)查的方法實戰(zhàn)
這篇文章主要給大家介紹了關(guān)于MyBatis-Plus實現(xiàn)多表聯(lián)查的方法,MyBatis Plus是一款針對MyBatis框架的增強工具,它提供了很多方便的方法來實現(xiàn)多表聯(lián)查,需要的朋友可以參考下2023-07-07Java 中POI 導(dǎo)入EXCEL2003 和EXCEL2007的實現(xiàn)方法
這篇文章主要介紹了Java 中POI 導(dǎo)入EXCEL2003 和EXCEL2007的實現(xiàn)方法的相關(guān)資料,希望通過本文大家能掌握理解這種方法,需要的朋友可以參考下2017-09-09java打包成jar并執(zhí)行jar包中指定的main方法
這篇文章主要介紹了如何將java打包成可執(zhí)行的jar,并執(zhí)行jar包中指定的main方法的相關(guān)資料,文中給出了詳細的示例代碼,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03