All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy