seshadri seshadri - 1 year ago 82
Java Question

spymemcached java client for couchbase

I am trying to write a simple java client to interact with couchbase using spymemcached library(my requirement, I cannot use couchbase sdk)

My code looks like below -

AuthDescriptor ad = new AuthDescriptor(new String[] { "PLAIN" },
new PlainCallbackHandler(
"****", "****"));

MemcachedClient client = new MemcachedClient(
new ConnectionFactoryBuilder()
.setProtocol(ConnectionFactoryBuilder.Protocol.BINARY)
.setAuthDescriptor(ad)
.build(),
AddrUtil.getAddresses(Arrays.asList("127.0.0.1:11211")));

// Store a value (async) for one hour
client.set("someKey", 3600, "someValue");
client.set("otherKey", 3600, 100L);
client.set("1", 3600, 1);
client.set("2", 3600, 2);

// Retrieve a value.
Object myObject = client.get("someKey");
System.out.println(myObject);

Map<String, Object> someKey = client.getBulk("someKey");
for (Map.Entry<String, Object> entry : someKey.entrySet()) {
System.out.println(entry.getKey());
System.out.println(entry.getValue());
}

Collection<SocketAddress> servers = client.getAvailableServers();
System.out.println(servers);

client.shutdown();


I have couchbase server up and running in my localhost and when i run the above code, I get the following error -

2017-07-24 15:42:58.397 INFO net.spy.memcached.MemcachedConnection: Added {QA sa=/127.0.0.1:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} to connect queue
2017-07-24 15:42:58.558 ERROR net.spy.memcached.protocol.binary.SASLAuthOperationImpl: Error: Auth failure
2017-07-24 15:42:58.559 WARN net.spy.memcached.protocol.binary.BinaryMemcachedNodeImpl: Discarding partially completed op: SASL auth operation
2017-07-24 15:42:58.560 INFO net.spy.memcached.MemcachedConnection: Reconnection due to exception handling a memcached operation on {QA sa=/127.0.0.1:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=1}. This may be due to an authentication failure.
OperationException: SERVER: Auth failure
at net.spy.memcached.protocol.BaseOperationImpl.handleError(BaseOperationImpl.java:192)
at net.spy.memcached.protocol.binary.OperationImpl.finishedPayload(OperationImpl.java:204)
at net.spy.memcached.protocol.binary.SASLBaseOperationImpl.finishedPayload(SASLBaseOperationImpl.java:98)
at net.spy.memcached.protocol.binary.OperationImpl.readPayloadFromBuffer(OperationImpl.java:196)
at net.spy.memcached.protocol.binary.OperationImpl.readFromBuffer(OperationImpl.java:139)
at net.spy.memcached.MemcachedConnection.readBufferAndLogMetrics(MemcachedConnection.java:861)
at net.spy.memcached.MemcachedConnection.handleReads(MemcachedConnection.java:840)
at net.spy.memcached.MemcachedConnection.handleReadsAndWrites(MemcachedConnection.java:720)
at net.spy.memcached.MemcachedConnection.handleIO(MemcachedConnection.java:683)
at net.spy.memcached.MemcachedConnection.handleIO(MemcachedConnection.java:436)
at net.spy.memcached.MemcachedConnection.run(MemcachedConnection.java:1446)
2017-07-24 15:42:58.561 WARN net.spy.memcached.MemcachedConnection: Closing, and reopening {QA sa=/127.0.0.1:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=1}, attempt 0.
2017-07-24 15:42:58.564 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for someKey.
2017-07-24 15:42:58.565 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for otherKey.
2017-07-24 15:42:58.565 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for 1.
2017-07-24 15:42:58.565 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for 2.
2017-07-24 15:42:58.565 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for someKey.
2017-07-24 15:42:58.659 WARN net.spy.memcached.auth.AuthThread: Authentication failed to /127.0.0.1:11211, Status: {OperationStatus success=false: cancelled}
2017-07-24 15:42:58.661 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for someKey.
2017-07-24 15:42:58.661 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for otherKey.
2017-07-24 15:42:58.661 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for 1.
2017-07-24 15:42:58.662 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for 2.
2017-07-24 15:42:58.662 WARN net.spy.memcached.MemcachedConnection: Could not redistribute to another node, retrying primary node for someKey.


I also tried connecting to the localhost instance using telnet and ran stats command but got this error -
SERVER_ERROR unauthorized, null bucket


Appreciate any inputs to solve this issue !

Answer Source

This problem occurs with Couchbase Server 5.0 Beta 2 version, when I tried with a stable version Couchbase Server 4.6.0 it works fine.

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download