Early Access Now Available for the New Java Messaging API!

marc
marc Member, Administrator, Moderator, Employee Posts: 972 admin
edited March 2021 in Early Access API #1

πŸš€ I'm excited to announce that Early Access is now available for our new PubSub+ Messaging API for Java!

Java as a language, and how developers use it, has evolved quite a bit over the past 15 years; and while JCSMP (our current Java API) has treated us well it is our oldest API and it is definitely time for a new, modern and clean API for all of the Java developers out there. Yes, this means no more usage of XMLMessage objects when you're not even using XML ;) This new Java API is intended to modernize the way developers write Java clients for PubSub+ Event Brokers and will take a builder style approach – similar what our recently released Python API does.

Enough jibber jabber, here is the info you need to try it out:

  • This Early Access API currently supports:

    • Connection management to PubSub+ event brokers
    • Addition and removal of topic subscriptions
    • Sending and receiving Direct and Guaranteed Messages
    • Message compression
    • Use of Selectors
    • Message Replay
    • Structured data types that allow interoperability between various architectures and programming languages
    • Kerberos authentication
  • Note that it does not yet support the following features:

    • Request/Reply message exchange pattern
    • PubSub+ Cache Client API support
    • Session Transactions
    • XA Transactions
    • Queue browsing
  • EA Download is attached to this post. Unzip and be sure to read the readme.txt (Don't worry, it will be available via maven central once GA)

  • Samples available to get you started quickly!
  • Javadocs Available on Developer Hub

We're Welcoming feedback during the Early Access period! Feel free to respond in this thread or start a new one. Please tag myself, @amackenzie and/or @Aaron as we'll be looking for feedback on this new API! You might even get some SWAG ;)

Tagged:

