部署前后端分离项目详细教程

4 篇文章 0 订阅
4 篇文章 0 订阅

部署前后端分离项目详细教程

1、准备工作

  1. 首先你需要一台服务器,然后在服务器上安装好你所需要的环境,我这里用的宝塔界面来安装环境。

    如果有人不知道怎么安装宝塔界面,可参考这篇文章,如果不知道怎么买服务器,可以参考阿里云飞天计划,学生可以免费领半年。

  2. 在宝塔界面的软件商店,安装MySQL,nginx、Tpmcat、Java项目管理器……(你项目用到了什么,就安什么)

    image-20240201100534335

    选择极速安装,一键安装即可

    image-20240201100620518

    安装过程可能会有点慢,耐心等待即可。

  3. 安装好之后,我们就可以打包前后端的项目了。

2、前端配置

  1. 首先把你用到的localhost全部替换为你的服务器ip,如我此处需要将localhost 全部替换为 8.130.48.75

    image-20240201102041570

  2. 修改你的vue.config.js文件

    9080为我的端口号,可以修改,8090为我后端的端口号,这里设置为你自己的就可。

    const { defineConfig } = require('@vue/cli-service')
     module.exports = defineConfig({
       transpileDependencies: true,
       devServer: {
         port: 9080,
         proxy: {                 //设置代理,必须填
           '/api': {              //设置拦截器  拦截器格式   斜杠+拦截器名字,名字可以自己定
               target: 'http://8.130.48.75:8090',     //代理的目标地址
               changeOrigin: true,              //是否设置同源,输入是的
               pathRewrite: {                   //路径重写
                   '^/api': ''                     //选择忽略拦截器里面的内容
               }
           }
       }
     }
     })

  3. 修改完之后,在终端输入 npm run build 打包即可

  4. 打包完后,可以看到dist目录,这就是你打包之后的文件

    image-20240201102450095

至此,前端打包完毕。

我们首先把前端放到你服务器上测试一下。

  1. 在宝塔界面,将你打包好的文件上传到/www/server/nginx/html 此位置

    image-20240201102921365

  2. 在宝塔界面的软件商店,打开nginx,配置修改,进行修改配置

    image-20240201103831550

image-20240201142247916

 
    server
     {
     listen 9080;   // 前端端口号
     server_name gb_springboot;
     root /www/server/nginx/html/dist;  // 打包好的文件所放的位置
     index index.html index.html;
     try_files $uri $uri/ /index.html;
         
     location /api { 
     proxy_pass http://8.130.48.75:8090/;  // 后端端口号
       }
         access_log  /www/wwwlogs/gb_springboot.log;
     }

然后我们可以尝试访问一下 https:// 你的服务器ip:你的前端端口号/ (https://8.130.48.75:9080/)

然后我们可以看到,无法访问此网站

这是因为我们服务器有安全规则,需要开放你的端口号,在宝塔界面,点击安全,把你的前端端口号添加上去即可。

image-20240201140334127

宝塔添加完之后,我们还需要进入你的服务器页面进行添加(我这里以阿里云服务器为例)点击安全组、管理规则

image-20240201103516849

点击手动添加,将你的端口号添加上去即可

image-20240201103608652

image-20240201140459803

然后再访问刚刚的网站,可看到,已经可以成功访问。

image-20240201142422909

但我们现在是登不上去的,因为我们现在后端没有启动,并且数据库也没有放上去,我们之后继续进行后端配置以及数据库配置。

3、服务器与宝塔配置

再配置后端以及数据库之前,我们先进行服务器和宝塔的一些配置。

从上述情况我们可以看出来,我们需要管理规则,添加端口号才能够进行访问,所以我们现在先把我们项目中所用到的端口号先进行开放。

image-20240201142651381

注意:除了宝塔界面需要开放、你的服务器(我这里以阿里云为例)也需要开放这些端口

image-20240201101630362

4、后端配置

首先,你需要一个springboot项目。

  1. 把你项目中用到localhost的地方全部换为你自己服务器的ip地址

    比如我此处的跨域问题,需要改为自己服务器的ip。

    注意:你的application.yml 或者 application.properties文件里面配置的数据库的url不要改,其他的需要改为你服务器的ip(因为我们数据库可以传到本地,之后数据库操作会提到)

    image-20240201094638537

  2. 把红框中的两个文件放到项目中,修改里面的配置

    image-20240201094843116

    只需改这一个地方即可,改为你自己启动类的地址,如我此处就是com.bo.SpringbootApplication

    image-20240201095016613

    ps:这两个文件会在之后启动后端项目使用到.

  3. 以上准备好之后,我们开始打包项目,点击右侧Maven,点击package

    image-20240201095438750

    打包完成后,左侧导航栏会有target,点开可看到jar包。

    image-20240201142832933

