当前位置:   article > 正文

vue+springboot项目部署服务器_vuespring部署要改成服务器的ip地址吗

vuespring部署要改成服务器的ip地址吗

项目仓库:vue+springboot-demo: vue+springboot增删改查的demo (gitee.com)

①vue中修改配置

在public文件夹下新建config.json文件:

  1. {
  2. "serverUrl": "http://localhost:9090"//这里localhost在打包后记得修改为服务器公网ip
  3. }

然后修改main.js:

  1. import ElementPlus from 'element-plus'
  2. import 'element-plus/dist/index.css'
  3. import { createApp } from 'vue'
  4. import App from './App.vue'
  5. import router from './router'
  6. import {zhCn} from "element-plus/es/locale/index";
  7. import axios from "axios"
  8. const app = createApp(App)
  9. axios.get('/config.json').then((res)=>{
  10. app.config.globalProperties.$config=res.data
  11. })
  12. export const globals=app.config.globalProperties
  13. app.use(router)
  14. app.use(ElementPlus, {
  15. locale: zhCn,
  16. })
  17. app.mount('#app')

最后修改request.js:

  1. import axios from "axios"
  2. import {globals} from "@/main"
  3. const serverUrl=globals.$config?.serverUrl||'http:localhost:9090'
  4. const request=axios.create({
  5. baseURL:serverUrl,
  6. timeout:30000
  7. })
  8. request.interceptors.request.use(config=>{
  9. config.headers['Content-Type']='application/json;charset=utf-8'
  10. return config
  11. },error=>{
  12. console.log('request error'+error)
  13. return Promise.reject(error)
  14. })
  15. request.interceptors.response.use(response=> {
  16. let res=response.data
  17. return res
  18. },error=>{
  19. console.log('response error'+error)
  20. return Promise.reject(error)
  21. })
  22. export default request

上述修改主要是动态辨别项目是在主机还是在服务器上,从而动态修改运行地址 

②打包vue+springboot项目 

springboot:先双击clean,再双击package,会生成jar包

 

vue:会生成一个dist文件夹

npm run build

 

③配置服务器

首先需要在腾讯云或者阿里云购买一个服务器,新用户注册会有免费一个月的服务器使用,然后需要准备xshell(相当于服务器的cmd)和winscp(上传文件到服务器)工具,将两个工具连上服务器

查看服务器内网ip:

ifconfig

用360压缩打开jar包,修改application.yml:将localhost修改为服务器内网ip,username和password修改为服务器数据库的username和password

  1. server:
  2. port: 9090
  3. spring:
  4. datasource:
  5. driver-class-name: com.mysql.cj.jdbc.Driver
  6. url: jdbc:mysql://localhost:3306/demo
  7. username: root
  8. password: 123456
  9. mybatis:
  10. configuration:
  11. map-underscore-to-camel-case: true

用xshell7在服务器上创建一个vue3文件夹,并用winscp将dist文件夹和jar包拖入vue3文件夹中:

 

在服务器上安装mysql:

①确定服务器的系统是否支持yum命令

输入以下命令,不报错即可:

yum -v

②下载对应的mysql 安装包 

wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

③安装mysql 

yum -y install mysql57-community-release-el7-10.noarch.rpm

④ 安装对应的服务

yum -y install mysql-community-server --nogpgcheck

⑤启动服务并查看Mysql 的初始密码 

  1. systemctl start mysqld.service #首先启动mysql
  2. grep "password" /var/log/mysqld.log #查看初始密码

⑥修改初始密码并刷新登录

  1. -- 1. 登录MySQL
  2. -- 回车后,输入上面的初始密码即可。
  3. mysql -u root -p
  4. -- 2. 修改密码
  5. alter user 'root'@'localhost' identified by '密码';
  6. -- 3. 刷新权限
  7. flush privileges;
  8. -- 4.退出Mysql
  9. exit
  1. -- 1. 登录(使用你的新密码)
  2. mysql -u root -p '新密码'
  3. -- 2. 显示所有的数据库
  4. show databases;
  5. +--------------------+
  6. | Database |
  7. +--------------------+
  8. | information_schema |
  9. | mysql |
  10. | performance_schema |
  11. | sys |
  12. +--------------------+
  13. 4 rows in set (0.00 sec)
  14. -- 3. 使用对应的数据库改管理员信息
  15. use mysql;
  16. -- 4. 查询所有管理员
  17. select user,host from user;
  18. +---------------+----------------+
  19. | user | host |
  20. +---------------+----------------+
  21. | root | % |
  22. | root | 1**.2**.1**.67 |
  23. | mysql.session | localhost |
  24. | mysql.sys | localhost |
  25. +---------------+----------------+
  26. 4 rows in set (0.00 sec)

