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


Python cassandra.cluster方法代碼示例

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


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

示例1: create_ks

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def create_ks(session, name, rf):
    query = 'CREATE KEYSPACE %s WITH replication={%s}'
    if isinstance(rf, int):
        # we assume simpleStrategy
        query = query % (name, "'class':'SimpleStrategy', 'replication_factor':%d" % rf)
    else:
        assert len(rf) >= 0, "At least one datacenter/rf pair is needed"
        # we assume networkTopologyStrategy
        options = (', ').join(['\'%s\':%d' % (d, r) for d, r in rf.items()])
        query = query % (name, "'class':'NetworkTopologyStrategy', %s" % options)

    try:
        retry_till_success(session.execute, query=query, timeout=120, bypassed_exception=cassandra.OperationTimedOut)
    except cassandra.AlreadyExists:
        logger.warn('AlreadyExists executing create ks query \'%s\'' % query)

    session.cluster.control_connection.wait_for_schema_agreement(wait_time=120)
    #Also validates it was indeed created even though we ignored OperationTimedOut
    #Might happen some of the time because CircleCI disk IO is unreliable and hangs randomly
    session.execute('USE {}'.format(name)) 
開發者ID:apache,項目名稱:cassandra-dtest,代碼行數:22,代碼來源:dtest.py

示例2: __init__

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def __init__(self, cluster=Cluster(['127.0.0.1'], connect_timeout=30), keyspace='cstar_perf', email_notifications=False):
        """Instantiate DB model object for interacting with the C* backend.

        cluster - Python driver object for accessing Cassandra
        keyspace - the keyspace to use
        email_notifications - if True, perform email notifications for some actions. Defaults to False.
        """
        log.info("Initializing Model...")
        self.cluster = cluster if type(cluster) == Cluster else Cluster(cluster)
        self.keyspace = keyspace
        self.email_notifications = email_notifications
        self.__maybe_create_schema()
        self.__shared_session = self.get_session()
        ## Prepare statements:
        self.__prepared_statements = {}
        for name, stmt in Model.statements.items():
            # log.debug("Preparing statement: {stmt}".format(stmt=stmt))
            self.__prepared_statements[name] = self.get_session().prepare(stmt)

        ### ZeroMQ publisher for announcing jobs as they come in:
        zmq_context = zmq.Context()
        self.zmq_socket = zmq_context.socket(zmq.PUSH)
        self.zmq_socket.connect("tcp://127.0.0.1:5556")

        log.info("Model initialized") 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:27,代碼來源:model.py

示例3: stop

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def stop(self):
        if self.__stopped:
            return

        self.__stopped = True
        # pytests may appear to hang forever waiting for cluster tear down. are all driver session objects shutdown?
        # to debug hang you can add the following at the top of the test
        #     import faulthandler
        #     faulthandler.enable()
        #
        # and then when the hang occurs send a SIGABRT to the pytest process (e.g. kill -SIGABRT <pytest_pid>)
        # this will print a python thread dump of all currently alive threads
        self.join(timeout=30)
        if self.__error is not None:
            raise self.__error 
開發者ID:apache,項目名稱:cassandra-dtest,代碼行數:17,代碼來源:dtest.py

示例4: create_cf_simple

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def create_cf_simple(session, name, query):
    try:
        retry_till_success(session.execute, query=query, timeout=120, bypassed_exception=cassandra.OperationTimedOut)
    except cassandra.AlreadyExists:
        logger.warn('AlreadyExists executing create cf query \'%s\'' % query)
    session.cluster.control_connection.wait_for_schema_agreement(wait_time=120)
    #Going to ignore OperationTimedOut from create CF, so need to validate it was indeed created
    session.execute('SELECT * FROM %s LIMIT 1' % name) 
開發者ID:apache,項目名稱:cassandra-dtest,代碼行數:10,代碼來源:dtest.py

示例5: execute

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def execute(values):
    
    #randomly set consistency level to quorum 
    #which will fail on a single node cluster
    CL1 = ConsistencyLevel.QUORUM if random.random() < 0.2 else ConsistencyLevel.ONE
    CL2 = ConsistencyLevel.QUORUM if random.random() < 0.2 else ConsistencyLevel.ONE
    insert_statement_prepared[0].consistency_level = CL1
    insert_statement_prepared[1].consistency_level = CL2
    
    # put both writes (cluster 1 and cluster 2) into a list
    writes = []
    #insert 1st statement into db1 session, table 1
    writes.append(db1.execute_async(insert_statement_prepared[0], values))
    #insert 2nd statement into db2 session, table 2
    writes.append(db2.execute_async(insert_statement_prepared[1], values))
    
    # loop over futures and output success/fail
    results = []
    for i in range(0,len(writes)):
        try:
            row = writes[i].result()
            results.append(1)
        except Exception:
            results.append(0)
            #log exception if you like
            #logging.exception('Failed write: %s', ('Cluster 1' if (i==0) else 'Cluster 2'))
        
    results.append(values)
    log(results)
    
    #did we have failures?
    if (results[0]==0):
        #do something, like re-write to cluster 1
        log('Write to cluster 1 failed')
    if (results[1]==0):
        #do something, like re-write to cluster 2
        log('Write to cluster 2 failed') 
開發者ID:scylladb,項目名稱:scylla-code-samples,代碼行數:39,代碼來源:dual_writes.py

