- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
目前,我正在将我们的 Web 应用程序从传统的 Spring MVC Web 应用程序升级到具有 REST 端点的单页应用程序。我们目前的前端 MVC 应用并没有使用 REST 调用与后端进行通信,而是通过直接调用必要的外观与后端(用 JAVA 编写)进行通信。 JAR 文件和 WAR 文件都打包在一个 ear 文件中,并部署在我们的生产服务器上(目前使用 JBoss EAP 6)。
由于我们现在正在转向单页面应用程序,并使用一组新的 API 升级我们的系统,我想问一下,单页面应用程序和用 JAVA 编写的后端的其余部分是否应该托管在同一个平台上服务器(JBoss EAP 6)?还是应该将它们拆分到单独的服务器上,一台用于服务 SPA 内容,另一台用于运行后端?在后一种情况下,哪个生产服务器最适合承载单页应用程序的内容(JS、HTML 和 CSS)? (我们的后端仍将托管在 JBoss EAP 6 上)
还有前后端分离在不同服务器上有什么好处?
我尝试搜索使用 JAVA REST 端点部署单页应用程序的最佳实践,但我没有找到任何适用于我们需求的有用文章。
提前致谢! :)
最佳答案
回答您的第一个问题:
是的,您可以完全将它们分开,理想情况下您应该这样做,这样您就可以在不依赖 Web 服务后端的情况下部署前端。
您可以使用任何流行的 Web 服务器(如 Apache、Nginx)或什至在云托管(如 S3)(在云端 CDN 后面)上部署 SPA 静态文件。
假设您的 REST 端点仍将使用 Java,那么这些端点将需要驻留在 Java 应用程序服务器中,例如 jBOSS、tomcat 或 glass fish。
约束/陷阱:
跨域:
您可以将 JBOSS 置于运行静态文件的同一个 Apache/Nginx 反向代理之后。
或者,如果您的域是独立的,您可以在 Web 服务上启用 CORS。
最后,如果您的 Web 服务是 JSON,jsonp 始终是一个选项。
身份验证和安全:
优点:
更容易单独扩展后端和前端,在 amazon S3 和 CloudFront CDN 等服务上使用静态 SPA,您可以在该部分无限扩展。
后端 Web 服务现在可以轻松地置于负载均衡器集群模型之后,因为您的服务是 REST 的。
由于关注点分离,现在更容易处理部署。
仅推送前端更改时出现的回归问题较少。您不必再替换整个 WAR 文件。
是否独立服务器
取决于您的应用程序预期处理的流量类型。让我列出三种情况。
低流量:您可以将它放在一台服务器上,Java App 服务器位于该 Web 服务器的反向代理后面。 Web 服务器还将为 SPA 的某个目录提供服务。
中等流量:您应该将前端服务器和 Web 服务器分开放在一台 Web 服务器上,并将 REST 服务托管在单独的机器上。从技术上讲,此设置与选项 1 没有太大区别,但您的应用服务器不会与 Web 服务器竞争 CPU 周期来响应请求。
高流量:与选项 2 相同,但现在您可以拥有多个 App 服务器和 SPA Web 服务器,并在顶部有一个 Apache/Nginx 进行负载平衡。
广阔地理区域的疯狂流量:在这种情况下,您不想自己托管这些 SAP。最好在 CloudFront CDN 后面使用像 Amazon S3 这样的服务,这样您的静态内容就会在世界范围内复制,以获得最佳响应时间。这也将减少服务器上的负载。现在介绍用于托管 REST 端点的应用程序服务器。您可以使用自己的云服务器来托管您的集群,也可以使用 Heroku 或亚马逊等 PAAS 来托管您的 WAR 文件并按需扩展。
注意:这些扩展场景不考虑数据库,因为您需要有关数据库的更多信息才能确定如何在上述场景中扩展它。
希望对您有所帮助,如果您需要有关上述任何事项的更多细节,请告诉我。
关于javascript - 单页应用程序 (SPA) 与全栈应用程序。限制和优势。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38791391/
我正在看的是在另一个 React 微前端中有一个有角度的微前端,这是我们可以通过 single-spa 实现的吗 最佳答案 是的,这可以通过两种方式完成。这取决于您的应用程序使用的框架。 选项 1:跨
总结:如何在不使用繁重的 JS 框架的情况下处理 PWA 中的导航、历史记录和深度链接? 在领导团队将现有的购物网站从 Angular 1 SPA 转换为多页面应用程序 (MPA) PWA 时,我遇到
我正在尝试使用 Angular.js 和 Express.js 创建 Node.js 应用程序。 我正在做的是使用此代码将客户名称和地址添加到列表(随机)。 var mylist = new gene
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 8 年前。 Improv
所以我在 Laravel 5.3 和 Vue 2 中开发一个网站/网络应用程序。SEO 很重要,所以我想在 Laravel + Blade 中保留网站的前端/可抓取部分,并且只保留一些不必要的小部分在
我设置了一个单页应用程序,它使用 Controller (用 PHP 编写)从 API 获取数据。到目前为止,我没有遇到任何问题,数据填充表,在选择表元素时它会使用新的 url 和部分数据(主要是 I
因此,我一直在尝试找出有关如何在 SPA 应用中处理授权(而不是身份验证)的最佳实践。 假设我有一个带有 api 后端的客户端 MVC(Angular、vuejs 等),我们如何管理应用程序的使用授权
SPA 的缺点当然是初始加载时间。 例如,我用 Durandal 创建了 AskACarPro.com。 它目前在加载时有一个“加载”屏幕。但我在想也许这是一个坏主意。它让我想起了一个全闪存网站——漂
我最近一直在阅读有关 SPA 以及它有多好的内容。 我想知道是否有人可以告诉我什么时候应该使用,或者什么时候不应该像常规 MVC 一样使用 SPA 最佳答案 MVC(Rails、MVC4)的工具更加成
基本设置:由Apache 2.4提供的Angular 1.5 SPA由REST api支持,Apache 2.4也提供了REST API。 我已经阅读了在服务器上更改了一些应用程序代码后可以使SPA更
在典型的单页应用程序(SPA,例如:React)中,整个代码包都提供给客户端。这包括应用程序的私有(private)组件,这些组件通常受到客户端授权机制的保护(例如,检查身份验证 token 是否已设
我想单独托管我的 应用程序和 网站 .层次结构如下: example.com - 网站托管在 DigitalOcean example.com/* - SPA 托管在 Firebase Hosting
我正在寻找可重复使用的解决方案,以解决用户执行的某些操作在完成之前可能需要用户进一步确认的问题。 我正在使用 React 前端和 WebAPI 后端开发应用程序。 假设用户正在发起资金转账,并假设我们
我有一个像这样的网站 http://domain/?key=32dxzQW 其中 key 是从每个用户的其他站点自动生成的 我需要知道的是访问量最大的部分,所以我正在考虑使用 GA,并且由于我的网页是
我真的很喜欢GunDb的概念,并且了解如何单独在客户端编写。 现在我使用来自 Github 的 Create-React-App。 有人知道 GunDb 的服务器端吗? 和一个 View [React
假设 ABC 公司有两个团队开发两个 SPA 应用程序:app1、app2 每个应用程序都有自己的 index.html 和关联的静态资源,例如: build / 索引.html 主.js 这是从:h
我一直在使用 AngularJS 开发 SPA,并将用户数据存储在 Angular Value 服务中,但我对此感到不舒服,主要是因为 Angular Value 不在浏览器选项卡之间共享。因此,如果
假设 ABC 公司有两个团队开发两个 SPA 应用程序:app1、app2 每个应用程序都有自己的 index.html 和关联的静态资源,例如: build / 索引.html 主.js 这是从:h
因此,我使用 Gorilla/Mux 在 Go 中设置了我的 SPA,但我想在不同的路由上运行它,这样我就可以将我的两个 Kubernetes 服务连接在一起(2 个不同的 SPA)。 难道我必须将我
我正在创建一个单页应用程序。我试图在 sql 中选择一个表并在字段中搜索特定日期 Date_Due,然后确保另一个字段 Date_Complete 为空。我试图弄清楚如何让隐藏字段填充查询中的 cfp
我是一名优秀的程序员,十分优秀!