WebSockets production ready server en Java?

EDIT: suppression de la référence à C# car la seule réponse acceptée concerne Java. Si quelqu'un a besoin d'informations sur l'implémentation du serveur websocket dans C#, posez une nouvelle question.

Connaissez-vous le framework" production ready " pour créer des serveurs Web en Java? J'ai trouvé une bibliothèque http://nugget.codeplex.com/ mais je ne savais pas comment c'était stable et rapide.

24
demandé sur Neeme Praks 2010-11-25 18:09:43
la source

6 ответов

Pour Java, découvrez ce post informatif. Copier-coller à partir de là:

Hors de ces options, je suppose que Jetty et Résine sont les plus matures et stables. Cependant, toujours bon de faire vos propres tests.

35
répondu Neeme Praks 2018-05-19 17:15:58
la source

la réponse acceptée date de 3 ans, avec la récente sortie de JEE7, maintenant tous les conteneurs Web qui implémentent servert 3.1 supporteront websocket via L'API standard ( javax.websocket).

Le code suivant montre un exemple comment mettre en œuvre websocket à l'aide de JEE7:

import java.util.logging.Level;
import java.util.logging.Logger;
import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;

@ServerEndpoint(value = "/chat")
public class ChatServer {

    private static final Logger LOGGER = 
            Logger.getLogger(ChatServer.class.getName());

    @OnOpen
    public void onOpen(Session session) {
        LOGGER.log(Level.INFO, "New connection with client: {0}", 
                session.getId());
    }

    @OnMessage
    public String onMessage(String message, Session session) {
        LOGGER.log(Level.INFO, "New message from Client [{0}]: {1}", 
                new Object[] {session.getId(), message});
        return "Server received [" + message + "]";
    }

    @OnClose
    public void onClose(Session session) {
        LOGGER.log(Level.INFO, "Close connection for client: {0}", 
                session.getId());
    }

    @OnError
    public void onError(Throwable exception, Session session) {
        LOGGER.log(Level.INFO, "Error for client: {0}", session.getId());
    }
}

Exemple dans les détails ici.

conteneur Web qui supporte Websocket:

45
répondu Pau Kiat Wee 2013-09-01 10:25:56
la source

Le Vert.l'option x vaut également la peine d'être considérée.

créer un serveur ws peut être aussi simple que

vertx.websocketHandler(new Handler<ServerWebSocket>() {
    public void handle(ServerWebSocket ws) {
        // A WebSocket has connected!
    }
}).listen(8080);

ou

vertx.createHttpServer().websocketHandler(new Handler<ServerWebSocket>() {
        @Override
        public void handle(final ServerWebSocket ws) {
            logger.info("ws connection established with " + ws.remoteAddress());
            ws.dataHandler(new Handler<Buffer>() {
                @Override
                public void handle(Buffer data) {
                    JsonObject item = new JsonObject(data.toString());
                    logger.info("data in -> " + item.encodePrettily());
                       // if you want to write something back in response to the client
                    //ws.writeTextFrame(...);
            }
            });
        }
    }).listen(port, new Handler<AsyncResult<HttpServer>>() {
        @Override
        public void handle(AsyncResult<HttpServer> event) {
            logger.info("ws server is up and listening on port " + port);
        }
    });

Pour plus de détails, regardez ici http://vertx.io/docs/vertx-core/java/#_websockets

donc on peut écrire son propre serveur WebSocket avec Vert.x, l'emballer comme FatJar, et l'exécuter sur son propre.

Ou bien vous pouvez intégrer Vert.x env. dans votre application, et déployer votre verticle (qui implémente le serveur ws) par programmation.


une autre alternative est la Conntow du serveur web de JBoss. Facile à intégrer dans les applications.

Ajouter ces dépendances:

<dependency>
  <groupId>io.undertow</groupId>
  <artifactId>undertow-servlet</artifactId>
  <version>${version.io.undertow}</version>
</dependency>

<dependency>
  <groupId>io.undertow</groupId>
  <artifactId>undertow-websockets-jsr</artifactId>
  <version>${version.io.undertow}</version>
</dependency>

Et voici un exemple de serveur ws:

