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


Python etcd.EtcdAlreadyExist方法代碼示例

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


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

示例1: _compare_and_swap_block

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def _compare_and_swap_block(self, block):
        """
        Write the block using an atomic Compare-and-swap.
        """

        # If the block has a db_result, CAS against that.
        if block.db_result is not None:
            _log.debug("CAS Update block %s", block)
            try:
                self.etcd_client.update(block.update_result())
            except EtcdCompareFailed:
                raise CASError(str(block.cidr))
        else:
            _log.debug("CAS Write new block %s", block)
            key = _block_datastore_key(block.cidr)
            value = block.to_json()
            try:
                self.etcd_client.write(key, value, prevExist=False)
            except EtcdAlreadyExist:
                raise CASError(str(block.cidr)) 
開發者ID:projectcalico,項目名稱:libcalico,代碼行數:22,代碼來源:ipam.py

示例2: atom_update_key

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def atom_update_key(self, key_type, key, func, *args, **kwargs):
        """Wrap a function to atomically update a key

        Read the current value of the key and pass it to the wrapped
        function which returns the updated value. Then, try to
        update the value with compare and swap and restart the whole
        process if there was a race.

        """
        while True:
            try:
                value, index = self.read_key_index(key_type, key,
                                                   realindex=True)
                nargs = args + (value,)
                new_value, ret = func(*nargs, **kwargs)

                logging.debug(
                    "Trying atomic update \"%s\" for \"%s\" ",
                        str(value).strip(),
                        str(new_value).strip())

                if value is None:
                    if new_value is None:
                        return ret
                    else:
                        self.write_key_new(key_type, key, new_value)
                else:
                    self.write_key_index(key_type, key, new_value,
                                         index)

                return ret
            except ( etcd.EtcdCompareFailed,
                     etcd.EtcdKeyNotFound,
                     etcd.EtcdAlreadyExist ):
                logging.debug("Retrying atomic update") 
開發者ID:cea-hpc,項目名稱:pcocc,代碼行數:37,代碼來源:Batch.py

示例3: _get_lock

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def _get_lock(self, lock_key, ttl=3, timeout=4):
        if timeout is not None:
            timeout_time = time.time() + timeout  # 5 minutes from now
        while True:
            try:
                etcd_client.write(lock_key, 'lock', prevExist=False, ttl=ttl)
                return True
            except etcd.EtcdAlreadyExist:
                if timeout is None or time.time() > timeout_time:
                    raise UnableToLockResource("%s already locked" % lock_key, {
                        "lock_key": lock_key,
                        "ttl": ttl})
                else:
                    time.sleep(0.2) 
開發者ID:app-registry,項目名稱:appr,代碼行數:16,代碼來源:models_index.py

示例4: test_locked

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def test_locked(monkeypatch, package_b64blob):

    def write(path, data, prevExist, ttl=None):
        raise etcd.EtcdAlreadyExist

    def read(path):
        assert path == ""
        return True
    monkeypatch.setattr("appr.models.kv.models_index_base.ModelsIndexBase.get_lock.im_func.__defaults__", (3, 0.1))

    monkeypatch.setattr("appr.models.kv.etcd.etcd_client.read", read)
    monkeypatch.setattr("appr.models.kv.etcd.etcd_client.write", write)
    with pytest.raises(UnableToLockResource):
        p = Package('a/b', "1.0.1", 'kpm', Blob("a/b", package_b64blob))
        p.save() 
開發者ID:app-registry,項目名稱:appr,代碼行數:17,代碼來源:test_etcd_models_index.py

