Table of Contents
A BUG related to MySQL rpl_semi_sync_master_timeout
1. Background
2. Phenomenon
3. Reason
4. Repair
4.1 Modify code
4.2 Compilation
4.3 Copy the semi-synchronization plug-in
4.4 Restart MySQL
5. Supplement
Home Backend Development PHP Tutorial A BUG_PHP tutorial related to MySQL rpl_semi_sync_master_timeout

A BUG_PHP tutorial related to MySQL rpl_semi_sync_master_timeout

Jul 12, 2016 am 08:57 AM
android

1. Background

When deploying an HA system based on MySQL native replication, it was found that in semi-sync mode, semi-sync If the timeout period for downgrading replication to asynchronous replication is set very long, it will seriously affect performance. This is a very strange phenomenon.


2. Phenomenon

Combine different parameters and use sysbench for stress testing.

sysbench --db-driver=mysql --mysql-db=test2 --mysql-host=srdsdevapp69 --mysql-table-engine=innodb --oltp-table-size=5000000 --num-threads=10 --max-time=10 --max-requests=0 --oltp-test-mode=complex --oltp-read-only=off --test=/opt/sysbench-0.5/sysbench/tests/db/insert.lua run


The results are as follows:

rpl_semi_sync_master_enabled rpl_semi_sync_master_timeout qps Remarks
on 21474836480 13.99 About 248 days
2147483648 196.3 About 24.8 days
214748364 1251.67 About 2.5 days
86400000 2146.96 1 day
43200000 3211.17 12 hours
21600000 3583.02 6 hours
10000 3637.16 10 seconds (default)
off - 8926.76


3. Reason

It is easy to see from the above table that when rpl_semi_sync_master_timeout is large, the execution time of each query is proportional to rpl_semi_sync_master_timeout.

Why does such a weird thing happen? Open the MySQL code and the truth will be revealed immediately!


PluginSemisyncseMisync_master.cc:

    #Define time_thousand 1000

  1. #Define time_million 1000000

  2. #define TIME_BILLION 1000000000
  3. ...
  4. int ReplSemiSyncMaster::commitTrx(const char* trx_wait_binlog_name,
  5. my_off_t trx_wait_binlog_pos)
  6. {
  7. ...
  8. unsigned long long diff_nsecs =
  9. start_ts.tv_nsec (unsigned long long)wait_timeout_ * TIME_MILLION;
  10. abstime.tv_sec = start_ts.tv_sec;
  11. while (diff_nsecs >= TIME_BILLION)//This while loop is the culprit The culprit! ! !
  12. {
  13. abstime.tv_sec ;
  14. diff_nsecs -= TIME_BILLION;
  15. }
  16. abstime.tv_nsec = diff_nsecs;
  17. ...
  18. }

There is a while above Loop, the number of loops is equal to the number of seconds corresponding to rpl_semi_sync_master_timeout, that is to say, if it is set to 300 days, it will loop 25,920,000 times, which is not slow!



4. Repair

After replacing the while in that code with equivalent writing, the problem is solved. The measured qps is around 3700, which has nothing to do with rpl_semi_sync_master_timeout.

4.1 Modify code

pluginsemisyncsemisync_master.cc:

  1. # diff plugin/semisync/semisync_master.cc plugin/semisync/semisync_master.cc_bak
  2. 687,688c687,688
  3. < start_ts.tv_nsec ((unsigned long long)wait_timeout_ % TIME_THOUSAND) * TIME_MILLION;
  4. < abstime.tv_sec = start_ts.tv_sec ( unsigned long long)wait_timeout_ / TIME_THOUSAND;
  5. ---
  6. > start_ts.tv_nsec (unsigned long long)wait_timeout_ * TIME_MILLION;
  7. > abstime.tv_sec = start_ts.tv_sec;


4.2 Compilation

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_FAST_MUTEXES=1make
Copy after login

Note: The above compilation options I filled it out quite casually. I just copied it from the Internet and then changed it. I just wanted it to be compiled and passed.

4.3 Copy the semi-synchronization plug-in

chown mysql:mysql  ./plugin/semisync/semisync_master.socp -rf ./plugin/semisync/semisync_master.so /usr/local/mysql/lib/mysql/plugin/semisync_master.socp -rf ./plugin/semisync/semisync_master.so /usr/local/mysql/lib/plugin/semisync_master.so
Copy after login


4.4 Restart MySQL

5. Supplement

The bug has been resolved Report to the official MySQL website, http://bugs.mysql.com/80651

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1108686.htmlTechArticleA BUG related to MySQL rpl_semi_sync_master_timeout 1. When deploying the HA system based on MySQL native replication in the background, it was found that semi-synchronization In mode, the timeout of semi-synchronous replication is downgraded to asynchronous replication...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:23 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Sep 11, 2024 am 06:37 AM

OnLeaks has now partnered with Android Headlines to provide a first look at the Galaxy S25 Ultra, a few days after a failed attempt to generate upwards of $4,000 from his X (formerly Twitter) followers. For context, the render images embedded below h

IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size Sep 07, 2024 am 06:35 AM

Alongside announcing two new smartphones, TCL has also announced a new Android tablet called the NXTPAPER 14, and its massive screen size is one of its selling points. The NXTPAPER 14 features version 3.0 of TCL's signature brand of matte LCD panels

Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Sep 07, 2024 am 06:39 AM

The Vivo Y300 Pro just got fully revealed, and it's one of the slimmest mid-range Android phones with a large battery. To be exact, the smartphone is only 7.69 mm thick but features a 6,500 mAh battery. This is the same capacity as the recently launc

Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Sep 12, 2024 pm 09:21 PM

Samsung has not offered any hints yet about when it will update its Fan Edition (FE) smartphone series. As it stands, the Galaxy S23 FE remains the company's most recent edition, having been presented at the start of October 2023. However, plenty of

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:22 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Sep 27, 2024 am 06:23 AM

The Redmi Note 14 Pro Plus is now official as a direct successor to last year'sRedmi Note 13 Pro Plus(curr. $375 on Amazon). As expected, the Redmi Note 14 Pro Plus heads up the Redmi Note 14 series alongside theRedmi Note 14and Redmi Note 14 Pro. Li

iQOO Z9 Turbo Plus: Reservations begin for the potentially beefed-up series flagship iQOO Z9 Turbo Plus: Reservations begin for the potentially beefed-up series flagship Sep 10, 2024 am 06:45 AM

OnePlus'sister brand iQOO has a 2023-4 product cycle that might be nearlyover; nevertheless, the brand has declared that it is not done with itsZ9series just yet. Its final, and possibly highest-end,Turbo+variant has just beenannouncedas predicted. T

See all articles