先看官方网介绍:https://dev.mysql.com/doc/refman/5.7/en/replication-options-replica.html
这个参数是全局性质的,默认是关闭的。
配置文件my.cnf,这样写:
--slave-compressed-protocol[={OFF|ON}] |
命令行设置方式是:
set global slave_compressed_protocol=1 |
启动的好处是,slave从master上拉binlog的时候,带宽能节省2/3,这样大大减轻了网络带宽的流量,特别是跨城的时候。
操作的时候,如果是在mysql进程已经启动之后,set global slave_compressed_protocol=1方式设置的,则需要重新启动io进程
set global slave_compressed_protocol = 1 ;
stop slave io_thread ;
start slave io_thread ;
缺陷是:对slave的cpu压力会变大,毕竟binlog压缩后传输到slave里面,还需要解压,才能apply到本地relog进程,才能由sql线程执行写入到slave里