小编Man*_*n84的帖子

没有 SockJS 的 Spring 启动 Websocket

我已经为此挣扎了至少两个星期。我对 websockets 很陌生。我对休息端点有很好的经验。

我的用例很简单。客户端启动一个 websocket 连接,向服务器发送一些信息,服务器使用该信息,并以固定的时间间隔(例如每 5 秒)向客户端发送一些信息。我按照这里的教程 - https://spring.io/guides/gs/messaging-stomp-websocket/ 它按照解释完美运行。根据上面的教程,客户端发起一个 http 请求,该请求被升级为 websocket。

就我而言,前端是一个 angular 10 应用程序,前端开发人员更喜欢使用rxjs/websocket,不想使用SockJS client,因为他确信我们不必支持任何旧版浏览器,这就是我感到震惊的地方. 显然rxjs/websocketws://协议中需要 url 。

从下面的片段中,我认为我的等效 ws 协议是 ws://localhost:8080/test但是,它似乎不起作用。我不确定出了什么问题。任何帮助是极大的赞赏!

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer
{

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config)
    {
        config.enableSimpleBroker("/topic");
        config.setApplicationDestinationPrefixes("/ws/");
    

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry)
    {
        registry.addEndpoint("/test");
    }

}
Run Code Online (Sandbox Code Playgroud)

从教程中,我更改了app.js,如下以测试这一点。

function connect() {
    // var socket = new SockJS('http://localhost:8080/test'); This works perfectly
    // stompClient = Stomp.over(socket);
    ws …
Run Code Online (Sandbox Code Playgroud)

websocket rxjs sockjs spring-boot spring-websocket

7
推荐指数
1
解决办法
589
查看次数

如何使用Spring Cloud Task动态部署独立Spring批处理

我们计划淘汰现有的旧Java批处理应用程序,并使用最新的可用批处理框架重新创建它.鉴于我们有大量的批处理作业需要现代化,我们正在寻找一个允许我们的框架或架构

  1. 开发批处理解决方案,使我们能够在创建新批处理时动态部署新批处理,而不会干扰现有的已部署应用程序. - Spring cloud Task是否提供此功能.注意:我们只希望将应用程序部署到本地服务器,而与云无关.
  2. 如果Spring Batch/Boot能够为我们提供批处理应用程序通常所期望的功能,那么Spring Cloud Task的特殊增值是什么? - 我无法从在线提供的Spring文档中完全理解这一点.
  3. 从Spring Cloud Task的文档中,我能够理解它允许应用程序在其中包含许多任务.如果每个任务都有自己的库依赖项,那么我该怎么办?这可能与其他任务的依赖项相矛盾?那么在这种情况下,如果这些任务中的每一个都转移到一个新的应用程序,或者这个有解决方法吗?

spring spring-batch spring-boot spring-cloud spring-cloud-task

3
推荐指数
1
解决办法
1677
查看次数