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


Python pymysqlreplication.BinLogStreamReader方法代碼示例

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


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

示例1: test_connection_stream_lost_event

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_connection_stream_lost_event(self):
        self.stream.close()
        self.stream = BinLogStreamReader(
            self.database, server_id=1024, blocking=True,
            ignored_events=self.ignoredEvents())

        query = "CREATE TABLE test (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)
        query2 = "INSERT INTO test (data) VALUES('a')"
        for i in range(0, 10000):
            self.execute(query2)
        self.execute("COMMIT")

        self.assertIsInstance(self.stream.fetchone(), RotateEvent)
        self.assertIsInstance(self.stream.fetchone(), FormatDescriptionEvent)

        event = self.stream.fetchone()

        self.assertIsInstance(event, QueryEvent)
        self.assertEqual(event.query, query)

        self.conn_control.kill(self.stream._stream_connection.thread_id())
        for i in range(0, 10000):
            event = self.stream.fetchone()
            self.assertIsNotNone(event) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:27,代碼來源:test_basic.py

示例2: test_skip_to_timestamp

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_skip_to_timestamp(self):
        self.stream.close()
        query = "CREATE TABLE test_1 (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)
        time.sleep(1)
        query = "SELECT UNIX_TIMESTAMP();"
        timestamp = self.execute(query).fetchone()[0]
        query2 = "CREATE TABLE test_2 (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query2)

        self.stream = BinLogStreamReader(
            self.database,
            server_id=1024,
            skip_to_timestamp=timestamp,
            ignored_events=self.ignoredEvents(),
            )
        event = self.stream.fetchone()
        self.assertIsInstance(event, QueryEvent)
        self.assertEqual(event.query, query2) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:21,代碼來源:test_basic.py

示例3: test_drop_column

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_drop_column(self):
        self.stream.close()
        self.execute("CREATE TABLE test_drop_column (id INTEGER(11), data VARCHAR(50))")
        self.execute("INSERT INTO test_drop_column VALUES (1, 'A value')")
        self.execute("COMMIT")
        self.execute("ALTER TABLE test_drop_column DROP COLUMN data")
        self.execute("INSERT INTO test_drop_column VALUES (2)")
        self.execute("COMMIT")

        self.stream = BinLogStreamReader(
            self.database,
            server_id=1024,
            only_events=(WriteRowsEvent,),
            )
        try:
            self.stream.fetchone()  # insert with two values
            self.stream.fetchone()  # insert with one value
        except Exception as e:
            self.fail("raised unexpected exception: {exception}".format(exception=e))
        finally:
            self.resetBinLog() 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:23,代碼來源:test_basic.py

示例4: test_alter_column

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_alter_column(self):
        self.stream.close()
        self.execute("CREATE TABLE test_alter_column (id INTEGER(11), data VARCHAR(50))")
        self.execute("INSERT INTO test_alter_column VALUES (1, 'A value')")
        self.execute("COMMIT")
        # this is a problem only when column is added in position other than at the end
        self.execute("ALTER TABLE test_alter_column ADD COLUMN another_data VARCHAR(50) AFTER id")
        self.execute("INSERT INTO test_alter_column VALUES (2, 'Another value', 'A value')")
        self.execute("COMMIT")

        self.stream = BinLogStreamReader(
            self.database,
            server_id=1024,
            only_events=(WriteRowsEvent,),
            )
        event = self.stream.fetchone()  # insert with two values
        # both of these asserts fail because of issue underlying proble described in issue #118
        # because it got table schema info after the alter table, it wrongly assumes the second
        # column of the first insert is 'another_data'
        # ER: {'id': 1, 'data': 'A value'}
        # AR: {'id': 1, 'another_data': 'A value'}
        self.assertIn("data", event.rows[0]["values"])
        self.assertNot("another_data", event.rows[0]["values"])
        self.assertEqual(event.rows[0]["values"]["data"], 'A value')
        self.stream.fetchone()  # insert with three values 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:27,代碼來源:test_basic.py

示例5: test_position_gtid

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_position_gtid(self):
        query = "CREATE TABLE test (id INT NOT NULL, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)
        query = "BEGIN;"
        self.execute(query)
        query = "INSERT INTO test (id, data) VALUES(1, 'Hello');"
        self.execute(query)
        query = "COMMIT;"
        self.execute(query)

        query = "CREATE TABLE test2 (id INT NOT NULL, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)
        query = "SELECT @@global.gtid_executed;"
        gtid = self.execute(query).fetchone()[0]

        self.stream.close()
        self.stream = BinLogStreamReader(
            self.database, server_id=1024, blocking=True, auto_position=gtid)

        self.assertIsInstance(self.stream.fetchone(), RotateEvent)
        self.assertIsInstance(self.stream.fetchone(), FormatDescriptionEvent)
        self.assertIsInstance(self.stream.fetchone(), GtidEvent)
        event = self.stream.fetchone()

        self.assertEqual(event.query, 'CREATE TABLE test2 (id INT NOT NULL, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))'); 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:27,代碼來源:test_basic.py

