Java JMS Anfängerfragen

Kr0e

Gesperrter Benutzer
Hi,

ein Server stellt ja Objekte wie Queues oder Topics zur Verfügung...

a) Wie erstelle ich zur Laufzeit des Servers neue Topics, Queues ?
b) Wenn ich z.B. eine Datei über eine Queue schicken will, darf dann diese
Queue NUR von diesen beiden Sessions benutzt werden ? Sprich pro Datentransfer dann quasi eine Queue ?
c) Wie erreiche ich es, dass eine Message nicht "acknoledged" werden muss ? (Sprich wenn sie einfach abgerufen wird, dann is sie weg... Bei einem Dateitransfer wäre acknoledge ja ziemlich performance raubend...)
d) Kann ich iwo nachschauen, wieviel gerade in eine Queue bereits drin ist ? Um z.B. zu merken, dass der Empfänger mit dem Abholen der Nachrichten nicht hinterher kommt, und dann vlt. einen Listener iwo registrieren um zu erfahren wenn die Queue wieder leer ist oder so ?

Ich hoffe ihr könnt mir da etwas weiterhelfen!

Gruß,
Chris

PS: Ich benutze HornetQ als Provider...
 

FArt

Top Contributor
Ich werde nicht die API Doku für dich lesen und die passenden Methoden posten, aber ich gebe dir schon mal den richtigen Tritt:

a) Wie erstelle ich zur Laufzeit des Servers neue Topics, Queues ?
Dafür wird es eine Factory geben.
b) Wenn ich z.B. eine Datei über eine Queue schicken will, darf dann diese
Queue NUR von diesen beiden Sessions benutzt werden ? Sprich pro Datentransfer dann quasi eine Queue ?
Nein. Es können beliebig viele Sender in die Queue posten und beliebig viele Listener darauf lauschen. Eine Message wird aber immer nur von einem Listener verarbeitet.
c) Wie erreiche ich es, dass eine Message nicht "acknoledged" werden muss ? (Sprich wenn sie einfach abgerufen wird, dann is sie weg... Bei einem Dateitransfer wäre acknoledge ja ziemlich performance raubend...)
Ich glaube nicht, dass der ack "performanceraubend" ist. Wo hast du das her? Sonst setzt man halt auf autoack, da wird aber natürlich auch ein ack ausgeführt.
d) Kann ich iwo nachschauen, wieviel gerade in eine Queue bereits drin ist ? Um z.B. zu merken, dass der Empfänger mit dem Abholen der Nachrichten nicht hinterher kommt, und dann vlt. einen Listener iwo registrieren um zu erfahren wenn die Queue wieder leer ist oder so ?
In der Regel kann man einen peek auf eine Queue machen. Das gibt die API her.

Wie das genau funktioniert, dazu solltest du mal die Doku lesen.
 

Kr0e

Gesperrter Benutzer
Nunja, bei einem Ack. muss doch nach dem Empfangen einer Nachricht nochmal eine Nachricht geschickt werden : "Ja, ich hab alles bekommen !" ... Bei einem Dateitransfer ist das doch eher hinderlich, wenn immer auf eine "Bestätigung" gewartet werden muss... Oder angenommen, man wolle JMS nutzen um Koordinaten von Spielern zu übertragen...

Es geht nich darum, dass jemand die API liest und mir die erklärt... Mehr als das was du mir gerade geschrieben hast, wollte ich doch garnicht :) Danke!

Gruß,
Chris

PS: Bisher hab ich nur die Möglichkeit gefunden, Topics und Queues temporär zu erstellen, mit createTemporaryQueue/Topic...
Ist das das selbe wie ne "normale Queue/Topic" ?
 
Zuletzt bearbeitet:

FArt

Top Contributor
Nein, temporäre Queues sind ... temporär...
Normle Queues können persistent sein und überleben (mit Messages) auch einen Serverstop.

Ein ack kostet keine Performance. Du kannst auch die Option "duplicates ok" wählen, da passiert aber auch implizit ein ack.
 

Kr0e

