Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Revert "Feature/mariadb gtid list event" #18

Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 0 additions & 13 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,16 +15,3 @@ services:
ports:
- 3307:3307
command: mysqld --log-bin=mysql-bin.log --server-id 1 --binlog-format=row --gtid_mode=on --enforce-gtid-consistency=on --log_slave_updates -P 3307

mariadb-10.6:
image: mariadb:10.6
environment:
MARIADB_ALLOW_EMPTY_ROOT_PASSWORD: 1
ports:
- "3308:3306"
command: |
--server-id=1
--default-authentication-plugin=mysql_native_password
--log-bin=master-bin
--binlog-format=row
--log-slave-updates=on
5 changes: 2 additions & 3 deletions examples/mariadb_gtid/read_event.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import pymysql

from pymysqlreplication import BinLogStreamReader, gtid
from pymysqlreplication.event import GtidEvent, RotateEvent, MariadbGtidEvent, QueryEvent, MariadbGtidListEvent
from pymysqlreplication.event import GtidEvent, RotateEvent, MariadbGtidEvent, QueryEvent
from pymysqlreplication.row_event import WriteRowsEvent, UpdateRowsEvent, DeleteRowsEvent

MARIADB_SETTINGS = {
Expand Down Expand Up @@ -65,8 +65,7 @@ def query_server_id(self):
RotateEvent,
WriteRowsEvent,
UpdateRowsEvent,
DeleteRowsEvent,
MariadbGtidListEvent
DeleteRowsEvent
],
auto_position=gtid,
is_mariadb=True
Expand Down
6 changes: 2 additions & 4 deletions pymysqlreplication/binlogstream.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,7 @@
QueryEvent, RotateEvent, FormatDescriptionEvent,
XidEvent, GtidEvent, StopEvent, XAPrepareEvent,
BeginLoadQueryEvent, ExecuteLoadQueryEvent,
HeartbeatLogEvent, NotImplementedEvent, MariadbGtidEvent,
MariadbGtidListEvent)
HeartbeatLogEvent, NotImplementedEvent, MariadbGtidEvent)
from .exceptions import BinLogNotEnabled
from .row_event import (
UpdateRowsEvent, WriteRowsEvent, DeleteRowsEvent, TableMapEvent)
Expand Down Expand Up @@ -601,8 +600,7 @@ def _allowed_event_list(self, only_events, ignored_events,
TableMapEvent,
HeartbeatLogEvent,
NotImplementedEvent,
MariadbGtidEvent,
MariadbGtidListEvent
MariadbGtidEvent
))
if ignored_events is not None:
for e in ignored_events:
Expand Down
39 changes: 0 additions & 39 deletions pymysqlreplication/event.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,45 +89,6 @@ def _dump(self):
def __repr__(self):
return '<GtidEvent "%s">' % self.gtid

class MariadbGtidListEvent(BinLogEvent):
"""
GTID List event
https://mariadb.com/kb/en/gtid_list_event/

Attributes:
gtid_length: Number of GTIDs
gtid_list: list of 'MariadbGtidObejct'

'MariadbGtidObejct' Attributes:
domain_id: Replication Domain ID
server_id: Server_ID
gtid_seq_no: GTID sequence
gtid: 'domain_id'+ 'server_id' + 'gtid_seq_no'
"""
def __init__(self, from_packet, event_size, table_map, ctl_connection, **kwargs):

super(MariadbGtidListEvent, self).__init__(from_packet, event_size, table_map, ctl_connection, **kwargs)

class MariadbGtidObejct(BinLogEvent):
"""
Information class of elements in GTID list
"""
def __init__(self, from_packet, event_size, table_map, ctl_connection, **kwargs):
super(MariadbGtidObejct, self).__init__(from_packet, event_size, table_map, ctl_connection, **kwargs)
self.domain_id = self.packet.read_uint32()
self.server_id = self.packet.server_id
self.gtid_seq_no = self.packet.read_uint64()
self.gtid = "%d-%d-%d" % (self.domain_id, self.server_id, self.gtid_seq_no)