Comments

  • Thrillstone
    Thrillstone Member Posts: 1 ✭

    @marc I'm looking to setup my pom file to try out the new API. Do I need both the JCSMP dependency and the solace-messaging-client? If so, why do I need both. Thanks!

  • amackenzie
    amackenzie Member, Employee Posts: 269 Solace Employee

    @Thrillstone (great username btw) the new Java API is a wrapper for JCSMP and thus needs it as a pom dependency. It's similar to how the Solace JMS provider is a wrapper for JCSMP and also requires JCSMP as a dependency.

  • Aaron
    Aaron Member, Administrator, Moderator, Employee Posts: 664 admin
    edited May 2021 #4

    Hey team... I'm whipping up some new samples with the New Java API! It's definitely different than JCSMP, but I like it a lot... feels very modern. Hoping other people give it a try..! πŸ‘

  • tkunnumpurath
    tkunnumpurath Member, Employee Posts: 11 Solace Employee
    edited June 2021 #5

    Getting the following error when I try to build the samples via maven:

    [ERROR] Failed to execute goal on project solace-messaging-client-sampler: Could not resolve dependencies for project com.solace:solace-messaging-client-sampler:jar:0.0.5-SNAPSHOT: The following artifacts could not be resolved: com.solacesystems:sol-jcsmp:jar:10.9.1-nextGen.41309, com.solace:solace-messaging-client:jar:0.0.5-SNAPSHOT: Could not find artifact com.solacesystems:sol-jcsmp:jar:10.9.1-nextGen.41309 in central (https://repo.maven.apache.org/maven2) -> [Help 1]
    
  • Aaron
    Aaron Member, Administrator, Moderator, Employee Posts: 664 admin

    Hey @tkunnumpurath didn't see this comment. Check out the new home for NewJava samples: https://github.com/SolaceSamples/solace-samples-java-new

    I think your maven error exists because it's not looking for JARs locally.

  • GreenRover
    GreenRover Member Posts: 22 ✭✭

    Is the feature to provision queues still included? I can find it.

  • Tamimi
    Tamimi Member, Administrator, Employee Posts: 543 admin

    hey @GreenRover are you referring to queue creation from the API? You can use the MissingResourcesCreationStrategy method to create a queue if it doesnt exist

  • GreenRover
    GreenRover Member Posts: 22 ✭✭
    edited September 2021 #10

    I tested our use cases (those are allot), here what i found for the moment.

    Problem 1:

            final PersistentMessageReceiver receiver = service
                    .createPersistentMessageReceiverBuilder()
                    .withMissingResourcesCreationStrategy(MissingResourcesCreationStrategy.CREATE_ON_START)
                    .withSubscriptions(
                            TopicSubscription.of("demo/foo/>"),
                            TopicSubscription.of("demo/baa/g*/alpha")
                    )
                    .withActivationPassivationSupport(stateChangeListener)
                    .withMessageAutoAcknowledgement()
                    .build(Queue.durableExclusiveQueue("demo_queue_name"))
                    .start();
    

    com.solacesystems.jcsmp.JCSMPErrorResponseException: 400: Subscription Already Exists - Queue 'demo_queue_name' - Topic 'demo/foo/>'

    Dint found the option to ignore subscription that are already assigned to the queue.

    Problem 2:

            final PersistentMessageReceiver receiver = service
                    .createPersistentMessageReceiverBuilder()
                    .withMissingResourcesCreationStrategy(MissingResourcesCreationStrategy.CREATE_ON_START)
                    .withSubscriptions(
                            TopicSubscription.of("demo/foo/>"),
                            TopicSubscription.of("demo/baa/g*/alpha")
                    )
                    .withMessageAutoAcknowledgement()
                    .withActivationPassivationSupport(stateChangeListener)
                    .build(Queue.durableExclusiveQueue("demo_queue_name"))
                    .start();
    

    When switching withMessageAutoAcknowledgement and withActivationPassivationSupport
    i get an not helping exception:
    Exception in thread "main" java.lang.UnsupportedOperationException: Unsupported property value type com.solace.samples.java.ConsumeQueue$$Lambda$110/0x00000008002d6440
    When using the builder/fluent setter pattern, the order how the calling the methods should be irrelevant.

    Reproducer: https://gist.github.com/GreenRover/b5d1ceee1bafef1b48dd439a88c522ac#file-consumequeue-java

    Problem 3:

    The handling of to big messages is still broken (Ticket RT-55160).
    If i send a 31MB message to the broker:

    • I get in log: ERROR com.solac.messa.publi.PersistentMessagePublisherImpl - DefaultProducer should not be log:null
      com.solacesystems.jcsmp.JCSMPErrorResponseException: 400: Document Is Too Large

    • Broker close connection

    • Client lib reconnects
    • Client lib try to resend the same message again
    • Endless loop

    Reproducer: https://gist.github.com/GreenRover/b5d1ceee1bafef1b48dd439a88c522ac#file-publishbigmessages-java

  • amackenzie
    amackenzie Member, Employee Posts: 269 Solace Employee

    Hello @GreenRover ,

    The 1st 2 look like potential bugs. Can I ask that you log a ticket with Solace Support to get dev to act on them?

    The 3rd is (as you have pointed out) a known issue and was not expected to have been fixed with Java API 1.0.0. We are working on addressing this and the fix will also pertain to a subsequent release of the Java API.

  • GreenRover
    GreenRover Member Posts: 22 ✭✭
    edited October 2021 #12

    There could be better documentation for:
    OutboundMessageBuilder.withProperty
    https://docs.solace.com/API-Developer-Online-Ref-Documentation/pubsubplus-java/
    Are there constants for thinks like "dmq eligible" , "correlation id"?

    Why is messageId included but here (https://docs.solace.com/API-Developer-Online-Ref-Documentation/java/index.html?com/solacesystems/jcsmp/JCSMPProperties.html) deprecated?

    @amackenzie Please have your developers to read this. I currently not interested to use the new lib.
    I like the new concepts but the current jcsmp looks much more stable.
    Just wanted to give a a try an made short testing. I have no official task to evaluate this lib. Just using some spare time and be unable to spend more time for this.