示例6: _open_stream

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def _open_stream(self, start_file="mysql-bin.000001", start_pos=4):
        """Returns a binary log stream starting at the given file and directly
        after the given position. server_id and blocking are both set here
        but they appear to have no effect on the actual stream.
        start_pos defaults to 4 because the first event in every binlog starts
        at log_pos 4.
        """
        return BinLogStreamReader(
            connection_settings=self.db_config._asdict(),
            server_id=1,
            blocking=False,
            resume_stream=True,
            log_file=start_file,
            log_pos=start_pos,
            only_schemas=[HEARTBEAT_DB]
        ) 
開發者ID:Yelp,項目名稱:mysql_streamer,代碼行數:18,代碼來源:heartbeat_searcher.py

示例7: _seek

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def _seek(
        self,
        source_database_config,
        tracker_database_config,
        allowed_event_types,
        position,
        only_tables
    ):
        self.stream = BinLogStreamReader(
            connection_settings=source_database_config,
            ctl_connection_settings=tracker_database_config,
            server_id=self.get_unique_server_id(),
            blocking=True,
            only_events=allowed_event_types,
            resume_stream=config.env_config.resume_stream,
            only_tables=only_tables,
            fail_on_table_metadata_unavailable=True,
            **position.to_replication_dict()
        ) 
開發者ID:Yelp,項目名稱:mysql_streamer,代碼行數:21,代碼來源:low_level_binlog_stream_reader_wrapper.py

示例8: consume_events

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def consume_events():
    stream = BinLogStreamReader(connection_settings=database,
                                server_id=3,
                                resume_stream=False,
                                blocking=True,
                                only_events = [UpdateRowsEvent],
                                only_tables = ['test'] )
    start = time.clock()
    i = 0.0
    for binlogevent in stream:
            i += 1.0
            if i % 1000 == 0:
                print("%d event by seconds (%d total)" % (i / (time.clock() - start), i))
    stream.close() 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:16,代碼來源:benchmark.py

示例9: test_filtering_only_events

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_filtering_only_events(self):
        self.stream.close()
        self.stream = BinLogStreamReader(
            self.database, server_id=1024, only_events=[QueryEvent])
        query = "CREATE TABLE test (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)

        event = self.stream.fetchone()
        self.assertIsInstance(event, QueryEvent)
        self.assertEqual(event.query, query) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:12,代碼來源:test_basic.py

示例10: test_filtering_ignore_events

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_filtering_ignore_events(self):
        self.stream.close()
        self.stream = BinLogStreamReader(
            self.database, server_id=1024, ignored_events=[QueryEvent])
        query = "CREATE TABLE test (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)

        event = self.stream.fetchone()
        self.assertIsInstance(event, RotateEvent) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:11,代碼來源:test_basic.py

示例11: test_log_pos

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_log_pos(self):
        query = "CREATE TABLE test (id INT NOT NULL AUTO_INCREMENT, data VARCHAR (50) NOT NULL, PRIMARY KEY (id))"
        self.execute(query)
        query = "INSERT INTO test (data) VALUES('Hello')"
        self.execute(query)
        self.execute("COMMIT")

        for i in range(6):
            self.stream.fetchone()
        # record position after insert
        log_file, log_pos = self.stream.log_file, self.stream.log_pos

        query = "UPDATE test SET data = 'World' WHERE id = 1"
        self.execute(query)
        self.execute("COMMIT")

        # resume stream from previous position
        if self.stream is not None:
            self.stream.close()
        self.stream = BinLogStreamReader(
            self.database,
            server_id=1024,
            resume_stream=True,
            log_file=log_file,
            log_pos=log_pos,
            ignored_events=self.ignoredEvents()
        )

        self.assertIsInstance(self.stream.fetchone(), RotateEvent)
        self.assertIsInstance(self.stream.fetchone(), FormatDescriptionEvent)
        self.assertIsInstance(self.stream.fetchone(), XidEvent)
        # QueryEvent for the BEGIN
        self.assertIsInstance(self.stream.fetchone(), QueryEvent)
        self.assertIsInstance(self.stream.fetchone(), TableMapEvent)
        self.assertIsInstance(self.stream.fetchone(), UpdateRowsEvent)
        self.assertIsInstance(self.stream.fetchone(), XidEvent) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:38,代碼來源:test_basic.py