示例5: init_phase

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def init_phase(self):
        """
        Initially, the rendezvous state is expected to be one of:

        1. empty (non-existent) - in this case we try to create a new one.
        2. joinable - we try to join it.
        3. final - we announce ourselves as waiting, and go into monitoring mode

        Any other state is considered transitional, and will be retried after
        a short delay.

        Returns:
            ``(rdzv_version, rank, world_size)``

        Raises:
            RendezvousClosedException - current rendezvous was/is closed
            EtcdRendezvousRetryableFailure - observed some intermediate
             state, which is best handled by retrying later
        """
        try:
            active_version = self.try_create_rendezvous()
            state = json.loads(active_version.value)
            log.info("New rendezvous state created: " + str(state))
        except etcd.EtcdAlreadyExist:
            active_version, state = self.get_rdzv_state()
            # Note: it is possible for above query to fail (etcd.EtcdKeyNotFound),
            # but this is ok for us - just means we'll restart from beginning.
            log.info("Observed existing rendezvous state: " + str(state))

        if state["status"] == "closed":
            raise RendezvousClosedException()

        if state["status"] == "joinable":
            return self.join_phase(state["version"])

        if state["status"] == "final":
            self.handle_existing_rendezvous(state["version"])
            raise EtcdRendezvousRetryImmediately()

        self.try_wait_for_state_change(etcd_index=active_version.etcd_index + 1)
        raise EtcdRendezvousRetryableFailure() 
開發者ID:pytorch,項目名稱:elastic,代碼行數:43,代碼來源:etcd_rendezvous.py

示例6: create_path_if_not_exists

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def create_path_if_not_exists(self, full_path, ttl=None):
        try:
            self.client.write(
                key=full_path, value=None, dir=True, prevExist=False, ttl=ttl
            )
        except etcd.EtcdAlreadyExist:
            pass 
開發者ID:pytorch,項目名稱:elastic,代碼行數:9,代碼來源:etcd_rendezvous.py

示例7: store_extra_data

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def store_extra_data(self, rdzv_version, key, value):
        node = self.get_path("/rdzv/v_{}/extra_data".format(rdzv_version))
        try:
            # If first time we are storing anything:
            extra_data = self.client.write(
                key=node, value=json.dumps({key: value}), prevExist=False
            )
            return
        except etcd.EtcdAlreadyExist:
            pass

        # CAS loop, to make sure we don't lose concurrent stores.
        while True:
            # We never delete extra_data. Failure here should be fatal, no special handling.
            extra_data = self.client.get(node)

            new_extra_data_value = json.loads(extra_data.value)
            new_extra_data_value[key] = value

            try:
                extra_data = self.client.test_and_set(
                    key=node,
                    value=json.dumps(new_extra_data_value),
                    prev_value=extra_data.value,
                )
                return
            except etcd.EtcdCompareFailed:
                log.info("Store extra_data CAS unsuccessful, retrying")
                time.sleep(0.1) 
開發者ID:pytorch,項目名稱:elastic,代碼行數:31,代碼來源:etcd_rendezvous.py

示例8: add

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def add(self, key, num: int) -> int:
        """
        Atomically increment a value by an integer amount. The integer is
        represented as a string using base 10. If key is not present,
        a default value of ``0`` will be assumed.

        Returns:
             the new (incremented) value


        """
        b64_key = self._encode(key)
        # c10d Store assumes value is an integer represented as a decimal string
        try:
            # Assume default value "0", if this key didn't yet:
            node = self.client.write(
                key=self.prefix + b64_key,
                value=self._encode(str(num)),  # i.e. 0 + num
                prevExist=False,
            )
            return int(self._decode(node.value))
        except etcd.EtcdAlreadyExist:
            pass

        while True:
            # Note: c10d Store does not have a method to delete keys, so we
            # can be sure it's still there.
            node = self.client.get(key=self.prefix + b64_key)
            new_value = self._encode(str(int(self._decode(node.value)) + num))
            try:
                node = self.client.test_and_set(
                    key=node.key, value=new_value, prev_value=node.value
                )
                return int(self._decode(node.value))
            except etcd.EtcdCompareFailed:
                cas_delay() 
開發者ID:pytorch,項目名稱:elastic,代碼行數:38,代碼來源:etcd_rendezvous.py

