前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot电商项目实战 — 前后端分离后的优雅部署

SpringBoot电商项目实战 — 前后端分离后的优雅部署

作者头像
攻城狮的那点事
发布2019-07-23 14:24:14
2.5K0
发布2019-07-23 14:24:14
举报
文章被收录于专栏:攻城狮的那点事

在如今的SpringBoot微服务项目中,前后端分离已成为业界标准使用方式,通过使用nginx等代理方式有效的进行解耦,并且前后端分离会为以后的大型分布式架构、弹性计算架构、微服务架构、多端化服务(多个客户展现端,例如:web端,安卓app,IOSapp,微信小程序等)打下坚实的基础。这个步骤是系统架构从猿进化成人的必经之路。

上图是简单的分布式微服务开发及前后端分离的示意图。展现层也就是所谓的前端(客户可直观看到的),比如电商项目前端包含:app(安卓和IOS)、微信小程序、PC商城、Web后台。后端是整个项目的核心,也就是系列项目中讲的内容,后端用Springboot+Dubbo实现分布式开发微服务落地,服务实现层的每一个服务都是一个独立部署的应用,并提供服务(Dubbo的提供者),接口层根据前端的请求,然后找对应的服务提供者消费服务。

在前后端分离的应用模式中,后端仅返回前端所需的数据,不再渲染HTML页面,不再控制前端的效果。至于前端用户看到什么效果,从后端请求的数据如何加载到前端中,都由前端自己决定,网页有网页的处理方式,各自有各自的处理方式,但无论哪种前端,所需的数据基本相同,后端仅需开发一套逻辑对外提供数据即可。前端(Web项目)分离处理,都是从原先的JSP转成了Html静态页面。

Web项目部署容器的选取

目前常用的部署Web项目的容器用Tomcat、Apache、Nginx等,那我们前后端分离后的前端Html静态项目到底部署在那个应用容器呢?我们先看看这几个应用容器的区别。

Nginx,Apache,Tomcat的区别:

Nginx常用做静态内容服务和代理服务器,直接外来请求转发给后面的应用服务器(如tomcat),而tomcat更多用来做一个应用容器。

1,Apache和nginx应该叫做HTTP Server,而tomcat是一个Application Server是一个Servlet/JSO应用的容器。

2,HTTP Server访问服务器上存储的资源(HTML文件,图片文件等),HTTP Server是中只是把服务器上的文件如实通过HTTP协议传输给客户端。

3,Application Server(应用服务器)往往是运行在HTTP Server的背后并执行应用,将动态的内容转化为静态的内容之后,通过HTTP Server分发到客户端。

4,Apache是同步多进程模型,一个连接对应一个进程,而nginx是一步的,多个连接(万级别)可以对应一个进程。nginx轻量级,抗并发,处理静态文件好。

根据对比,我们不难发现Nginx是较好的选择,它是由俄罗斯人(伊戈尔·赛索耶夫)开发的一款高性能的HTTP和反向代理web服务器。本身是轻量级、抗并发、能实现万级的连接等。同时它也是一个反向代理服务器。因此,我们不仅可以用它部署静态的html应用,还可以实现域名及访问地址的代理。

Nginx部署前端Web项目

Nginx的安装这里不做介绍,只说配置及部署相关内容。首先进入linux系统中Nginx的安装录的conf目录下,找到nginx.config配置文件,vim nginx.config进入编辑模式,在http下的server对应的同级编辑或添加如下代码,然后在root对应的目录下上传对应的html今天项目文件。注意:这里上传的如果是压缩包就需要解压,目录下要有index.html。

代码语言:javascript
复制
server {
  listen 80;
  server_name www.xxxx.com;
  location / {
      root html/; #html访问路径  
      index index.html;
  }
}

但我们的实际项目中,经常有多个Web端需要部署,如前面图中的例子,Web端有PC商城和Web后台系统,甚至可能更多,这些多个Web静态项目我们都放在nginx的html目录下的不同文件夹里,然后通过域名或ip+port代理到对应目录。下面就是多个Web项目在Nginx里的配置。

代码语言:javascript
复制
##商城Html页面
server {
  listen 80;
  server_name www.xxxx.com;
  location / {
      root html/pc/; #html访问路径  
      index index.html;
  }
}
##后台系统Html页面
server {
  listen 80;
  server_name admin.xxxx.com;
  location / {
      root html/admin/; #html访问路径  
      index index.html;
  }
}

编辑完成后保存,并重启nginx服务 service nginx restart。

注:server_name 这里可配置域名或ip+端口号。

后端项目的部署

大家应该都知道,SpringBoot里集成了Tomcat容器,所有Springboot的项目部署,很是容易,根本不需要你还安装什么Tomcat、JBoss等应用。我们只需打成jar文件,上传到服务器,然后通过执行java -jar ***.jar &命令即可。

但有没有人遇到过,你通过java -jar ***.jar &刚刚部署的服务,在你断开linux服务器的shell连接后服务就没了。大家有知道这是什么原因吗?这里给大家说说部署java jar文件命令的那点事。

1,java -jar ***.jar &

此命令可直接启动jar文件,是在当前会话进程中开启一个子进程来运行程序,这个子进程会随着会话进程的结束而结束。也就是说在你端口Shell连接回话结束,服务就跟着结束了。这种情况适合短时间测试用。

2,nohup java -jar ***.jar &

这里在说这个命令前先说两个名词,即:

  • hangup (挂断),终端退出时会发送 hangup 信号来通知关闭所有子进程。
  • nohup(不挂断,忽略挂断信号)

nohup 的使用是十分方便的,只需在要处理的命令前加上 nohup 即可,标准输出和标准错误缺省会被重定向到 nohup.out 文件中。一般我们可在结尾加上"&"来将命令同时放入后台运行,也可用">filename2>&1"来更改缺省的重定向文件名。这种情况适合在生产环境长时间运行。

在生产环境如果你只用简单的jar部署,那一定得用nohup java 命令启动应用。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-07-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 攻城狮的那点事 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档