⑦给远程权限

  1. -- 1. 更新root的权限
  2. update user set host='%' where user = 'root';
  3. -- 2. 设置完一定要刷新
  4. flush privileges;
  5. -- 3. 再查询一遍,检查root的host变为%
  6. select user,host from user;

 看见root的host为%就表示可以远程连接数据库了,在服务器打开3306端口就可以用navicat连接了

服务器上配置java环境:

 ①去官网下载jdk压缩包

②用winscp创建文件夹将压缩包拖入,这里将压缩包放入usr文件夹下的local文件夹下

 

③解压文件并修改文件名

tar -xvf jdk-8u401-linux-x64.tar.gz
mv jdk1.8.0_401 jdk1.8

在winscp可以看见解压后的文件:

④配置环境变量

vi /etc/profile

在该文件末尾添加下面代码:先按esc,再按:wq保存推出

  1. JAVA_HOME=/root/usr/local/jdk1.8
  2. CLASS_PATH=.:$JAVA_HOME/lib/
  3. PATH=$PATH:$JAVA_HOME/bin
  4. export JAVA_HOME CLASS_PATH PATH

 环境变量生效:

source /etc/profile

验证一下:

java -version

显示如图,说明配置成功 

 

③后端项目部署

修改下pom.xml文件:添加下面代码,重新打包上传服务器

  1. <build>
  2. <plugins>
  3. <plugin>
  4. <groupId>org.springframework.boot</groupId>
  5. <artifactId>spring-boot-maven-plugin</artifactId>
  6. <executions>
  7. <execution>
  8. <phase>package</phase>
  9. <goals>
  10. <goal>repackage</goal>
  11. </goals>
  12. </execution>
  13. </executions>
  14. <configuration>
  15. <includeSystemScope>true</includeSystemScope>
  16. <mainClass>这里填写你的 Application 的路径</mainClass>
  17. </configuration>
  18. </plugin>
  19. </plugins>
  20. </build>

用winscp在vue3文件夹新建一个start.sh:

nohup java -jar springboot-demo-0.0.1-SNAPSHOT.jar > server.log 2>&1 &

启动一下(或者直接用命令java -jar jar包名直接启动更加便捷):

  1. cd vue3//进入文件夹
  2. chmod 777 *//开放权限
  3. ./start.sh//启动后端

用ll指令看下有没有log文件,查看log文件(这是日志文件,会告诉你启动成功还是失败):

用winscp查看该文件:出现如图说明启动成功

 

服务器开放9090端口:直接用公网ip的9090端口访问一下,出现如图就说明后端项目部署成功了

④前端项目部署

 安装nginx:

  1. yum install gcc-c++//安装c++
  2. yum install -y pcre pcre-devel//安装pcre
  3. yum install -y zlib zlib-devel//安装devel
  4. yum install -y openssl openssl-devel//安装openssl-devel
  5. cd /tmp/
  6. wget http://nginx.org/download/nginx-1.24.0.tar.gz//安装nginx
  7. tar -zxvf nginx-1.24.0.tar.gz
  8. cd /usr/local
  9. mkdir nginx
  10. cd nginx
  11. cp -R /tmp/nginx-1.24.0 ./
  12. cd nginx-1.24.0
  13. ./configure --with-http_stub_status_module --with-http_ssl_module
  14. make && make install
  15. cd ..
  16. cd sbin/
  17. ./nginx //这里就启动nginx了

访问下公网ip:显示下图说明成功 

配置项目:

  1. cd ..
  2. cd conf
  3. vi nginx.conf

将源文件对应代码段修改如下:

  1. server {
  2. listen 80;
  3. server_name localhost;
  4. #charset koi8-r;
  5. #access_log logs/host.access.log main;
  6. location / {
  7. root /root/vue3/dist;//主要在这个地方修改为dist的路径,其他地方不动
  8. index index.html index.htm;
  9. }

重启下nginx:

  1. cd ..
  2. cd sbin
  3. ./nginx -s reload

这里在访问的时候可能会出现403 错误,开一下dist所在文件目录的权限就好:

chmod -R 777 /root

访问一下服务器:这里需要ctrl+鼠标左键刷新(强制缓存刷新)才显示出来

整个前后端项目的部署到这里就差不多结束了 o(* ̄▽ ̄*)ブ

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/213313
推荐阅读
相关标签
  

闽ICP备14008679号