示例9: test_claim_block_affinity_already_owned

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def test_claim_block_affinity_already_owned(self):
        """
        Test _claim_block_affinity() when we already own the block

        Order of events
        1 Write host affinity
        2 Try to write the new block, but this fails.
        3 Read the block, check its affinity
        """

        block = _test_block_empty_v4()
        m_result0 = Mock(spec=EtcdResult)
        m_result0.value = block.to_json()

        # Reads at 3
        self.m_etcd_client.read.return_value = m_result0

        # Write at 1, 2
        self.m_etcd_client.write.side_effect = [None, EtcdAlreadyExist()]

        self.client._claim_block_affinity(block.host_affinity,
                                          block.cidr, IPAMConfig())

        key = _block_datastore_key(block.cidr)
        value = block.to_json()
        self.m_etcd_client.write.assert_has_calls([call(ANY, ""),
                                                   call(key, value,
                                                        prevExist=False)])
        self.m_etcd_client.read.assert_called_once_with(key, quorum=True) 
開發者ID:projectcalico,項目名稱:libcalico,代碼行數:31,代碼來源:test_ipam.py

示例10: test_claim_block_affinity_already_deleted

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def test_claim_block_affinity_already_deleted(self):
        """
        Test _claim_block_affinity() when another process deletes the host
        affinity under our feet.
        This can occur when the block gets claimed by one host and a second
        host has two competing processes trying to claim the block. They can
        both try to clean up at the same time.

        Order of events
        1 Write host affinity
        2 Try to write the new block, but this fails
        3 Re-read the block, discover another host owns it
        4 Delete key from 1 but find it's already removed.
        """

        block = _test_block_empty_v4()
        m_result0 = Mock(spec=EtcdResult)
        m_result0.value = block.to_json()

        block_our_host = AllocationBlock(BLOCK_V4_1, "test_host2", False)

        # Reads at 3
        self.m_etcd_client.read.return_value = m_result0

        # Write at 1, 2
        self.m_etcd_client.write.side_effect = [None, EtcdAlreadyExist()]

        # Delete at 4
        self.m_etcd_client.delete.side_effect = [EtcdKeyNotFound()]

        with self.assertRaises(HostAffinityClaimedError):
            self.client._claim_block_affinity(block_our_host.host_affinity,
                                              block.cidr, IPAMConfig())

        key = _block_datastore_key(block_our_host.cidr)
        value = block_our_host.to_json()
        self.m_etcd_client.write.assert_has_calls([call(ANY, ""),
                                                   call(key, value,
                                                        prevExist=False)])
        self.m_etcd_client.read.assert_called_once_with(key, quorum=True)
        self.m_etcd_client.delete.assert_called_once_with(ANY) 
開發者ID:projectcalico,項目名稱:libcalico,代碼行數:43,代碼來源:test_ipam.py

示例11: test_compare_and_swap_handle_cas_error_new

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def test_compare_and_swap_handle_cas_error_new(self):
        """
        Test _compare_and_swap_handle hitting a CAS error on adding a new
        handle.
        """
        handle_id = "handle_id_1"
        block_cidr = BLOCK_V4_1
        amount = 10

        handle0 = AllocationHandle(handle_id)
        handle0.increment_block(block_cidr, amount)
        self.m_etcd_client.write.side_effect = EtcdAlreadyExist

        self.assertRaises(CASError, self.client._compare_and_swap_handle,
                          handle0) 
開發者ID:projectcalico,項目名稱:libcalico,代碼行數:17,代碼來源:test_ipam.py

