io.vertx.redis.client.Redis Maven / Gradle / Ivy
/*
* Copyright 2019 Red Hat, Inc.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* The Apache License v2.0 is available at
* http://www.opensource.org/licenses/apache2.0.php
*
* You may elect to redistribute this code under either of these licenses.
*/
package io.vertx.redis.client;
import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.annotations.Nullable;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.*;
import io.vertx.redis.client.impl.RedisClient;
import io.vertx.redis.client.impl.RedisClusterClient;
import io.vertx.redis.client.impl.RedisSentinelClient;
import java.util.List;
/**
* A simple Redis client.
*/
@VertxGen
public interface Redis {
/**
* Create a new redis client using the default client options.
* @param vertx the vertx instance
* @return the client
*/
static Redis createClient(Vertx vertx) {
return createClient(vertx, new RedisOptions());
}
/**
* Create a new redis client using the default client options. Does not support rediss (redis over ssl scheme) for now.
* @param connectionString a string URI following the scheme: redis://[username:password@][host][:port][/database]
* @param vertx the vertx instance
* @return the client
* @see Redis scheme on www.iana.org
*/
static Redis createClient(Vertx vertx, String connectionString) {
return createClient(vertx, new RedisOptions().setConnectionString(connectionString));
}
/**
* Create a new redis client using the given client options.
* @param vertx the vertx instance
* @param options the user provided options
* @return the client
*/
static Redis createClient(Vertx vertx, RedisOptions options) {
switch (options.getType()) {
case STANDALONE:
return new RedisClient(vertx, options);
case SENTINEL:
return new RedisSentinelClient(vertx, options);
case CLUSTER:
return new RedisClusterClient(vertx, options);
default:
throw new IllegalStateException("Unknown Redis Client type: " + options.getType());
}
}
/**
* Connects to the redis server.
*
* @param handler the async result handler
* @return a reference to this, so the API can be used fluently
*/
@Fluent
Redis connect(Handler> handler);
/**
* Closes the client and terminates any connection.
*/
void close();
/**
* Send the given command to the redis server or cluster.
* @param command the command to send
* @param onSend the asynchronous result handler.
* @return fluent self.
*/
@Fluent
default Redis send(Request command, Handler> onSend) {
connect(connect -> {
if (connect.failed()) {
onSend.handle(Future.failedFuture(connect.cause()));
return;
}
final RedisConnection conn = connect.result();
conn.send(command, send -> {
try {
onSend.handle(send);
} finally {
// regardless of the result, return the connection to the pool
conn.close();
}
});
});
return this;
}
/**
* Sends a list of commands in a single IO operation, this prevents any inter twinning to happen from other
* client users.
*
* @param commands list of command to send
* @param onSend the asynchronous result handler.
* @return fluent self.
*/
@Fluent
default Redis batch(List commands, Handler>> onSend) {
connect(connect -> {
if (connect.failed()) {
onSend.handle(Future.failedFuture(connect.cause()));
return;
}
final RedisConnection conn = connect.result();
conn.batch(commands, batch -> {
try {
onSend.handle(batch);
} finally {
// regardless of the result, return the connection to the pool
conn.close();
}
});
});
return this;
}
}