当前位置 : 主页 > 操作系统 > centos >

Docker+Nginx打包部署前后端分离步骤实现

来源:互联网 收集:自由互联 发布时间:2023-03-17
目录 问题描述 项目打包 前端项目打包 修改vue.config.js文件 router配置中添加base属性 打包前端项目 后端项目打包 将前端和后端的打包文件上传到服务器 nginx反向代理配置 后端通过Dock
目录
  • 问题描述
  • 项目打包
    • 前端项目打包
      • 修改vue.config.js文件
      • router配置中添加base属性
      • 打包前端项目
    • 后端项目打包
      • 将前端和后端的打包文件上传到服务器
      • nginx反向代理配置
        • 后端通过Dockerfile打包成docker镜像
          • 这里为什么使用docker?
            • 构建Docker镜像
              • 查看构建的镜像
                • 运行容器
                  • 运行测试

                  问题描述

                  最近做了一个前后端分离的通用权限管理系统,今天想用自己的服务器部署下,本地部署测试是没问题的,但是部署在服务器上还是出现了许多小插曲,这里大概记录一下吧。

                  项目打包

                  前端项目打包

                  由于我需要在同一个端口号下使用nginx部署多个前端项目,所以需要额外设置一些东西。

                  修改vue.config.js文件

                  添加如下配置:

                  image-20221230164452873

                  router配置中添加base属性

                  const createRouter = () => new Router({
                    // mode: 'history', // require service support
                    scrollBehavior: () => ({ y: 0 }),
                    routes: constantRoutes,
                    base:'/guigu'
                  })

                  image-20221230164614590

                  打包前端项目

                  执行命令:

                  npm run build:prod

                  image-20221230164743322

                  image-20221230164732551

                  出现dist文件夹说明打包成功

                  image-20221230164808807

                  后端项目打包

                  这里我跳过了test步骤

                  image-20221230164838903

                  打包之后target文件夹下面会有jar包

                  image-20221230164906192

                  将前端和后端的打包文件上传到服务器

                  这里上传的方法较多,不过多赘述了。

                  image-20221230165043432

                  将dist.tgz文件解压即可

                  tar -zxvf dist.tgz -C 
                  

                  写你的解压路径即可

                  nginx反向代理配置

                  部分配置如下:

                  image-20221230165222245

                    server {
                          listen       80;
                          server_name  localhost;
                  
                          #charset koi8-r;
                  
                          #access_log  logs/host.access.log  main;
                  
                          location / {
                             proxy_pass http://blog;
                  		   proxy_set_header HOST $host;
                  		   proxy_set_header X-Forwarded-Proto $scheme;
                  		   proxy_set_header X-Real-IP $remote_addr;
                  		   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                          }
                  		
                  		location ^~/prod-api/ {
                  			proxy_set_header X-Real-IP $remote_addr;
                  			proxy_set_header REMOTE-HOST $remote_addr;
                  			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                  			proxy_set_header X-NginX-Proxy true;
                  			proxy_pass http://127.0.0.1:8800/;
                  		}
                  		# guigu-auth配置
                  		location /guigu {
                  			alias /opt/guigu-auth/guigu-front/;
                  			index index.html index.htm;
                  		}
                  
                          #error_page  404              /404.html;
                  
                          # redirect server error pages to the static page /50x.html
                          #
                          error_page   500 502 503 504  /50x.html;
                          location = /50x.html {
                              root   html;
                          }
                      }

                  上面nginx.conf的配置分为两个部分,第一个部分实现前端vue的映射,

                  即将

                  /opt/guigu-auth/guigu-front/index.html
                  

                  映射成

                  127.0.0.1:8080/guigu
                  location /guigu {
                  			alias /opt/guigu-auth/guigu-front/;
                  			index index.html index.htm;
                  }

                  第二部分是将后端请求指向后端项目。这里直接替换了uri的前缀

                  prod-api
                  

                  也就是说假设前端向后端发送的请求为

                  http://localhost:8800/prod-api/admin/system/index
                  

                  经过nginx反向代理后,实际上到达后端的uri为

                  http://localhost:8800/admin/system/index

                  至此,前端项目部署完毕

                  访问

                  codeleader.top/guigu
                  

                  会出现如下页面说明前端部署成功

                  image-20221230170335533

                  后端通过Dockerfile打包成docker镜像

                  这里为什么使用docker?

                  我开始不想用这个,是直接将jar包在服务器上部署的,觉得小项目没必要用docker。

                  但是由于我以前搭建个人博客的时候装的jdk11,这个项目使用jdk8开发的,环境不一致,docker的环境隔离机制非常适合现在这种情况,关于docker使用场景请看我docker专栏,这里不再赘述。

                  编写Dockerfile

                  # 基础镜像使用java
                  FROM java:8
                  # 作者
                  MAINTAINER xtt
                  # VOLUME 指定临时文件目录为/tmp,在主机/var/lib/docker目录下创建了一个临时文件并链接到容器的/tmp
                  VOLUME /tmp
                  # 将jar包添加到容器中并更名为guigu_docker.jar
                  ADD service-system.jar guigu_docker.jar
                  # 运行jar包
                  RUN bash -c 'touch /guigu_docker.jar'
                  ENTRYPOINT ["java","-jar","/guigu_docker.jar"]
                  #暴露8800端口作为微服务
                  EXPOSE 8800

                  构建Docker镜像

                  将打包的后端项目jar包和Dockerfile放在同一个目录下面

                  image-20221230170847494

                  执行命令如下命令构建镜像:

                  docker build -t guigu_docker:1.0 .

                  image-20221230170948838

                  查看构建的镜像

                  docker images

                  image-20221230171022201

                  运行容器

                  docker run -d -p 8800:8800 --name guigu-auth guigu_docker:1.0

                  image-20221230171057150

                  image-20221230171116141

                  运行测试

                  点击登录按钮,成功进入系统,说明前后端部署成功。

                  image-20221230171226854

                  image-20221230171736165

                  image-20221230171711121

                  现在这种部署方式跟部署单个微服务的方法一样,但是生产中不可能只有一个微服务,所以需要借助容器编排来实现一次打包一堆微服务,包括docker-compose、docker swam、k8s、DevOps等这还需要大量的开发实践才行,这些技术光学没用,要在自己的项目中实践才行。其实这里nginx和前端也可以用容器部署的,但这里暂时感觉没必要。

                  开发+部署多有意思啊,现在整天搞自己不感兴趣的方向已经和当初自己想象的研究生科研生涯完全不同了,这种感觉或许只有自己读研之后才能感同身受了,虽有诸多无奈,但我绝不会放弃我所热爱的技术,架构师之路任重而道远。

                  以上就是Docker+Nginx打包部署前后端分离步骤实现的详细内容,更多关于Docker+Nginx部署前后端分离的资料请关注自由互联其它相关文章!

                  上一篇:Nginx中Location配置超详细讲解
                  下一篇:没有了
                  网友评论