當前位置: 首頁>>代碼示例>>Java>>正文


Java TransactionResult類代碼示例

本文整理匯總了Java中io.lettuce.core.TransactionResult的典型用法代碼示例。如果您正苦於以下問題:Java TransactionResult類的具體用法?Java TransactionResult怎麽用?Java TransactionResult使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TransactionResult類屬於io.lettuce.core包,在下文中一共展示了TransactionResult類的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: exec

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
@Override
public TransactionResult exec() {
  Span span = helper.buildSpan("exec");
  try {
    return commands.exec();
  } catch (Exception e) {
    onError(e, span);
    throw e;
  } finally {
    span.finish();
  }
}
 
開發者ID:opentracing-contrib,項目名稱:java-redis-client,代碼行數:13,代碼來源:TracingRedisCommands.java

示例2: deleteAll

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
/**
 * Delete all the keys in the region data store, and its respective TTLs.
 * 
 * Time Complexity is O(2N), where N is the number of keys in the region.
 * This N is multiplied by 2 since there are N ttls for N keys.
 */
@Override
public void deleteAll() {

	RedisFuture<TransactionResult> future = null;
	try {

		/*
		 * Atomic transaction (MULTI/EXEC) to delete the data store for the region,
		 * and the respective ttls data store.
		 * 
		 * (see https://redis.io/commands/multi)
		 */
		asyncCommands.multi();
		asyncCommands.del( region );
		asyncCommands.del( ttls );
		future = asyncCommands.exec();
		future.get( waitTimeSeconds, TimeUnit.SECONDS );


	} catch ( Exception e ) {
		if ( cfEngine.thisPlatform != null ) {
			cfEngine.log( getName() + " deleteAllFailed: " + e.getMessage() );
		}
		if ( future != null ) {
			future.cancel( false );
		}
	}
}
 
開發者ID:OpenBD,項目名稱:openbd-core,代碼行數:35,代碼來源:RedisCacheImpl.java

示例3: deleteExactTrue

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
private void deleteExactTrue( String key ) {

		RedisFuture<TransactionResult> futureDel = null;

		try {

			/*
			 * Atomic transaction (MULTI/EXEC) to delete the key from the region data store,
			 * and the respective ttl from the ttls data store for this region.
			 * 
			 * (see https://redis.io/commands/multi)
			 */
			asyncCommands.multi();
			asyncCommands.zrem( ttls, key );
			asyncCommands.hdel( region, key );
			futureDel = asyncCommands.exec();
			futureDel.get( waitTimeSeconds, TimeUnit.SECONDS );

		} catch ( Exception e ) {
			if ( cfEngine.thisPlatform != null ) {
				cfEngine.log( getName() + " deleteExactFalse: " + e.getMessage() );
			}
			if ( futureDel != null ) {
				futureDel.cancel( false );
			}
		}

	}
 
開發者ID:OpenBD,項目名稱:openbd-core,代碼行數:29,代碼來源:RedisCacheImpl.java

示例4: exec

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
@Override
public RedisFuture<TransactionResult> exec() {
  Span span = helper.buildSpan("exec");
  return setCompleteAction(commands.exec(), span);
}
 
開發者ID:opentracing-contrib,項目名稱:java-redis-client,代碼行數:6,代碼來源:TracingRedisAsyncCommands.java

示例5: get

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
/**
 * Return the given key, if it is not expired.
 * 
 * Time Complexity is 2*O(1).
 */
