-
#677: ZPoller now supports registering multiple event handlers on a single socket or channel.
-
#685, #687: ZMQ.Socket has new methods that encode and decode messages based on a picture pattern which is compatible to ZProto:
sendPicture
,recvPicture
,sendBinaryPicture
andrecvBinaryPicture
. -
#692: Added an overload of the ZBeacon that has an additional
serverAddress
option so that the broadcast address can be specified. The default value is still255.255.255.255
. -
#694: Added a draft ZNeedle helper class for serialization and deserialization within a frame.
-
#697: Added encoding/decoding of the
COMMAND
flag when using CURVE encryption. -
#698: Added a
Msg.putShortString
method.
-
#671, #672: In the internal
zmq.io.StreamEngine
class, aZError.InstantiationException
is now thrown when a decoder or encoder cannot be instantiated. Previously, a stacktrace would be printed andnull
would be returned instead of a decoder/encoder instance. -
#673:
zmq.Mailbox.recv
now handlesEINTR
by returningnull
. This can happen, for example, if the channel is closed. -
#679: Fixed a file descriptor leak when opening a TCP connection.
-
#680: Various improvements to support for IPv6 and name resolution.
IPv6 is now enabled if the properties
java.net.preferIPv4Stack=false
orjava.net.preferIPv6Addresses=true
are set. -
#684: Fixed a bug where
zmq.Msg.getBytes
was writing to an internal buffer instead of the given buffer. -
#688: Javadoc fixes.
-
#691: Fixed a bug where timers would accumulate in the PollerBase when failed connections were retried, causing a memory leak.
-
#693: Fixed a Java 8-related compilation error.
-
#702: Removed all usage of
java.util.function
,java.util.stream
,java.util.Objects
andjava.util.Optional
, which are known to cause problems for some versions of Android. Replaced their usage with internal implementations.
-
#539, #552, #573: Implemented heartbeating between sockets as specified in https://rfc.zeromq.org/spec:37/ZMTP.
-
#556: There is now a
SocketType
enum that can be used when creating sockets. This is recommended over the old way of using integer values, which is error-prone. The overload ofZContext.createSocket
that takes an integer is still supported, but is now marked deprecated. -
#559: Added
recvStream
andrecvStrStream
instance methods to theZMQ.Socket
class. These expose a Stream of incoming messages, each of which is abyte[]
orString
, respectively. -
#560: ZMsg instance methods can now be chained.
-
#576: Added an overload of
ZMsg.recvMsg
that takes aConsumer<ZMsg> handler
and aConsumer<ZMQException> exceptionHandler
for handling the result of attempting to receive a message on a socket. -
#586: Implemented a Timer API based on the one added to libzmq in version 4.2.
-
#590: Added a
closeSelector
method to the ZContext class, to expose a way for selectors created bycreateSelector
to be closed. Note that both of these methods are also deprecated; it is not recommended to manage selectors directly, as these are managed for you by pollers. -
#614: Added a
ZMQ_SELECTOR_PROVIDERCHOOSER
socket option that allows you to define a custom SelectorProvider.
-
JeroMQ no longer supports Java 7. Dropping support for Java 7 allows us to leverage the new features of Java 8, including the use of lambda syntax to create IAttachedRunnable and IDetachedRunnable.
-
Refactored code to use Java 8 features like lambdas and streams in various places. See #570 and #650, for example.
-
#510: Polling now measures time in nanoseconds instead of microseconds, ensuring a higher degree of precision.
-
#523: Fixed a bug where ZLoop was closing the context.
-
#525: Fixed a bug in
zmq.io.StreamEngine
that was causing an infinite loop in the IO thread, blocking the application with 100% CPU usage. -
#527: Fixed a bug in
zmq.io.StreamEngine
where data could still be present inside the handshake buffer that was not decoded. -
#535: Fixed an edge case where, once in a blue moon, after a socket fails to connect, and is subsequently closed, it would still try to reconnect as if it weren't closed.
-
#546: Prior to this release, when a ZContext was initialized, its internal
ZMQ.Context
would be null initially, and the ZContextisClosed
instance method would misleadingly returntrue
; theZMQ.Context
was being created lazily whengetContext
was called on the ZContext. Worse, the internal context would be reset tonull
after closing a ZContext, which could lead to problems if another thread happened to try to use the ZContext after it was closed, resulting in a newZMQ.Context
secretly being created. Now, the internalZMQ.Context
is created upon initialization of the ZContext, and you can rely on it never being null. -
#548: Various javadoc updates and improvements. There is now a
@Draft
annotation to identify work-in-progress APIs that are unstable or experimental. -
#552: Fixed a bug where internal command messages (e.g. HEARTBEAT commands) were disrupting the REQ state machine.
-
#564: Implemented the ability to bind a socket via IPC or TCP with a dynamic ("wildcard") port and retrieve it via
ZMQ.ZMQ_LAST_ENDPOINT
. Leveraged this to make our test suite more reliable. -
#569: Fixed an issue where an overridable method was being used in the ZStar constructor.
-
#578: Fixed an issue where an errno of 48 ("address already in use") would persist longer than intended in the process of binding to a random port. Now, errno is reset to 0 after a port is found.
-
#581: Fixed a bug where, if you're polling in one thread and you close the context in another thread, it would result in an uncaught ClosedSelectorException.
-
#583: Fixed a race condition causing
ZMQ_CONNECT_RID
to sometimes be assigned to the wrong peer socket. -
#597: Fixed a bug causing the context to hang indefinitely after calling
destroy()
, if multiple sockets had connected to the same socket. -
#609: For numerous methods, when invalid arguments are passed to the method, an InvalidArgumentException with a friendly error message will now be thrown, instead of an assertion error.
-
#610: Added some asserts in places where there could potentially be NullPointerExceptions.
-
#623:
Options.rcvbuf
andOptions.sndbuf
will now adjustConfig.IN_BATCH_SIZE
andConfig.OUT_BATCH_SIZE
accordingly. -
#634: We are now using a 64-bit long, instead of a 32-bit integer, as a cursor in the internal
java.zmq.Signaler
class. This change should not affect the library user, except that it will now take longer for the value to overflow. Previously, with the 32-bit integer cursor, the Signaler could overflow within a month or so under heavy load, causing serious problems such as a server being unable to accept new client connections. -
#642, #646, #652: Removed debug printing intended for development use only.
-
#643: Added some checks in parts of the codebase related to encryption and authentication mechanisms.
-
#652: IOExceptions that occur during polling will now set
errno
more accurately depending on the exception. Previously, theerrno
would always be set toEINTR
when an IOException occurs during polling. -
#653:
ZError.toString
now defaults to"errno " + Integer.toString(code)
if a string version of that error code hasn't been implemented. -
#654: In a low-level place where an
IllegalStateException
was thrown with no arguments before, the string value of theerrno
is now included to provide some context. -
#655: In a low-level place in the polling code,
EINTR
is now correctly reported to indicate that polling was interrupted, whereas we used to miss it and try to poll again. -
#657: When destroying a ZPoller, we will no longer close the poller's Selector, as that is handled by the context.
-
#659: Made internal optimizations to ZContext. The only visible change should be that the order of the sockets when you call
getSockets()
is no longer deterministic, as we are now storing them internally in a Set rather than a List. -
#660: When creating a socket and the
maxSockets
limit is reached, a ZMQException is now thrown instead of the more generic IllegalStateException.
-
#470: Added an argument to the ZBeacon constructor to configure datagram socket blocking behavior. The default behavior (non-blocking) is preserved when the argument is omitted.
-
#474, #475, #477, #479 Added features:
- ZAuth, an actor that manages authentication and handles ZAP requests.
- ZCert, an abstraction for CURVE certificates.
- ZCertStore, a sub-optimal store for certificates.
- ZConfig, to manage the ZPL file format.
- ZMonitor, for simplified socket monitoring.
- Reinstated support for the
ZMQ_MSG_ALLOCATOR
option. Added asetMsgAllocator
method in the ZMQ class for setting a custom message allocator.
-
#477: Added an overload of
ZAgent.recv
that takes a timeout argument. -
#498: Implemented
Closable
forZMQ.Poller
, providing a way to call.close()
on a poller when you're done with it and free the selector resource to avoid memory leaks.It is recommended that you either close a poller or terminate the context when you are done polling.
-
Miscellaneous Javadoc documentation tweaks/fixes.
-
#453, #462, #471: Fixed Android-specific compilation issues.
-
#454: Fixed an issue where the router was interpreting peers' socket identities as UTF-8 strings instead of raw bytes.
-
#460: Fixed an issue where CURVE keys were being parsed as strings.
-
#461, #501: Fixed protocol handshake issues that were causing interoperability problems between applications using different versions of ZeroMQ/JeroMQ.
-
#465 Various small fixes:
- Fixed an uncaught divide by zero exception (#447).
- ZMQ.Socket class is no longer final.
- Handle interrupt caused by close in ZBeacon.
-
#468: Fix an issue where sockets would disconnect when network connection was lost.
-
#469 Various small fixes:
- Fixed an error in comparison of byte arrays in the Mechanism class.
- Handled the possibility of receiving a null message in ZSocket by returning null instead of throwing an uncaught NullPointerException.
- Fixed the return value of ZMQ.setHWM, which indicates the status of the lower-level calls to set the send and receive HWM, but was doing so incorrectly.
-
#478: Fixed an issue where, when using an XPUB/XSUB proxy, the PUB socket was throwing an error when attempting to send a message if all of the subscriptions have been removed.
-
#479: Various internal improvements.
-
#486: Fixed an issue where it was not possible to send two messages in a row without a successful receive in between, even with the RELAXED option set on the REQ socket.
-
#487 Various improvements:
- Added some method name aliases for compatibility with the jzmq API, in places where the JeroMQ method names differed.
- Miscellaneous internal refactoring to make JeroMQ code more similar to that of jzmq.
- It is not possible to get the values of the ZMQ options
ZMQ_REQ_CORRELATE
andZMQ_REQ_RELAXED
, sogetReqCorrelated
andgetReqRelaxed
are now deprecated and will throw an UnsupportedOperationException when called.
-
#492: Fixed an issue where a NullPointerException was thrown when trying to bind on an already used port, for example when the socket has a monitor.
-
#502: Use explicit mutex locks to help prevent problems caused by concurrent access to a ZContext. This makes ZContext behave more like libzmq's zctx.
- #443: Fix issue where JeroMQ was broken on Android. Security no longer depends on libsodium and is now pure Java
JeroMQ is now based off of 4.1.7 of libzmq which means it now supports additional security features.
-
#413: fixed a NullPointerException when ZMQ.ZMQ_TCP_ACCEPT_FILTER is used
-
#412: tcp accept filter null pointer exception fix
-
#366: support for
ZMQ_REQ_RELAXED
andZMQ_REQ_CORRELATE
socket options -
#375: re-added
ZMQ.Socket.disconnect
, which had been removed in 0.3.6 because the contributor who originally added it did not agree to the license change from LGPL to MPLv2
-
#374:
- fixed a NullPointerException and mangling of existing indexes in ZMQ.Poller
- fixed a Windows bug in Signaler
- other small changes to keep JeroMQ in sync with jzmq
-
#386: improved deallocation of polling Selector resources. When creating a poller via
ZMQ.Context.poller
orZContext.createPoller
, the context will manage the Selector resources and ensure that they are deallocated when the context is terminated. -
#387: (BREAKING CHANGE) It is no longer possible to create a ZMQ.Poller in any way except via a context. This is to ensure that all Selector resources are deallocated when a context is terminated.
-
#388
ZMQ.Socket.setLinger
can now be called safely after a context is terminated. -
#390: fixed a bug where terminating a context while polling would sometimes cause a ClosedChannelException.
-
#399: fixed a NullPointerException that would sometimes occur when terminating a context
-
#400: (BREAKING CHANGE)
- deprecated the setters
setIoThreads
,setMain
andsetContext
inZContext
. These parameters are set in the constructor andfinal
. Because it is no longer possible to set these values after constructing a ZContext, the setters are now no-ops.
- deprecated the setters
-
#402: added constructors for ZPoller that take a ZContext argument, thus making it possible to create a ZPoller whose Selector resources are managed by the context.
-
#292: support for
ZMQ_XPUB_NODROP
andZMQ_XPUB_VERBOSE_UNSUBSCRIBE
options -
#299: a setter for UncaughtExceptionHandlers in ZBeacon threads
-
#309: MsgAllocator allows you to define how Msgs are allocated.
-
#316: ZSocket high-level API allows you to work with sockets directly without having to manage the ZMQ context.
-
Changed from LGPL to MPLv2 license.
-
Related to changing license, the following changes were made as a result of reverting pre-0.3.6 commits by contributors who did not agree to the license change:
ZMQ.Socket.disconnect
method removed- Slight changes to the way ephemeral ports are handled.
-
#266: fixed a NullPointerException bug in
ZMsg.dump
when attempting to dump a ZMsg after its frames have been cleared -
#271, #272: misc fixes and improvements to ZAgent, ZActor, ZProxy, and ZStar
-
#295: renamed
ZMQ.Socket.setRouterHandlover
toZMQ.Socket.setRouterHandover
(typo fix) -
#301: fixed a bug where if a frame failed to send, it would still try to send the next frame
-
#306, #308, #311: misc byte buffer performance improvements and bugfixes
-
#324: implementation changes to avoid extra bytes being copied in PUB/SUB
- Capitalize constants
- Use for each style
- Issue #152 - Add unit test to test ZContext.close
- Fix mislabeling issue
- remove me from the AUTHORS file
- Sometimes hostname resolution will fail. Make sure that, if it does, we don't break the ioloop.
- Narrowed exception handling a bit. Makes me kind of nervous because the exceptions thrown are not documented.
- remove email addresses
- Fix issue #166 - Able to build using java 8
- Fix issue #166 - Fix building project in a backwards compatible way
- Replace home grown Multimap with guava
- Update README.md
- Normalize license header preamble that mirrors libzmq
- Add Trevor Bernard as a contributor and sort authors
- typo readme
- Fix issue #176 - Remove auto-generated ant build files
- Overload Socket send
- Fix style violation of unittests
- fix bug where poll does not accept -1 as argument
- Issue #176 - Remove build.xml ant file
- Fix all style violations
- Remove superfluous limit
- Move the wcursor increment after the assert
- Improve imports
- Issue #191 - Generates excess garbage on close
- Port JeroMQ to be based on libzmq 3.2.5
- Remove public method declaration in interfaces
- Revert "Remove public method declaration in interfaces"
- Change Chunk to be a static inner class
- Fix raw type parameterized warnings
- Change constructor and method declarations to be public
- Update plugins
- Fix issue where project wasn't correctly importing using new m2eclipse plugin
- Remove redundant if
- Revert checkstyle plugin update to fix build error
- Add ZBeacon implementation
- Fix checkstyle errors
- Problem: beacon messages are not always filtered out for local addresses
- Problem: current ZBeacon tests are not testing whether messages are received.
- Fix typo
- Revert "Replace home grown Multimap with guava"
- Remove redundant static modifier
- Remove redundant encoding entry
- Fix java6 build problem where req was failing with BOTTOM illegalstateexception
- Remove redundant method
- Fix #209 - Set errno on SocketBase instead of throwing IllegalArgumentException
- Fix issue #197 - Don't call setReuseAddress on windows
- Change version to 3.2.5
- Make Mailbox,Thread and Reaper closeable
- Router Handover
- Rename xterminated into xpipeTerminated to follow libzmq
- Fix exception for inproc bind fail
- Fix issue #200
- Remove redundant nested static modifer from interfaces
- Ignore .checkstyle file
- Fixed two bugs in test path. In flserver3.java ZFrame.equals(string) will always return false. and in cloneserv6.java equals method is called on an Array.
- Revert "Remove redundant method"
- Test receiving correctly a prefetched message when using a poller
- Fix issue #228 - Add ZMQ_BLOCKY to Context to get a less surprising behaviour on context termination
- Implementation proposal for Z-Components: ZPoller, ZAgent, ZStar, ZActor, ZProxy
- Fixed typo in Features section.
- Aligned punctuation and capitalized first letter in sentences.
- pom.xml: missing bracket
- Change ZMQ.bind() method to return void.
- Fixed minor issues - documentation (javadoc links, ..) - possible NPEs - simplified some statements, removed unnecessary variables, ...
- Break loop on finding the first non-printable character
- Fix issue #243 - Add a copy section in the README specifying the license
- Fix issue #245 - Double socket close no longer hangs
- Set daemon flag on poller threads.
- Set daemon flag on beacon and zthread threads.
- Fix Spinning in Reaper Thread
- Added constructors to ZMQException
- Changed ZFrame.recvFrame to return null in non-overloaded method
- Added ENOTSOCK error code
- Added EAGAIN error (code already present)
- Fix resource leak at socket close
- Fix c-style method name
- Various code improvements
- Add unbind method to org.zeromq.ZMQ.Socket
- Added double checked locking for shared variable context. getContext() and createSocket() should now be thread safe.
- Extend support for ZMQ monitors to inline with jzmq
- Apply checkstyle and sample changes
- Fixed recvFrame to return null on no data. Added Test cases.
- Corrected ZMsg documentation.
- Adds lazy create context to getContext() method
- Fix wrong Router xwrite_activated assert
- Raise exception when bind fails
- Fix issue #80
- throw an exception if the ByteBuffer provided to Msg is not flipped
- re-resolve tcp addresses on reconnections
- add convenience methods to set TCP keep alive options
- Refactor Msg to better handle memory and Java idiomatic
- Force StreamEngine to use big endian
- Remove org.jeromq.* namespace and associated tests
- Revert back to use currentTimeMillis because it's less expensive than nanoTime
- Fix issue #122 - handshake now uses ByteBuffer accessor methods directly
- Various code improvements
- Update junit to version 4.11
- Fix issue #115 - Expose all Context options
- Fix issue #58 - XPUB can receive multipart messages
- Fix issue #109 - Make ZMQ.Context and ZMQ.Socket implement java.io.Closeable
- Use UTF-8 as default charset
- Use monotonic source for time
- Use try finally idiom on locks
- Backport fix for race condition on shutdown
- sendByteBuffer should return number of sent bytes
- [maven-release-plugin] prepare release v0.3.0
- Prepare for release
- Update maven plugins
- Change groupId to zeromq
- Use the org.zeromq groupId
- Add build status icon
- Fix issue #95 - Add travis-ci support
- remove usage of bytebuffer just for the sake of a byte array
- use configurable Charset in every String.getBytes() and new String()
- support DirectByteBuffer on socket.sendByteBuffer()
- ignore whole target and also ignore Eclipse's .settings folder
- fixes zeromq#86
- Improved handling of ephemeral ports
- Possible fix for a memory leak in Poller.fd_table.
- subscriber should ignore HUGZ
- support ZMQ_DELAY_ATTACH_ON_CONNECT socket option
- Close inproc socket pairs on zmq_disconnect
- Rewrite TestConnectDelay
- Backport for LIBZMQ-541 fix
- Fix issue when building with Ant and system default encoding is not UTF-8
- Update clonesrv6.java
- Ignore CtxTerminatedException at ZContext.destroy
- Fix issue #76, #77 but at topic remove at trie
- Remove global errno
- expose special purpose raw zmq.SocketBase
- Work around for LIBZMQ-496 The problem is that other threads might still be in mailbox::send() when it is destroyed. So as a workaround, we just acquire the mutex in the destructor. Therefore the running send will finish before the mailbox is destroyed.
- patch for issue 456 Do not filter out duplicate subscriptions on the XSUB side of XSUB/XPUB, so that ZMQ_XPUB_VERBOSE doesn't get blocked by forwarding devices (as long as the devices all use ZMQ_XPUB_VERBOSE)
- Issue #72 resource leak at Reaper
- Issue #70 Remove thread local at errno
- Fix IPv6 address parsing.
- added osgi manifest headers with maven-bundle-plugin
- osgi manifest
- Fix issue #66 - Add ByteBuffer API to Sockets for sending and receiving messages
- Fix a bug that socket disconnect didn't terminate properly
- add setTCPKeepAlive socket option
- add a pom helper for the latest sonatype snapshot
- fix missing frame at monitoring
- Add chapter 5 guide
- ZMsg.recv documentation of flag options
- new timer during handling timer_event doesn't set correctly
- chapter 4 java guide
- fix a bug which unsubscribe doesn't work correctly
- Set the compiler version to 1.6
- Suppress platform dependent encoding warning
- ZContext.close doesn't have to throw an exception
- implement Closeable on ZContext
- user friendly error at bind failure
- change jeromq package namespace and cleanup guide
- Add set method for sockopt ZMQ_XPUB_VERBOSE
- Add disconnect method
- Ignore eclipse workspace files
- rewrite poller as it compatile with jzmq
- converted asyncsrv guide example to use the org.zeromq packaged code, and updated for the slightly different API.
- fix constant collision between jzmq and czmq
- simplify the ZMQ mayRaise logic
- fix typo
- make jzmq compatible and update examples
- LIBZMQ-497 send unsent data in encoder buffer at termination
- moving namespace from org.jeromq to org.zeromq
- Issue#34 inproc connect should raise ZMQException
- fix POLLOUT polling causes InvalidArgumentException
- jdk epoll bug workaround
- ZMsg.send returns boolean value
- handle ConcurrentModification Exception
- returns -1 with EAGAIN when mandatory is set and pipe is full
- enhance device code
- update README about 0.2.0 release
- remove persistence related code
- persistence helper encoder
- start 0.3.0-SNAPSHOT