有些人可能打包出来的文件不对劲,我们可以修改自己的pom.xml文件

 <build>
         <plugins>
 ​
             <plugin>
                 <groupId>org.apache.maven.plugins</groupId>
                 <artifactId>maven-assembly-plugin</artifactId>
                 <version>3.1.0</version>
                 <executions>
                     <execution>
                         <id>make-assembly</id>
                         <phase>install</phase>
                         <goals>
                             <goal>single</goal>
                         </goals>
                         <configuration>
                             <!-- 打包生成的文件名 -->
                             <finalName>${project.artifactId}</finalName>
                             <!-- jar 等压缩文件在被打包进入 zip、tar.gz 时是否压缩,设置为 false 可加快打包速度 -->
                             <recompressZippedFiles>false</recompressZippedFiles>
                             <!-- 打包生成的文件是否要追加 release.xml 中定义的 id 值 -->
                             <appendAssemblyId>true</appendAssemblyId>
                             <!-- 指向打包描述文件 package.xml -->
                             <descriptors>
                                 <descriptor>package.xml</descriptor>
                             </descriptors>
                             <!-- 打包结果输出的基础目录 -->
                             <outputDirectory>${project.build.directory}/</outputDirectory>
                         </configuration>
                     </execution>
                 </executions>
             </plugin>
 ​
             <plugin>
                 <groupId>org.apache.maven.plugins</groupId>
                 <artifactId>maven-jar-plugin</artifactId>
                 <version>3.0.2</version>
                 <configuration>
                     <excludes>
                         <exclude>*.yml</exclude>
                         <exclude>application.properties</exclude>
                     </excludes>
                 </configuration>
             </plugin>
         </plugins>
     </build>

至此,后端项目打包完毕。

然后我们把打包后的文件放到服务器上进行启动。

  1. 将-release 中的这四个文件放到服务器上,然后打开终端。

  2. cd 到刚刚的目录,然后输入 chmod u+x st.*.sh 修改文件的权限

    image-20240201152126209

  3. 输入 ./start.sh 进行运行

    image-20240201152254797

可看到,已运行成功,我们再次访问之前的网站,发现还是登不进去,这是因为我们没有配置它的数据库。

5、数据库

打开Navicate,点击左上角的连接,选择MySQL 第一步:第一个页面是常规,按照图上的标注填写

image-20240201152646224

第二步,点击 SSH ,进入下面的页面

image-20240201160038218

第三步,点击测试连接

image-20240201160100484

完成之后,我们需要把之前本地的数据库数据同步到我们新建的这个连接上。

  1. 点击工具 - 数据传输

    image-20240201161127783

  2. 点击下一步,选择 运行期间所有表,点击下一步

    image-20240201161155379

  3. 点击开始,即可完成同步

    image-20240201161248712

以上都完成后,再次访问,即可进入我们部署好的页面。

image-20240201162007043

但是,我们这里 ./start.sh 进行运行 ,当我们退出去后就会停止运行,所以我们需要让后端项目再后台进行运行,以便我们随时访问,我们可以使用 ./start.sh nohup 此命令来进行后台运行。

image-20240201162145416

我们也可以再 output.log中进行日志查看。

image-20240201162624864

至此我们已经部署完毕。

wms-web admin 123 (这是我部署上去的)

6、总结

  1. 准备好服务器以及对应环境(推荐用宝塔,简单)

  2. 前端打包

  3. 后端打包

  4. nginx配置

  5. 数据库配置

  6. 安全组规则配置

部署项目有多种方式,以上是我所使用的,仅供参考!!!

  • 34
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然,我可以为您提供一个详细教程来帮助您部署Vue+SpringBoot前后端分离项目到云服务器上使用Docker。 首先,确保您已经完成以下准备工作: - 注册一个云服务提供商的账号,并创建一个云服务器实例。 - 在本地环境中安装了Docker,并熟悉Docker的基本操作。 - 本地已经安装了Node.js和npm,以及Vue CLI和Java开发环境。 以下是详细的步骤: 1. 登录到云服务器: 使用SSH工具连接到您的云服务器。例如,使用命令行工具执行以下命令: ``` ssh username@server_ip_address ``` 2. 安装Docker: 根据您的云服务器的操作系统,选择对应的安装方式进行Docker安装。以下是一些常见操作系统的安装命令: - Ubuntu: ``` sudo apt-get update sudo apt-get install docker.io ``` - CentOS: ``` sudo yum update sudo yum install docker ``` 3. 验证Docker安装是否成功: 执行以下命令来验证Docker是否已经成功安装: ``` docker version ``` 4. 构建Vue项目: 在本地开发环境中,使用Vue CLI创建Vue项目,并进行开发和测试。确保项目可以正常运行。 ``` vue create myproject cd myproject npm run serve ``` 5. 打包Vue项目: 在Vue项目根目录下执行以下命令,将Vue项目打包成静态文件。 ``` npm run build ``` 6. 创建SpringBoot项目: 使用Spring Initializr创建SpringBoot项目,并进行开发和测试。确保项目可以正常运行。 - 访问Spring Initializr网站:https://start.spring.io/ - 选择项目的基本设置,如使用的编程语言、构建工具、Spring Boot版本等。 - 添加所需的依赖项,如Spring Web、Spring Data JPA等。 - 点击"Generate"按钮下载生成的SpringBoot项目压缩包。 - 解压缩项目压缩包,并使用您喜欢的集成开发环境(IDE)打开项目。 7. 创建Dockerfile: 在SpringBoot项目的根目录下创建一个名为`Dockerfile`的文件,用于定义Docker镜像的构建步骤。在`Dockerfile`中添加以下内容: ``` FROM openjdk:8-jdk-alpine VOLUME /tmp ADD target/myproject.jar app.jar ENTRYPOINT ["java", "-jar", "/app.jar"] ``` 8. 构建Docker镜像: 在SpringBoot项目的根目录下执行以下命令,构建Docker镜像: ``` docker build -t myproject . ``` 9. 运行Docker容器: 执行以下命令,在Docker中运行SpringBoot项目的Docker容器: ``` docker run -d -p 80:8080 myproject ``` 10. 访问应用: 使用浏览器访问您的云服务器的公网IP地址,即可查看部署好的前后端分离项目。 希望这个详细教程能够帮助您成功部署Vue+SpringBoot前后端分离项目到云服务器上使用Docker。如果您有任何问题,请随时提问!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值