@Override
public cfData get( String key ) {

	// Calculate the time now, represented as a decimal
	long nowSecs = Instant.now().getMillis() / 1000;
	double nowTtl = getDecimalTtl( nowSecs );

	RedisFuture<TransactionResult> future = null;
	TransactionResult transactionResult = null;
	try {
		if ( key == null ) {
			throw new Exception( "'key' cannot be null" );
		}

		/*
		 * Atomic transaction (MULTI/EXEC) to check get the key and its ttl in one round.
		 * 
		 * (see https://redis.io/commands/multi)
		 */
		asyncCommands.multi();
		asyncCommands.zscore( ttls, key ); // Time complexity: O(1)
		asyncCommands.hget( region, key ); // Time complexity: O(1)
		future = asyncCommands.exec();

		transactionResult = future.get( waitTimeSeconds, TimeUnit.SECONDS );

		// Get the result of the 'ZSCORE' command, the TTL for the given key
		Double keyTtl = transactionResult.get( 0 );
		String base64value = null;
		if ( keyTtl > nowTtl ) {
			// Set the value to be returned, when the TTL is not expired
			base64value = transactionResult.get( 1 );
		}

		return base64value == null ? null : (cfData) Transcoder.fromString( base64value );

	} catch ( Exception e ) {
		if ( cfEngine.thisPlatform != null ) {
			cfEngine.log( getName() + " get Failed: " + e.getMessage() );
		}
		if ( future != null ) {
			future.cancel( true );
		}
	}
	return null;
}
 
開發者ID:OpenBD,項目名稱:openbd-core,代碼行數:52,代碼來源:RedisCacheImpl.java

示例6: set

import io.lettuce.core.TransactionResult; //導入依賴的package包/類
/**
 * Set the given key and value in the region for this cache instance,
 * with the given time-to-live, i.e. ageMS.
 * 
 * Time Complexity is O(1) to set the key-value pair and O(log(N) to set the tll for the key,
 * where N is the number of the keys in this region.
 * 
 * @param key
 *          the given key.
 * @param data
 *          the value for this key.
 * @param ageMS
 *          the ttl for this key-value pair. If ageMS < 1 || ageMs > dayMs, then ageMS = dayMs.
 * @param idleTime
 *          not used in this implementation.
 */
@Override
public void set( String key, cfData data, long ageMS, long idleTime ) {

	// Convert the ageMs, tll in milliseconds, to ageSecs, ttl in seconds.
	long ageSecs;
	if ( ageMS < 1 || ageMS > DAY_MS ) {
		ageSecs = DAY_MS / 1000;
	} else {
		ageSecs = ageMS / 1000;
	}

	// Get the time now in seconds plus the ageSecs in seconds
	long nowSecs = Instant.now().getMillis() / 1000 + ageSecs;

	// Convert the time now in seconds to a decimal
	double ttl = getDecimalTtl( nowSecs );

	RedisFuture<TransactionResult> future = null;
	RedisFuture<Boolean> futureHset = null;
	RedisFuture<Long> futureZadd = null;

	try {
		if ( key == null ) {
			throw new Exception( "'key' cannot be null" );
		}

		if ( data == null ) {
			throw new Exception( "'data' cannot be null" );
		}

		String base64value = Transcoder.toString( data );

		/*
		 * Atomic transaction (MULTI/EXEC) to set the key and its ttl.
		 * 
		 * (see https://redis.io/commands/multi)
		 */
		asyncCommands.multi();
		futureHset = asyncCommands.hset( region, key, base64value ); // Time complexity: O(1)
		futureZadd = asyncCommands.zadd( ttls, ttl, key ); // O(log(N)) for each key added, where N is the number of keys in the sorted set.
		future = asyncCommands.exec();
		future.get( waitTimeSeconds, TimeUnit.SECONDS );

	} catch ( Exception e ) {
		if ( cfEngine.thisPlatform != null ) {
			cfEngine.log( getName() + " set Failed: " + e.getMessage() );
		}
		if ( futureHset != null ) {
			futureHset.cancel( true );
		}
		if ( futureZadd != null ) {
			futureZadd.cancel( true );
		}
		if ( future != null ) {
			future.cancel( true );
		}
	}
}
 
開發者ID:OpenBD,項目名稱:openbd-core,代碼行數:75,代碼來源:RedisCacheImpl.java


注:本文中的io.lettuce.core.TransactionResult類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。