素材巴巴 > 程序开发 >

springboot前后端不分离项目,静态资源提取单独部署

程序开发 2023-09-12 09:50:23

一、项目背景

        该项目是几年前的一个项目,项目初始以为是个很简单的产品,没有使用前后端分离进行开发(当时的公司技术栈也不是分离架构),项目使用的是 thymeleaf 作为模板引擎。

        随着业务的发展,该项目的功能一直在迭代,中间有机会进行架构升级,但是因为各种原因导致升级架构搁置。目前项目中的静态文件资源已经达到300M,这样就导致每一次启动项目开发,打包构建,生成镜像,以及项目启动加载的时间很长。

二、优化前

1、项目静态资源目录

        

2、打包构建时间和生成镜像时间如图:

        

        镜像大小:

        

          如上图可知:每一次项目进行部署,打包,生成镜像,推送,集群拉取镜像,启动。整个流程跑下来,每次都需要15分钟以上。耗费大量时间。

        开发人员在本地开发,只要进行重新编译,每次也需要耗费大量时间。

        

三、优化后

1、项目静态资源目录

         

   2、本地开发项目配置

  配置项目启动加载静态文件夹,开发使用;

@Configuration
 @Profile("dev")
 public class LocalFilePathConfig {/*** 上传文件存储在本地的根路径*/private String localFilePath = "/static";@Beanpublic WebMvcConfigurer webMvcConfigurerAdapter() {return new WebMvcConfigurer() {/*** 外部文件访问
*/@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler( localFilePath + "/**").addResourceLocations(ResourceUtils.FILE_URL_PREFIX + "./statics" + File.separator);}};}

注意:有权限框架的需要把 /static/** 设置为无权限访问;

3、页面JS、CSS等资源路径修改(idea工具,全局查找替换即可)

原有配置:
 
 更改后:
 
 

 4.容器化部署架构:

        nginx + 项目 两个服务启动,由nginx进行反向代理到项目

nginx 配置:

user  root;
 worker_processes  auto;events {worker_connections  1024;
 }http {include /etc/nginx/mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;client_body_buffer_size 128k;server {listen      80;  server_name localhost;location /static/ {alias /usr/share/nginx/html/static/;}#集群内部访问方式location / {proxy_pass http://服务名.命名空间:端口;    }  }
 }

5.优化后部署时间

        

        1)只部署项目(在不增加静态文件时,仅部署项目即可)

        2)项目和静态文件同部署

写在最后:动静分离后,访问系统能明显感受到响应速度变快。这里我没有进行测试响应时间了。有想法的同学可以,自行探索测试,进行比较。


标签:

上一篇: Ant、Ivy入门与集成 下一篇:
素材巴巴 Copyright © 2013-2021 http://www.sucaibaba.com/. Some Rights Reserved. 备案号:备案中。