gpt4 book ai didi

java - 轻量级 Java Web 服务

转载 作者:行者123 更新时间:2023-12-01 08:03:46 26 4
gpt4 key购买 nike

我有 Java EE 应用程序 (ear) 在单独的 JBoss 实例和不同的硬件上运行。我想从以下地方打电话

  1. 一个应用程序到另一个服务器 JBOSS 中的另一个应用程序。
  2. 相同的 JBOSS,位于两耳之间。
  3. 同一服务器,位于两个 JBO 之间。

通信数据类型可以是任何类型。例如; JSON 或对象。我想知道我可以使用哪些轻量级开源 Java Web 框架来相互调用? Here他们中有一些。但我没有从他们那里得到任何经验。通常使用SOAP和RESTful服务,其实现框架也有很多。

请根据您的经验建议我了解哪些可用的框架适合我的要求?让我有解释任何比较的来源。我担心的是,通信方法应该是轻量级的,应该支持传输任何类型的数据,不应该有太多的配置或标准。该框架应该支持简单且安全的传输(所有通信都在我的应用程序中完成,因此不需要结构良好、标准化的权重配置)。它应该是用Java编写的。我使用 Java 7。

最佳答案

这是一个典型的集成问题。对于集成、中介、代理等不同的服务甚至传输数据,请使用 Apache Camel 。有关 Camel 是什么的简短答案,请参阅 What exactly is Apache Camel?

在 Camel 中,您可以使用 Java DSL 或 XML Spring DSL 定义路由。描述了代理 Web 服务 here 。使用 XML Spring DSL,路线将如下所示:

<route>
<from uri="jetty:http://0.0.0.0:8080/myapp?matchOnUriPrefix=true"/>
<to uri="jetty:http://realserverhostname:8090/myapp?bridgeEndpoint=true&amp;throwExceptionOnFailure=false"/>
</route>

使用 Java DSL,这将变成:

from("jetty:http://0.0.0.0:8080/myapp?matchOnUriPrefix=true"
.to("jetty:http://realserverhostname:8090/myapp?bridgeEndpoint=true&amp;throwExceptionOnFailure=false")

Camel 支持许多不同的协议(protocol),例如 JSM、SOAP WS、RESTful WS、纯 HTTP、TCP。看看https://camel.apache.org/components.html对于所有的可能性。

下一个示例向您展示使用Restlet component定义RESTful服务器是多么容易。 :

from("restlet:http://localhost:8400/orders/{id}?restletMethod=post")
.process(new Processor() {
@Override
public void process(final Exchange exchange) throws Exception {
final String res = "received [" + exchange.getIn().getBody(String.class) + "] with order id = " + exchange.getIn().getHeader("id");
exchange.getIn().setBody(res);
}
});

相应的客户端如下所示:

 from("direct:start")
.setBody(constant("Hello, world!!"))
.to("http://localhost:8400/orders/22?restletMethod=post")
.log("order: direct start body result = ${bodyAs(String)}")

也就是说,Camel 支持多种企业集成模式,例如拆分器、聚合器等,可以满足您的需求。看看http://camel.apache.org/enterprise-integration-patterns.html了解更多相关信息。

您可以只使用“普通”Java 类来转换数据并将它们挂接到路由中。除此之外,还有许多集成类型转换器用于将一种数据类型转换为另一种数据类型。这些转换器可以轻松扩展。请参阅https://camel.apache.org/type-converter.html

您可以使用 Camel 作为基础集成框架并添加例如JMS/ActiveMQ 用于通信。但是,也可以使用 ActiveMQ 作为基础并添加 Camel 来转换数据,请参阅 https://activemq.apache.org/broker-camel-component.html :“代理 Camel 组件使这变得更加容易 - 当消息通过代理本身时,它会拦截消息,从而允许在将消息持久化到消息存储或传递给最终消费者之前对其进行修改和操作。”不过,我更喜欢使用 Camel 作为基础,并添加 JMS/ActiveMQ 进行异步通信(例如,如果需要消息持久性或者通信必须在不同主机之间进行)。

Camel 支持大量不同的协议(protocol)和格式。但是,如果您不需要它们,则不必使用它们。如果需要,只需将依赖项添加到您的 pom.xml 中即可。 Apache Camel 是一个小型库 (11.2 MB),具有最小的依赖性,可轻松嵌入到任何 Java 应用程序中。 Camel 在 Servlet 引擎或 OSGI 容器(例如 Karaf/ServiceMix/JBoss Fuse ESB)中独立运行。如果您的需求不断增长,您可以从小规模开始,应用程序可以不断发展。

要开始使用 Camel,请阅读 Claus Ibsen 的优秀书籍:http://www.manning.com/ibsen/ .

关于java - 轻量级 Java Web 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23233282/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com