Gesperrter Benutzer
Hmm, ich hab mir jetzt mal die Core API von hornetQ angesehen... Das geht da mit einem "PRE_ACK" sprich der Server macht das schon, bevor er sie dem consumer zuteilt... Ein wirklich sehr ausgereiftes Framework. Ich denke ich werde lieber das nutzen...
Die JMS-Spezifikation ist ja schon irgendwie relativ begrenzt... Bzw. man müsste dann wohl mit JMX den Rest machen, der einem "fehlt". Aber mal schauen.. Danke soweit :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
LarsLovstrom ConcurrentHashMap in Java bei komplexen Objekten Netzwerkprogrammierung 2
D HTTP Apache-HttpClient/UNAVAILABLE (java 1.4) Netzwerkprogrammierung 18
M JAX-WS unter Java 17 plötzlich nicht mehr möglich Netzwerkprogrammierung 5
K Java RMI bricht ab wenn Remote eine Methode ausgeführt werden soll Netzwerkprogrammierung 5
M HTTP Let's Encrypt und Java Trust-Store Netzwerkprogrammierung 6
JaXnPriVate Java HTTPS Server (Secure Sockets) Netzwerkprogrammierung 15
Tobero Java serversocket nicht nur zuganglich für localhost Netzwerkprogrammierung 6
D path-Variablen in eine URL hinzufügen mit Java 1.8 Netzwerkprogrammierung 2
D WebSocket Server mit HTML Client und Java Server Netzwerkprogrammierung 5
S Von Java auf passwortgeschützten Server zugreifen + Umgang mit Ports Netzwerkprogrammierung 28
S Probleme bei Java-Installation auf Server (Linux/Shell/Terminal) Netzwerkprogrammierung 6
S Java: Anbindung an einen realen Server? (+ Portfreigabe) Netzwerkprogrammierung 8
H Socket Chat entwickeln mit Java Server Client Netzwerkprogrammierung 4
x46 Java SSLContext erstellen mit SSL-Zertifikat Netzwerkprogrammierung 1
P Jenkins Login per Java Download Manager Netzwerkprogrammierung 15
N Java socket Programmierung Filme verschicken Netzwerkprogrammierung 20
S HTTP Post?!? - Java Server Netzwerkprogrammierung 7
F Verbindung zu einem LDAP Server über Java Netzwerkprogrammierung 4
K Java Websocketserver Problem | Android to Pi Netzwerkprogrammierung 1
R Anfängerbeispiel: Suche Java-Anwendung die http-Anfragen in Tomcat liest Netzwerkprogrammierung 8
V Browsergame mit Java(WebSocketServer) als Backend? Netzwerkprogrammierung 5
platofan23 Socket Java Socket mit DynDns nicht erreichbar Netzwerkprogrammierung 6
S Fragen zu Java Webservice mit Axis2 Netzwerkprogrammierung 0
M Mit Java Mail Mails an Webmailer schicken Netzwerkprogrammierung 1
mor16Euro HTTP Php website mit Java aktualisiern Netzwerkprogrammierung 6
T HTTP JAVA Browser Konsolenanfrage(JavaScript) Netzwerkprogrammierung 7
L Socket Wie kann man in Java die Anzahl der Objekte in einem InputStream sehen ohne ihn durchgehen zu müssen Netzwerkprogrammierung 1
M Socket Verbindung Matlab(Server) Java(Client) Netzwerkprogrammierung 1
M Socket peer to peer Verbindung zwischen Java und Matlab Netzwerkprogrammierung 0
L Remote Desktop per Java steuern Netzwerkprogrammierung 4
F Server für Java Applikationen Netzwerkprogrammierung 16
J Webserver mit Java schreiben? Netzwerkprogrammierung 4
D JAVA RMI Netzwerkprogrammierung 1
K HTTP Mit Java HTML Codeauslesen um damit zu arbeiten Netzwerkprogrammierung 7
V Kann man mit Hilfe eines Java-Programms den Zugriff auf bestimmte Internetseiten verhinden? Netzwerkprogrammierung 3
J HTTP [Java 9] Neuer HTTP Client - Tutorial Netzwerkprogrammierung 3
T Mikrofonaudio über Java Server an Webbrowser streamen Netzwerkprogrammierung 13
A Bestimmter URL/Certificate per Java immer vertrauen (Trustmanager/HostnameVerifier) Netzwerkprogrammierung 1
T VPN-Verbindung über Java Netzwerkprogrammierung 4
M HTTP PATCH Request mit Java ausführen Netzwerkprogrammierung 2
Niggo_ Probleme mit Java Mail Netzwerkprogrammierung 14
Aruetiise Socket Java Programm auf Server Netzwerkprogrammierung 3
L FTP Java Interpreter unterbindet SSL Handshake Netzwerkprogrammierung 2
C IFrame mit java auslesen Netzwerkprogrammierung 1
A FTP wie kann ich von java auf datei in fpt://192.168.178.1 lesen/schreiben? Netzwerkprogrammierung 3
C Datensammlung mit Java RMI Netzwerkprogrammierung 0
K Java Jsoup : OnLoad Netzwerkprogrammierung 0
S Java Chat Server Netzwerkprogrammierung 8
Carres HTTP Vorhandenen Session-ID Cookie von Firefox, Chrome oder IE in Java verwenden Netzwerkprogrammierung 2
B Java+Grbl: G-Code Befehle mit Java an Arduino senden und lesen Netzwerkprogrammierung 1
Z HTTP HTML Element auslesen in Java Netzwerkprogrammierung 1
T Socket Java Programm hängt sich auf bei dem versuch von einem Socket scanner Daten zu erhalten. Netzwerkprogrammierung 1
Thallius HTTP HTTPS unter Java 1.6 schlägt fehl Netzwerkprogrammierung 4
Thallius Java Application über ZScaler benutzer? Netzwerkprogrammierung 0
P Chat in Java Netzwerkprogrammierung 3
C java.net.ConnectException: Operation timed out? Netzwerkprogrammierung 2
M Java Eingabe auf FTP Server übergeben Netzwerkprogrammierung 4
T curl request in java umwandeln Netzwerkprogrammierung 4
M Socket Java Server: NullPointerException Netzwerkprogrammierung 4
J Java Server empfängt php inhalt nicht Netzwerkprogrammierung 1
I Socket Kommunikation C / Java Netzwerkprogrammierung 2
H Machbarkeitsfrage: TCP/IP Client (z.B. Netty) für Java Web Applcation Netzwerkprogrammierung 1
L Java RMI Objekt konsistenz Netzwerkprogrammierung 1
H Portforwarding umgehen in Java? Netzwerkprogrammierung 5
D Response in Java Servlet erzeugen Netzwerkprogrammierung 0
X Mit Java eine Applikation auf einem anderen Windows Rechner (Windows Server 2008) starten Netzwerkprogrammierung 1
E HttpUrlConnectionExample cannot be resolved to a type / Java 8 Netzwerkprogrammierung 1
F Socket Java Server mit Android App, Antwort vom Server an App Netzwerkprogrammierung 5
M Java-Programm aus dem Web laden Netzwerkprogrammierung 3
S HTTP-Requeste von Browser mit Java sniffen? Netzwerkprogrammierung 9
J access denied (“java.net.SocketPermission”…) mit Java 8 Netzwerkprogrammierung 1
N CURL requests in Java Netzwerkprogrammierung 6
P Kritische Java-Anwendung und Citrix veröffentlichen Netzwerkprogrammierung 1
F Java Server Scanner oder InputStream kann nicht gelsesen werden! Netzwerkprogrammierung 6
1 Netty NIO oder Java IO Netzwerkprogrammierung 2
1 Via Java mit WLAN Netzwerken verbinden Netzwerkprogrammierung 5
J Java Service Wrapper Netzwerkprogrammierung 1
K Mit Java ASPX Webseite fern steuern Netzwerkprogrammierung 2
H Socket Java | Server sendet Nachricht nur wenn vorher eine JOptionPane-Nachricht ausgegeben wurde. Netzwerkprogrammierung 2
K Emailsenden via Java Applikation Netzwerkprogrammierung 5
L Mit Java über PHP in MySQL anmelden (Login script) Netzwerkprogrammierung 3
C Java Chat Admin Kenzeichnung Netzwerkprogrammierung 14
P PHP Script per Java ausführen Netzwerkprogrammierung 2
P PPTP Protokoll für JAVA Netzwerkprogrammierung 14
T php/java-bridge Netzwerkprogrammierung 16
D Webseite(mit JavaScript-Element) mit Java auslesen Netzwerkprogrammierung 0
G Multiple Clients and one Server --> java.lang.NullPointerException Netzwerkprogrammierung 1
E Java Server übers Internet erreichen Netzwerkprogrammierung 4
D Socket Error: java.lang.NullPointerException Netzwerkprogrammierung 1
windl AirPlay mittels Java Netzwerkprogrammierung 0
R Email mit Java API Netzwerkprogrammierung 1
P Java Deauth / Deauthentication request Netzwerkprogrammierung 10
F Socket Java - Server/Client simple Netzwerkprogrammierung 1
E HTTP java.lang.IllegalArgumentException: protocol = http host = null Netzwerkprogrammierung 1
R Java - Socketprogrammierung Netzwerkprogrammierung 10
B Methoden und Konstruktoren von Java.net package werden nicht geladen Netzwerkprogrammierung 2
L Email versenden mit Java funktioniert nicht, Fehlermeldungen: MessagingException & SocketException Netzwerkprogrammierung 10
V Templates für Java Client rabbitmq Netzwerkprogrammierung 4
N Socket java.net.ConnectException Netzwerkprogrammierung 5
A Java Server - IOS Client Applikation Netzwerkprogrammierung 20

Ähnliche Java Themen

Neue Themen


Oben