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


PHP ArrayUtils::consistentHashSort方法代碼示例

本文整理匯總了PHP中ArrayUtils::consistentHashSort方法的典型用法代碼示例。如果您正苦於以下問題:PHP ArrayUtils::consistentHashSort方法的具體用法?PHP ArrayUtils::consistentHashSort怎麽用?PHP ArrayUtils::consistentHashSort使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ArrayUtils的用法示例。


在下文中一共展示了ArrayUtils::consistentHashSort方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: getConnection

	/**
	 * Get a Redis object with a connection suitable for fetching the specified key
	 * @return Array (server, RedisConnRef) or (false, false)
	 */
	protected function getConnection( $key ) {
		if ( count( $this->servers ) === 1 ) {
			$candidates = $this->servers;
		} else {
			$candidates = $this->servers;
			ArrayUtils::consistentHashSort( $candidates, $key, '/' );
			if ( !$this->automaticFailover ) {
				$candidates = array_slice( $candidates, 0, 1 );
			}
		}

		foreach ( $candidates as $server ) {
			$conn = $this->redisPool->getConnection( $server );
			if ( $conn ) {
				return array( $server, $conn );
			}
		}
		return array( false, false );
	}
開發者ID:nahoj,項目名稱:mediawiki_ynh,代碼行數:23,代碼來源:RedisBagOStuff.php

示例2: getConnection

 /**
  * Get a Redis object with a connection suitable for fetching the specified key
  * @param string $key
  * @return array (server, RedisConnRef) or (false, false)
  */
 protected function getConnection($key)
 {
     $candidates = array_keys($this->serverTagMap);
     if (count($this->servers) > 1) {
         ArrayUtils::consistentHashSort($candidates, $key, '/');
         if (!$this->automaticFailover) {
             $candidates = array_slice($candidates, 0, 1);
         }
     }
     while (($tag = array_shift($candidates)) !== null) {
         $server = $this->serverTagMap[$tag];
         $conn = $this->redisPool->getConnection($server);
         if (!$conn) {
             continue;
         }
         // If automatic failover is enabled, check that the server's link
         // to its master (if any) is up -- but only if there are other
         // viable candidates left to consider. Also, getMasterLinkStatus()
         // does not work with twemproxy, though $candidates will be empty
         // by now in such cases.
         if ($this->automaticFailover && $candidates) {
             try {
                 if ($this->getMasterLinkStatus($conn) === 'down') {
                     // If the master cannot be reached, fail-over to the next server.
                     // If masters are in data-center A, and slaves in data-center B,
                     // this helps avoid the case were fail-over happens in A but not
                     // to the corresponding server in B (e.g. read/write mismatch).
                     continue;
                 }
             } catch (RedisException $e) {
                 // Server is not accepting commands
                 $this->handleException($conn, $e);
                 continue;
             }
         }
         return array($server, $conn);
     }
     $this->setLastError(BagOStuff::ERR_UNREACHABLE);
     return array(false, false);
 }
開發者ID:rrameshs,項目名稱:mediawiki,代碼行數:45,代碼來源:RedisBagOStuff.php

示例3: getConnection

 /**
  * @return Status Uses RediConnRef as value on success
  */
 protected function getConnection()
 {
     if (!isset($this->conn)) {
         $conn = false;
         $servers = $this->ring->getLocations($this->key, 3);
         ArrayUtils::consistentHashSort($servers, $this->key);
         foreach ($servers as $server) {
             $conn = $this->pool->getConnection($this->serversByLabel[$server], $this->logger);
             if ($conn) {
                 break;
             }
         }
         if (!$conn) {
             return Status::newFatal('pool-servererror', implode(', ', $servers));
         }
         $this->conn = $conn;
     }
     return Status::newGood($this->conn);
 }
開發者ID:paladox,項目名稱:mediawiki,代碼行數:22,代碼來源:PoolCounterRedis.php

示例4: getTableByKey

 /**
  * Get the server index and table name for a given key
  * @param string $key
  * @return array Server index and table name
  */
 protected function getTableByKey($key)
 {
     if ($this->shards > 1) {
         $hash = hexdec(substr(md5($key), 0, 8)) & 0x7fffffff;
         $tableIndex = $hash % $this->shards;
     } else {
         $tableIndex = 0;
     }
     if ($this->numServers > 1) {
         $sortedServers = $this->serverNames;
         ArrayUtils::consistentHashSort($sortedServers, $key);
         reset($sortedServers);
         $serverIndex = key($sortedServers);
     } else {
         $serverIndex = 0;
     }
     return array($serverIndex, $this->getTableNameByShard($tableIndex));
 }
開發者ID:MediaWiki-stable,項目名稱:1.26.1,代碼行數:23,代碼來源:SqlBagOStuff.php

示例5: getConnection

 /**
  * Get a Redis object with a connection suitable for fetching the specified key
  * @param string $key
  * @return array (server, RedisConnRef) or (false, false)
  */
 protected function getConnection($key)
 {
     $candidates = array_keys($this->serverTagMap);
     if (count($this->servers) > 1) {
         ArrayUtils::consistentHashSort($candidates, $key, '/');
         if (!$this->automaticFailover) {
             $candidates = array_slice($candidates, 0, 1);
         }
     }
     foreach ($candidates as $tag) {
         $server = $this->serverTagMap[$tag];
         $conn = $this->redisPool->getConnection($server);
         if ($conn) {
             return array($server, $conn);
         }
     }
     $this->setLastError(BagOStuff::ERR_UNREACHABLE);
     return array(false, false);
 }
開發者ID:GoProjectOwner,項目名稱:mediawiki,代碼行數:24,代碼來源:RedisBagOStuff.php

示例6: getConnection

 /**
  * Get a Redis object with a connection suitable for fetching the specified key
  * @param string $key
  * @return array (server, RedisConnRef) or (false, false)
  */
 protected function getConnection($key)
 {
     $candidates = array_keys($this->serverTagMap);
     if (count($this->servers) > 1) {
         ArrayUtils::consistentHashSort($candidates, $key, '/');
         if (!$this->automaticFailover) {
             $candidates = array_slice($candidates, 0, 1);
         }
     }
     foreach ($candidates as $tag) {
         $server = $this->serverTagMap[$tag];
         $conn = $this->redisPool->getConnection($server);
         if (!$conn) {
             continue;
         }
         try {
             $info = $conn->info();
             // Check if this server has an unreachable redis master
             if ($info['role'] === 'slave' && $info['master_link_status'] === 'down' && $this->automaticFailover) {
                 // If the master cannot be reached, fail-over to the next server.
                 // If masters are in data-center A, and slaves in data-center B,
                 // this helps avoid the case were fail-over happens in A but not
                 // to the corresponding server in B (e.g. read/write mismatch).
                 continue;
             }
         } catch (RedisException $e) {
             // Server is not accepting commands
             $this->handleException($conn, $e);
             continue;
         }
         return array($server, $conn);
     }
     $this->setLastError(BagOStuff::ERR_UNREACHABLE);
     return array(false, false);
 }
開發者ID:D66Ha,項目名稱:mediawiki,代碼行數:40,代碼來源:RedisBagOStuff.php


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