Rechercher dans le manuel MySQL
28.7.19 C API Binary Log Data Structures
      C API functions for processing a replication event stream from a
      server require a connection handler (a MYSQL *
      pointer) and a pointer to a MYSQL_RPL structure
      that describes the steam of replication events to read from the
      server binary log. For example:
    
MYSQL *mysql = mysql_real_connect(...);
MYSQL_RPL rpl;
# ... initialize MYSQL_RPL members ...
int result = mysql_binlog_open(mysql, &rpl);
      This section describes the MYSQL_RPL structure
      members. Connection handlers are described in
      Section 28.7.5, “C API Data Structures”.
    
      The applicable MYSQL_RPL members depend on the
      binary log operation to be performed:
- Before calling - mysql_binlog_open(), the caller must set the- MYSQL_RPLmembers from- file_name_lengththrough- flags. In addition, if- flagshas the- MYSQL_RPL_GTIDflag set, the caller must set the members from- gtid_set_encoded_sizethrough- gtid_set_arg.
- After a successful - mysql_binlog_fetch()call, the caller examines the- sizeand- buffermembers.
      MYSQL_RPL structure member descriptions:
- file_name_length- The length of the name of the binary log file to read. This member is used in conjunction with - file_name; see the- file_namedescription.
- file_name- The name of the binary log file to read: - If - file_nameis- NULL, the client library sets it to the empty string and sets- file_name_lengthto 0.
- If - file_nameis not- NULL,- file_name_lengthmust either be the length of the name or 0. If- file_name_lengthis 0, the client library sets it to the length of the name, in which case,- file_namemust be given as a null-terminated string.
 - To read from the beginning of the binary log without having to know the name of the oldest binary log file, set - file_nameto- NULLor the empty string, and- start_positionto 4.
- start_position- The position at which to start reading the binary log. The position of the first event in any given binary log file is 4. 
- server_id- The server ID to use for identifying to the server from which the binary log is read. 
- flags- The union of flags that affect binary log reading, or 0 if no flags are set. These flag values are permitted: - MYSQL_RPL_SKIP_HEARTBEAT- Set this flag to cause - mysql_binlog_fetch()to skip heartbeat events.
- MYSQL_RPL_GTID- Set this flag to read GTID (global transaction ID) data. If set, you must initialize the - MYSQL_RPLstructure GTID-related members from- gtid_set_encoded_sizeto- gtid_set_argbefore calling- mysql_binlog_open().- It is beyond the scope of this documentation to describe in detail how client programs use those GTID-related members. For more information, examine the - mysqlbinlog.ccsource file. For information about GTID-based replication, see Section 17.1.3, “Replication with Global Transaction Identifiers”.
 
- gtid_set_encoded_size- The size of GTID set data, or 0. 
- fix_gtid_set- The address of a callback function for - mysql_binlog_open()to call to fill the command packet GTID set, or- NULLif there is no such function. The callback function, if used, should have this calling signature:- void my_callback(MYSQL_RPL *rpl, unsigned char *packet_gtid_set);
- gtid_set_arg- Either a pointer to GTID set data (if - fix_gtid_setis- NULL), or a pointer to a value to be made available for use within the callback function (if- fix_gtid_setis not- NULL).- gtid_set_argis a generic pointer, so it can point to any kind of value (for example, a string, a structure, or a function). Its interpretation within the callback depends on how the callback intends to use it.
- size- After a successful - mysql_binlog_fetch()call, the size of the returned binary log event. The value is 0 for an EOF event, greater than 0 for a non-EOF event.
- buffer- After a successful - mysql_binlog_fetch()call, a pointer to the binary log event contents.
Document created the 26/06/2006, last modified the 26/10/2018
Source of the printed document:https://www.gaudry.be/en/mysql-rf-c-api-binary-log-data-structures.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.
References
These references and links indicate documents consulted during the writing of this page, or which may provide additional information, but the authors of these sources can not be held responsible for the content of this page.
The author of this site is solely responsible for the way in which the various concepts, and the freedoms that are taken with the reference works, are presented here. Remember that you must cross multiple source information to reduce the risk of errors.
 
  
  
  
 