Managing the interaction with the server is primarily the job of the client library but most of the libraries also provide some insight into what is happening under the covers.
For example, the client library may provide a mechanism to get the connection's current status:
Connection nc =Nats.connect("nats://demo.nats.io:4222");System.out.println("The Connection is: "+nc.getStatus());nc.close();System.out.println("The Connection is: "+nc.getStatus());
// you can find out where you connected:t.log(`connected to a nats server version ${nc.info.version}`);// or information about the data in/out of the client:conststats=nc.stats();t.log(`client sent ${stats.outMsgs} messages and received ${stats.inMsgs}`);
nc =NATS()await nc.connect( servers=["nats://demo.nats.io:4222"], )# Do something with the connection.print("The connection is connected?", nc.is_connected)whileTrue:if nc.is_reconnecting:print("Reconnecting to NATS...")breakawait asyncio.sleep(1)await nc.close()print("The connection is closed?", nc.is_closed)
NATS.start(max_reconnect_attempts:2) do|nc|puts"Connect is connected?: #{nc.connected?}" timer = EM.add_periodic_timer(1) doif nc.closing?puts"Connection closed..."EM.cancel_timer(timer)NATS.stopendif nc.reconnecting?puts"Reconnecting to NATS..."nextendendend