Undertow server = Undertow.builder()
            .addHttpListener(8080, "localhost")
            .setHandler(path()
                    .addPrefixPath("/myapp", websocket(new WebSocketConnectionCallback() {

                        @Override
                        public void onConnect(WebSocketHttpExchange exchange, WebSocketChannel channel) {
                            channel.getReceiveSetter().set(new AbstractReceiveListener() {

                                @Override
                                protected void onFullTextMessage(WebSocketChannel channel, BufferedTextMessage message) {
                                    final String messageData = message.getData();
                                    for (WebSocketChannel session : channel.getPeerConnections()) {
                                        WebSockets.sendText(messageData, session, null);
                                    }
                                }
                            });
                            channel.resumeReceives();
                        }
                    }))
            .build();

    server.start();
4
répondu aymens 2017-10-25 13:17:38
la source

regardez Hirsute Cadre. Il s'agit d'une superposition de haut niveau pour les serveurs WebSocket Java couramment utilisés, comme Jetty, Netty ou Tomcat. Si vous aimez Spring Framework, vous devez certainement essayer Bristleback!

avis de non-responsabilité: je contribue au projet cadre de Bristleback.

2
répondu voitec 2013-07-02 18:54:32
la source

Apache Tomcat 8.0 implémente WebSockets 1.1 API ( JSR-356

JETTY

j'ai passé la semaine dernière à me demander comment faire un serveur WebSocket. Enfin quelque chose à travailler espère que cette aide. Il utilise les bibliothèques de la Jetée (pots).

Fichier WebRTC_IceServer.java

package com.evanstools;
import org.eclipse.jetty.server.*;
import org.eclipse.jetty.websocket.server.*;
public class WebRTC_IceServer{
public static void main(String[] args){
try{
////////////////////////
if(args.length == 0){
  System.out.printf("%s%n","WebRTC_IceServer [port]");
  return;
}
Server server = new Server(Integer.parseInt(args[0]));
WebSocketHandler.Simple webSocketHandlerSimple = new WebSocketHandler.Simple(WebsocketPOJO.class);
server.setHandler(webSocketHandlerSimple);
server.start();
server.join();
////////////////////////
}catch(Exception w){w.printStackTrace();}
}
}

File WebsocketPOJO.java

package com.evanstools;
import org.eclipse.jetty.websocket.api.annotations.*;
import org.eclipse.jetty.websocket.api.Session;
//The class must be not abstract and public.
@WebSocket
public class WebsocketPOJO{
//Flags one method in the class as receiving the On Connect event.
//Method must be public, not abstract, return void, and have a single Session parameter.
@OnWebSocketConnect
public void onWebSocketConnect(Session session){
    System.out.printf("%s%n","test client connected");
}
//Flags one method in the class as receiving the On Close event.
//Method signature must be public, not abstract, and return void.
//The method parameters:
////Session (optional)
////int closeCode (required)
////String closeReason (required)
@OnWebSocketClose
public void OnWebSocketClose(Session session,int closeCode,String closeReason){}
//Flags up to 2 methods in the class as receiving On Message events.
//You can have 1 method for TEXT messages, and 1 method for BINARY messages.
//Method signature must be public, not abstract, and return void.
//The method parameters for Text messages:
////Session (optional)
////String text (required)
//The method parameters for Binary messages:
////Session (optional)
////byte buf[] (required)
////int offset (required)
////int length (required)
@OnWebSocketMessage
public void onWebSocketMessageString(Session session, String text){}
//Flags one method in the class as receiving Error events from the WebSocket implementation.
//Method signatures must be public, not abstract, and return void.
//The method parameters:
////Session (optional)
////Throwable cause (required)
//@OnWebSocketError
//Flags one method in the class as receiving Frame events from the WebSocket implementation after they have been processed by any extensions declared during the Upgrade handshake.
//Method signatures must be public, not abstract, and return void.
//The method parameters:
////Session (optional)
///Frame (required)
//The Frame received will be notified on this method, then be processed by Jetty, possibly resulting in another event, such as On Close, or On Message. Changes to the Frame will not be seen by Jetty.
//@OnWebSocketFrame
}
0
répondu user28775 2016-12-07 11:24:53
la source

Autres questions sur