示例12: _compare_and_swap_handle

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def _compare_and_swap_handle(self, handle):
        """
        Write the handle using an atomic Compare-and-swap.
        """
        # If the handle has a db_result, CAS against that.
        if handle.db_result is not None:
            _log.debug("Handle %s exists.", handle.handle_id)
            if handle.is_empty():
                # Handle is now empty.  Delete it instead of an update.
                _log.debug("Handle %s is empty.", handle.handle_id)
                key = _handle_datastore_key(handle.handle_id)
                try:
                    self.etcd_client.delete(
                        key,
                        prevIndex=handle.db_result.modifiedIndex)
                except EtcdCompareFailed:
                    raise CASError(handle.handle_id)
            else:
                _log.debug("Handle %s is not empty.", handle.handle_id)
                try:
                    self.etcd_client.update(handle.update_result())
                except EtcdCompareFailed:
                    raise CASError(handle.handle_id)
        else:
            _log.debug("CAS Write new handle %s", handle.handle_id)
            assert not handle.is_empty(), "Don't write empty handle."
            key = _handle_datastore_key(handle.handle_id)
            value = handle.to_json()
            try:
                self.etcd_client.write(key, value, prevExist=False)
            except EtcdAlreadyExist:
                raise CASError(handle.handle_id) 
開發者ID:projectcalico,項目名稱:libcalico,代碼行數:34,代碼來源:ipam.py

示例13: attempt_to_acquire_leader

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def attempt_to_acquire_leader(self, permanent=False):
        try:
            return bool(self.retry(self._client.write,
                                   self.leader_path,
                                   self._name,
                                   ttl=None if permanent else self._ttl,
                                   prevExist=False))
        except etcd.EtcdAlreadyExist:
            logger.info('Could not take out TTL lock')
        except (RetryFailedError, etcd.EtcdException):
            pass
        return False 
開發者ID:zalando,項目名稱:patroni,代碼行數:14,代碼來源:etcd.py

示例14: etcd_write

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def etcd_write(self, key, value, **kwargs):
    if key == '/service/exists/leader':
        raise etcd.EtcdAlreadyExist
    if key in ['/service/test/leader', '/patroni/test/leader'] and \
            (kwargs.get('prevValue') == 'foo' or not kwargs.get('prevExist', True)):
        return True
    raise etcd.EtcdException 
開發者ID:zalando,項目名稱:patroni,代碼行數:9,代碼來源:test_etcd.py

示例15: __init__

# 需要導入模塊: import etcd [as 別名]
# 或者: from etcd import EtcdAlreadyExist [as 別名]
def __init__(
        self,
        endpoints,
        prefix,
        run_id,
        num_min_workers,
        num_max_workers,
        timeout,
        last_call_timeout,
        **kwargs,
    ):
        self._prefix = prefix
        self._run_id = run_id
        self._num_min_workers = num_min_workers
        self._num_max_workers = num_max_workers
        self._timeout = timeout
        self._last_call_timeout = last_call_timeout

        # For cleaning up TTL refresher threads (for ephemeral keys)
        self._lease_run_id_stop = None
        self._lease_this_rank_stop = None

        if not self._prefix.endswith("/"):
            self._prefix += "/"

        self.client = etcd.Client(host=endpoints, allow_reconnect=True, **kwargs)
        log.info("Etcd machines: " + str(self.client.machines))

        # Setup a permanent prefix dir, if didn't exist
        if self._prefix != "/":
            self.create_path_if_not_exists(self._prefix)

        # Lease a "sub-root" node specific to this job instance (run_id)
        self.create_path_if_not_exists(self.get_path(""), ttl=CONST_RUNID_SUBROOT_TTL)
        self._lease_run_id_stop = self.setup_lease_renewal(
            self.get_path(""), ttl=CONST_RUNID_SUBROOT_TTL
        )

        # Subdir for all rendezvous work
        self.create_path_if_not_exists(self.get_path("/rdzv"))

        # Create a rendezvous version counter, if doesn't exist
        try:
            self.client.write(
                key=self.get_path("/rdzv/version_counter"), value="0", prevExist=False
            )
        except etcd.EtcdAlreadyExist:
            pass 
開發者ID:pytorch,項目名稱:elastic,代碼行數:50,代碼來源:etcd_rendezvous.py


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