在常见的服务器环境中使用Spring和php的优点

前端之家收集整理的这篇文章主要介绍了在常见的服务器环境中使用Spring和php的优点前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我建议的可能听起来很奇怪,但我有我的理由.

很长一段时间,我们已经有了这个基于Spring的API,它起源于CRUD功能的一组抽象REST服务.然而,随着时间的推移,我们开始构建业务和表示层,直到我们达到死胡同状态.不要误解我的意思,Spring / Hibernate是很棒的框架,构建在JVM之上有其明显的优势,包括性能优于其他Web技术,如PHP.与PHP相比,它为我们提供了更深入的控制方式,如事务处理,多线程处理,处理字节数据,控制本机C应用程序,使用JNI等.

堆栈明显碰到硬墙的地方,是需求最常变化的地方,即业务层和表示层.将应用程序转变为现代的,以用户为中心的社交应用程序,我们经历了职业生涯中最严峻的挑战. Java EE演示技术难以使用.此外,由于构建测试和部署大型Java应用程序的传统障碍,改变业务需求变得非常漫长.

它也感觉在很大程度上,我们正试图重新发明轮子.在PHP世界中,已经存在许多项目,它们为您提供了一个完整的管理系统,与任何类型的后端系统无关(映射挂钩到REST / SOAP端点).他们中的许多人已准备好所有这些功能,允许管理员友好地改变各种各样的情况,规则,模板等.另外,基于PHP意味着绝对没有时间浪费在构建和部署上.写下变更,测试,确认它有效,并切换.

我们现在的想法是找到一种方法来在这种基于PHP的前端服务器应用程序中移动业务和表示层,并将纯后端内容留给Spring / Hibernate.我们有一些担忧,来自我们对Spring的相对缺乏经验.

>如果我们使用PHP方法实现业务方法,我们如何保持事务安全性?我的意思是,如果一个业务方法必须向JAVA发出三个单独的HTTP请求,那么我们怎样才能保证它们都将在同一个事务中执行,DB-wise?
>有没有办法在两个系统之间使用代理或承诺对象?例如,如果PHP业务方法需要调用Spring搜索方法数据库获取对象的集合,然后将其传递给另一个spring方法,这将意味着必须来回传送整个集合.也许,人们可以将它存储在JAVA端的会话对象中,并简单地将一个空代理发送回前端,前端可以将其反馈回另一个jav方法.
>我们很多基于Spring的功能都依赖于使用Spring事件的插件结构.我们如何才能使我们的前端服务器在每个发生的ackend事件上得到通知.
我在这里有两个想法:一个后处理过滤器,它只是使用一些命名约定向前端服务器上的控制器发出POST请求.
或者…使用某种消息队列,例如JMS或RabbitMQ,或者为什么甚至不能像Reddis那样可以观察数据的变化

谁曾经这样做过?总的来说这是个好主意吗?有任何建议如何解决上述问题?

最佳答案
这不是你提出的问题,但我认为值得一提的是,你遇到的一些Java问题是大多数有经验的Java开发人员有一天遇到的问题,大多数人都找到了一些解决方案.例如,您可以使用Arquillian在Java中执行“更快”的TDD.您可以使用JRebel执行“代码和刷新”方法,就像在PHP中一样.现代IDE还有助于重构,这有助于“需求变更”场景.

当然,演示部分仍然是Java的一个大问题.我个人不喜欢JSF,(对我而言),大多数其他演示技术要么不直观,要么很麻烦.

我想说这就是为什么许多Java开发人员正在成为前端的HTML5和Javascript(backbone.js,underscore.js,jquery,…)的采用者,后端使用REST.中间没有必要使用PHP.

我担心我无法回答你的其他问题,但也许一个好的开始是看看PHP是否可以在Java EE容器内运行?我知道这适用于Ruby和Python应用程序,因为JRuby和Jython将负责两个世界之间的桥梁.

猜你在找的Spring相关文章