示例12: test_log_pos_handles_disconnects

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def test_log_pos_handles_disconnects(self):
        self.stream.close()
        self.stream = BinLogStreamReader(
            self.database,
            server_id=1024,
            resume_stream=False,
            only_events = [FormatDescriptionEvent, QueryEvent, TableMapEvent, WriteRowsEvent, XidEvent]
        )

        query = "CREATE TABLE test (id INT  PRIMARY KEY AUTO_INCREMENT, data VARCHAR (50) NOT NULL)"
        self.execute(query)
        query = "INSERT INTO test (data) VALUES('Hello')"
        self.execute(query)
        self.execute("COMMIT")

        self.assertIsInstance(self.stream.fetchone(), FormatDescriptionEvent)
        self.assertGreater(self.stream.log_pos, 0)
        self.assertIsInstance(self.stream.fetchone(), QueryEvent)

        self.assertIsInstance(self.stream.fetchone(), QueryEvent)
        self.assertIsInstance(self.stream.fetchone(), TableMapEvent)
        self.assertIsInstance(self.stream.fetchone(), WriteRowsEvent)

        self.assertIsInstance(self.stream.fetchone(), XidEvent)

        self.assertGreater(self.stream.log_pos, 0) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:28,代碼來源:test_basic.py

示例13: resetBinLog

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def resetBinLog(self):
        self.execute("RESET MASTER")
        if self.stream is not None:
            self.stream.close()
        self.stream = BinLogStreamReader(self.database, server_id=1024,
                                         ignored_events=self.ignoredEvents()) 
開發者ID:58daojia-dba,項目名稱:mysqlbinlog_flashback,代碼行數:8,代碼來源:base.py

示例14: sync_binlog_stream

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def sync_binlog_stream(mysql_conn, config, binlog_streams, state):
    binlog_streams_map = generate_streams_map(binlog_streams)

    for tap_stream_id in binlog_streams_map.keys():
        common.whitelist_bookmark_keys(BOOKMARK_KEYS, tap_stream_id, state)

    log_file, log_pos = calculate_bookmark(mysql_conn, binlog_streams_map, state)

    verify_log_file_exists(mysql_conn, log_file, log_pos)

    if config.get('server_id'):
        server_id = int(config.get('server_id'))
        LOGGER.info("Using provided server_id=%s", server_id)
    else:
        server_id = fetch_server_id(mysql_conn)
        LOGGER.info("No server_id provided, will use global server_id=%s", server_id)

    connection_wrapper = make_connection_wrapper(config)

    try:
        reader = BinLogStreamReader(
            connection_settings={},
            server_id=server_id,
            slave_uuid='stitch-slave-{}'.format(server_id),
            log_file=log_file,
            log_pos=log_pos,
            resume_stream=True,
            only_events=[RotateEvent, WriteRowsEvent, UpdateRowsEvent, DeleteRowsEvent],
            pymysql_wrapper=connection_wrapper
        )
        LOGGER.info("Starting binlog replication with log_file=%s, log_pos=%s", log_file, log_pos)
        _run_binlog_sync(mysql_conn, reader, binlog_streams_map, state)
    finally:
        # BinLogStreamReader doesn't implement the `with` methods
        # So, try/finally will close the chain from the top
        reader.close()

    singer.write_message(singer.StateMessage(value=copy.deepcopy(state))) 
開發者ID:singer-io,項目名稱:tap-mysql,代碼行數:40,代碼來源:binlog.py

示例15: _binlog_loader

# 需要導入模塊: import pymysqlreplication [as 別名]
# 或者: from pymysqlreplication import BinLogStreamReader [as 別名]
def _binlog_loader(self):
        """
        read row from binlog
        """
        if self.is_binlog_sync:
            resume_stream = True
            logging.info("Resume from binlog_file: {file}  binlog_pos: {pos}".format(file=self.log_file,
                                                                                     pos=self.log_pos))
        else:
            resume_stream = False

        stream = BinLogStreamReader(connection_settings=self.binlog_conf,
                                    server_id=self.config['mysql']['server_id'],
                                    only_events=[DeleteRowsEvent, WriteRowsEvent, UpdateRowsEvent],
                                    only_tables=[self.config['mysql']['table']],
                                    resume_stream=resume_stream,
                                    blocking=True,
                                    log_file=self.log_file,
                                    log_pos=self.log_pos)
        for binlogevent in stream:
            self.log_file = stream.log_file
            self.log_pos = stream.log_pos
            for row in binlogevent.rows:
                if isinstance(binlogevent, DeleteRowsEvent):
                    rv = {
                        'action': 'delete',
                        'doc': row['values']
                    }
                elif isinstance(binlogevent, UpdateRowsEvent):
                    rv = {
                        'action': 'update',
                        'doc': row['after_values']
                    }
                elif isinstance(binlogevent, WriteRowsEvent):
                    rv = {
                        'action': 'index',
                        'doc': row['values']
                    }
                else:
                    logging.error('unknown action type in binlog')
                    raise TypeError('unknown action type in binlog')
                yield rv
                # print(rv)
        stream.close()
        raise IOError('mysql connection closed') 
開發者ID:zhongbiaodev,項目名稱:py-mysql-elasticsearch-sync,代碼行數:47,代碼來源:__init__.py


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