示例6: connect_cassandra

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def connect_cassandra(is_client_encryption_enable):
    connected = False
    attempt = 0
    session = None
    _ssl_context = None

    if is_client_encryption_enable:

        ssl_context = SSLContext(PROTOCOL_TLSv1)
        ssl_context.load_verify_locations(certfile)
        ssl_context.verify_mode = CERT_REQUIRED
        ssl_context.load_cert_chain(
            certfile=usercert,
            keyfile=userkey)
        _ssl_context = ssl_context

    while not connected and attempt < 10:
        try:
            cluster = Cluster(contact_points=["127.0.0.1"], ssl_context=_ssl_context)
            session = cluster.connect()
            connected = True
        except cassandra.cluster.NoHostAvailable:
            attempt += 1
            time.sleep(10)

    return session 
開發者ID:thelastpickle,項目名稱:cassandra-medusa,代碼行數:28,代碼來源:integration_steps.py

示例7: get_session

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_session(self, shared=True):
        try:
            if shared:
                try:
                    session = self.__shared_session
                except AttributeError:
                    session = self.cluster.connect(self.keyspace)
            else:
                session = self.cluster.connect(self.keyspace)
        except cassandra.InvalidRequest, e:
            # Only attempt to create the schema if we get an error that it
            # doesn't exist:
            if "Keyspace '{ks}' does not exist".format(ks=self.keyspace) in e.message:
                self.__maybe_create_schema()
            session = self.cluster.connect(self.keyspace) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:17,代碼來源:model.py

示例8: schedule_test

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def schedule_test(self, test_id, test_series, user, cluster, test_definition):
        session = self.get_session()
        test_definition['test_id'] = str(test_id)
        test_json = json.dumps(test_definition)
        session.execute(self.__prepared_statements['insert_test'], (test_id, user, cluster, 'scheduled', test_json))
        session.execute(self.__prepared_statements['insert_series'], (test_series, test_id))
        session.execute(self.__prepared_statements['insert_test_status'], ('scheduled', cluster, test_id, user, test_definition['title']))
        self.zmq_socket.send_string("scheduled {cluster} {test_id}".format(**locals()))
        return test_id 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:11,代碼來源:model.py

示例9: update_test_progress_msg

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def update_test_progress_msg(self, test_id, progress_msg):
        if not isinstance(test_id, uuid.UUID):
            test_id = uuid.UUID(test_id)
        session = self.get_session()
        test = self.get_test(test_id)
        session.execute(self.__prepared_statements['update_test_set_progress_msg'], (progress_msg, test_id))
        session.execute(self.__prepared_statements['update_test_status_set_progress_msg'],
                        (progress_msg, 'in_progress', test['cluster'], test_id)) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:10,代碼來源:model.py

示例10: update_test_status

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def update_test_status(self, test_id, status):
        assert status in TEST_STATES, "{status} is not a valid test state".format(status=status)
        session = self.get_session()
        if not isinstance(test_id, uuid.UUID):
            test_id = uuid.UUID(test_id)
        test = self.get_test(test_id)
        original_status = self.get_test_status(test_id)
        # Update tests table:
        if status == "completed":
            completed_date = uuid.uuid1()
            session.execute(self.__prepared_statements['update_test_set_status_completed'], (status, completed_date, test_id ))
            # Add denormalized copy in tests_
            session.execute(self.__prepared_statements['insert_test_completed'], ("completed", completed_date, test_id, test['cluster'], test['test_definition']['title'], test['user']))
        else:
            session.execute(self.__prepared_statements['update_test_set_status'], (status, test_id))
        # Remove the old status from test_status:
        session.execute(self.__prepared_statements['delete_test_status'], (test['status'], test['cluster'], test_id))
        # Add the new status to test_status:
        session.execute(self.__prepared_statements['insert_test_status'], (status, test['cluster'], test_id, test['user'], test['test_definition']['title']))
        self.zmq_socket.send_string("{status} {cluster} {test_id}".format(status=status, cluster=test['cluster'], test_id=test_id))
        log.info("test status is: {status}".format(status=status))

        # Send the user an email when the status updates:
        if self.email_notifications and status not in ('scheduled','in_progress') and status != original_status:
            TestStatusUpdateEmail([test['user']], status=status, name=test['test_definition']['title'],
                                  test_id=test_id).send()
        return namedtuple('TestStatus', 'test_id status')(test_id, status) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:29,代碼來源:model.py

示例11: get_scheduled_tests

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_scheduled_tests(self, cluster, limit=999999999):
        return self.get_test_status_by_cluster('scheduled', cluster, 'ASC', limit) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:4,代碼來源:model.py

示例12: get_failed_tests

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_failed_tests(self, cluster, limit=999999999):
        return self.get_test_status_by_cluster('failed', cluster, 'DESC', limit) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:4,代碼來源:model.py

示例13: get_cancelled_tests

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_cancelled_tests(self, cluster, limit=999999999):
        return self.get_test_status_by_cluster('cancelled', cluster, 'DESC', limit) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:4,代碼來源:model.py

示例14: get_next_scheduled_test

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_next_scheduled_test(self, cluster):
        session = self.get_session()
        rows = session.execute(self.__prepared_statements['select_next_scheduled'], (cluster,))
        tests = [self.__test_row_to_dict(r) for r in rows]
        try:
            return tests[0]
        except IndexError:
            raise NoTestsScheduledError('No tests scheduled for {cluster}'.format(cluster=cluster)) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:10,代碼來源:model.py

示例15: get_in_progress_tests

# 需要導入模塊: import cassandra [as 別名]
# 或者: from cassandra import cluster [as 別名]
def get_in_progress_tests(self, cluster, limit=999999999):
        return self.get_test_status_by_cluster('in_progress', cluster, 'ASC', limit) + \
            self.get_test_status_by_cluster('cancel_pending', cluster, 'ASC', limit) 
開發者ID:datastax,項目名稱:cstar_perf,代碼行數:5,代碼來源:model.py


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