self.gtid_length = self.packet.read_uint32()
self.gtid_list = [MariadbGtidObejct(from_packet, event_size, table_map, ctl_connection, **kwargs) for i in range(self.gtid_length)]


def _dump(self):
super(MariadbGtidListEvent, self)._dump()
print("GTID length:",self.gtid_length)
print("GTID list: " + ",".join(list(map(lambda x: x.gtid,self.gtid_list))))

class MariadbGtidEvent(BinLogEvent):
"""
Expand Down
2 changes: 1 addition & 1 deletion pymysqlreplication/packet.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ class BinLogPacketWrapper(object):
constants.MARIADB_ANNOTATE_ROWS_EVENT: event.NotImplementedEvent,
constants.MARIADB_BINLOG_CHECKPOINT_EVENT: event.NotImplementedEvent,
constants.MARIADB_GTID_EVENT: event.MariadbGtidEvent,
constants.MARIADB_GTID_GTID_LIST_EVENT: event.MariadbGtidListEvent,
constants.MARIADB_GTID_GTID_LIST_EVENT: event.NotImplementedEvent,
constants.MARIADB_START_ENCRYPTION_EVENT: event.NotImplementedEvent
}

Expand Down
31 changes: 1 addition & 30 deletions pymysqlreplication/tests/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ def isMySQL80AndMore(self):

def isMariaDB(self):
if self.__is_mariaDB is None:
self.__is_mariaDB = "MariaDB" in self.execute("SELECT VERSION()").fetchone()[0]
self.__is_mariaDB = "MariaDB" in self.execute("SELECT VERSION()").fetchone()
return self.__is_mariaDB

@property
Expand Down Expand Up @@ -121,32 +121,3 @@ def bin_log_basename(self):
bin_log_basename = cursor.fetchone()[0]
bin_log_basename = bin_log_basename.split("/")[-1]
return bin_log_basename


class PyMySQLReplicationMariaDbTestCase(PyMySQLReplicationTestCase):
def setUp(self):
# default
self.database = {
"host": "localhost",
"user": "root",
"passwd": "",
"port": 3308,
"use_unicode": True,
"charset": "utf8",
"db": "pymysqlreplication_test"
}

self.conn_control = None
db = copy.copy(self.database)
db["db"] = None
self.connect_conn_control(db)
self.execute("DROP DATABASE IF EXISTS pymysqlreplication_test")
self.execute("CREATE DATABASE pymysqlreplication_test")
db = copy.copy(self.database)
self.connect_conn_control(db)
self.stream = None
self.resetBinLog()




17 changes: 1 addition & 16 deletions pymysqlreplication/tests/test_basic.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
from pymysqlreplication.constants.BINLOG import *
from pymysqlreplication.row_event import *

__all__ = ["TestBasicBinLogStreamReader", "TestMultipleRowBinLogStreamReader", "TestCTLConnectionSettings", "TestGtidBinLogStreamReader","TestMariadbBinlogStreaReader"]
__all__ = ["TestBasicBinLogStreamReader", "TestMultipleRowBinLogStreamReader", "TestCTLConnectionSettings", "TestGtidBinLogStreamReader"]


class TestBasicBinLogStreamReader(base.PyMySQLReplicationTestCase):
Expand Down Expand Up @@ -1002,21 +1002,6 @@ def test_parsing(self):
gtid = Gtid("57b70f4e-20d3-11e5-a393-4a63946f7eac:1-:1")
gtid = Gtid("57b70f4e-20d3-11e5-a393-4a63946f7eac::1")

class TestMariadbBinlogStreaReader(base.PyMySQLReplicationMariaDbTestCase):

def test_gtid_list_event(self):
event = self.stream.fetchone()
self.assertEqual(event.position, 4)

#FormatDescriptionEvent
event = self.stream.fetchone()
self.assertEqual(event.event_type,15)
self.assertIsInstance(event,FormatDescriptionEvent)

#MariadbAnnotateRowsEvent
event = self.stream.fetchone()
self.assertEqual(event.event_type,163)
self.assertIsInstance(event,MariadbGtidListEvent)

if __name__ == "__main__":
import unittest
Expand Down