데이터 베이스 MySQL 튜토리얼 MySQL Proxy快速实现读写分离以及负载均衡

MySQL Proxy快速实现读写分离以及负载均衡

Jun 07, 2016 pm 05:34 PM
읽기 및 쓰기 분리

1. 安装下载已经编译好的安装包,或者预编译安装包均可,在这里,使用预编译版本。 [@s1.yejr.com ~]# tar zxf mysql-proxy-0.6.

1. 安装
下载已经编译好的安装包,或者预编译安装包均可,在这里,使用预编译版本。

[@s1.yejr.com ~]# tar zxf mysql-proxy-0.6.0-linux-rhas4-x86.tar.gz

[@s1.yejr.com ~]# cd mysql-proxy-0.6.0-linux-rhas4-x86

#可以看到有2个目录
[@s1.yejr.com mysql-proxy-0.6.0-linux-rhas4-x86]# ls
sbin  share

[@s1.yejr.com mysql-proxy-0.6.0-linux-rhas4-x86]# mv sbin/mysql-proxy /usr/local/sbin/

[@s1.yejr.com mysql-proxy-0.6.0-linux-rhas4-x86]# ls share
mysql-proxy        tutorial-constants.lua  tutorial-packets.lua    tutorial-rewrite.lua  tutorial-warnings.lua
tutorial-basic.lua  tutorial-inject.lua    tutorial-query-time.lua  tutorial-states.lua

#将lua脚本放到/usr/local/share下,以备他用
[@s1.yejr.com mysql-proxy-0.6.0-linux-rhas4-x86]# mv share/mysql-proxy /usr/local/share/

#删除符号连接等垃圾代码
[@s1.yejr.com mysql-proxy-0.6.0-linux-rhas4-x86]# strip /usr/local/sbin/mysql-proxy
2. 启动
编译一下启动管理脚本:

[@s1.yejr.com ~]# vi /etc/init.d/mysql-proxy

#!/bin/sh
export LUA_PATH=/usr/local/share/mysql-proxy/?.lua

mode=$1
if [ -z "$mode" ] ; then
  mode="start"
fi

case $mode in
  'start')
    mysql-proxy --daemon \
--admin-address=:4401 \
--proxy-address=:3307 \
--proxy-backend-addresses=:3306 \
--proxy-read-only-backend-addresses=192.168.133.232:3306 \
--proxy-read-only-backend-addresses=10.10.74.61:3306 \
--proxy-lua-script=/usr/local/share/mysql-proxy/rw-splitting.lua
    ;;

  'stop')
    killall mysql-proxy
    ;;

  'restart')
    if $0 stop ; then
      $0 start
    else
      echo  "retart failed!!!"
      exit 1
    fi
    ;;
esac
exit 0
现在解释一下启动脚本:
--daemon 采用daemon方式启动
--admin-address=:4401 指定mysql proxy的管理端口,在这里,表示本机的4401端口
--proxy-address=:3307 指定mysql proxy的监听端口,也可以用 127.0.0.1:3307 表示
--proxy-backend-addresses=:3306 指定mysql主机的端口
--proxy-read-only-backend-addresses=192.168.1.1:3306 指定只读的mysql主机端口
--proxy-read-only-backend-addresses=192.168.1.2:3306 指定另一个只读的mysql主机端口
--proxy-lua-script=/usr/local/share/mysql-proxy/rw-splitting.lua 指定lua脚本,在这里,使用的是rw-splitting脚本,用于读写分离

完整的参数可以运行以下命令查看:

mysql-proxy --help-all
运行以下命令启动/停止/重启mysql proxy:

[@s1.yejr.com ~]# /etc/init.d/mysql-proxy start

[@s1.yejr.com ~]# /etc/init.d/mysql-proxy stop

[@s1.yejr.com ~]# /etc/init.d/mysql-proxy restart
3. 试用

[@s1.yejr.com ~]# mysql -h127.0.0.1 -uroot -P3307

mysql> show processlist;
+-------+------+----------------+------+---------+------+-------+------------------+
| Id    | User | Host          | db  | Command | Time | State | Info            |
+-------+------+----------------+------+---------+------+-------+------------------+
| 30052 | root | localhost:9656 | NULL | Query  |    0 | NULL  | show processlist |
+-------+------+----------------+------+---------+------+-------+------------------+
可以看到,产生了一个新连接。

用sysbench测试一下,看会不会挂掉:

[@s1.yejr.com ~]# sysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=1000000 \
--mysql-socket=/tmp/mysql.sock --mysql-user=root --mysql-db=test prepare

[@s1.yejr.com ~]# sysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=1000000 \
--mysql-socket=/tmp/mysql.sock --mysql-user=root --mysql-db=test run
.........
.........
Threads fairness:
    events (avg/stddev):          10000.0000/0.00
    execution time (avg/stddev):  23.0387/0.00
还好,没给大家丢脸,,剩下的测试自己完成吧 :)

4. 其他
mysql proxy还可以实现连接池的功能,这在很多LAMP开发中是软肋,因此,有了mysql proxy,就可以不用再担心连接数超限的问题了。
如果使用rw-splitting.lua脚本的话,最好修改以下2个参数的默认值:

min_idle_connections = 1
max_idle_connections = 3

MySQL Proxy 的详细介绍:请点这里
MySQL Proxy 的下载地址:请点这里

相关阅读:

MySQL Proxy读写分离实战

在CentOS 5.2下安装最新的MySQL Proxy

RHEL5.5下MySQL Proxy 安装

mysql proxy、mysql-mmm实现读写分离高可用性

linux

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

React Query에서 데이터베이스 읽기와 쓰기를 분리하는 방법은 무엇입니까? React Query에서 데이터베이스 읽기와 쓰기를 분리하는 방법은 무엇입니까? Sep 26, 2023 am 09:22 AM

ReactQuery에서 데이터베이스 읽기와 쓰기를 분리하는 방법은 무엇입니까? 최신 프런트 엔드 개발에서 데이터베이스 읽기와 쓰기의 분리는 중요한 아키텍처 설계 고려 사항입니다. ReactQuery는 프런트엔드 애플리케이션의 데이터 수집 및 관리 프로세스를 최적화할 수 있는 강력한 상태 관리 라이브러리입니다. 이 글에서는 ReactQuery를 사용하여 데이터베이스에서 읽기와 쓰기를 분리하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. ReactQuery의 핵심 개념은 Query, Mutatio입니다.

php+mysql이 읽기와 쓰기 분리를 실현하는 방법에 대한 간략한 분석 php+mysql이 읽기와 쓰기 분리를 실현하는 방법에 대한 간략한 분석 Mar 21, 2023 pm 03:49 PM

​MySQL은 가장 널리 사용되는 데이터베이스 중 하나이며 애플리케이션에서 널리 사용됩니다. 높은 동시성 및 대용량 데이터 볼륨의 경우 MySQL의 읽기 및 쓰기 동시성 성능이 부족하여 MySQL의 동시성 성능을 향상시키기 위해서는 읽기 및 쓰기 분리가 필요한 솔루션이 되었습니다. 널리 사용되는 동적 언어인 PHP는 MySQL과 매우 밀접하게 통합되어 있습니다. 따라서 이 기사에서는 PHP를 사용하여 MySQL 읽기 및 쓰기 분리를 구현하는 방법을 소개합니다.

MySQL 연결에 대한 읽기-쓰기 분리를 구성하는 방법은 무엇입니까? MySQL 연결에 대한 읽기-쓰기 분리를 구성하는 방법은 무엇입니까? Jun 30, 2023 am 11:39 AM

MySQL 연결에 대한 읽기-쓰기 분리를 구성하는 방법은 무엇입니까? MySQL 데이터베이스는 가장 일반적으로 사용되는 관계형 데이터베이스 중 하나이며, MySQL의 높은 가용성과 성능은 대규모 웹사이트와 애플리케이션에 매우 중요합니다. 데이터베이스의 로드 밸런싱과 성능을 향상시키기 위해 MySQL 연결의 읽기-쓰기 분리를 구성할 수 있습니다. 읽기-쓰기 분리는 읽기 작업과 쓰기 작업을 서로 다른 데이터베이스 서버에 할당하여 데이터베이스의 동시 처리 기능을 향상시키는 데이터베이스 아키텍처 설계 패턴입니다. 이렇게 하면 여러 서버를 최대한 활용할 수 있습니다.

Redis의 마스터-슬레이브 동기화 및 읽기-쓰기 분리 메커니즘 Redis의 마스터-슬레이브 동기화 및 읽기-쓰기 분리 메커니즘 May 11, 2023 pm 03:22 PM

고성능 인메모리 데이터베이스인 Redis는 일상적인 애플리케이션에서 높은 동시성 시나리오에 직면해 있습니다. 이러한 요구에 대처하기 위해 Redis는 마스터-슬레이브 동기화와 읽기-쓰기 분리라는 두 가지 메커니즘을 제공하여 Redis의 성능과 가용성을 향상시킵니다. 이 글에서는 Redis의 마스터-슬레이브 동기화 및 읽기-쓰기 분리의 원리와 구현을 자세히 소개합니다. 1. Redis의 마스터-슬레이브 동기화 메커니즘 Redis의 마스터-슬레이브 동기화 메커니즘은 하나의 Redis 서버에서 다른 Redis 서버로 데이터를 동기화하여 데이터 백업 및 로드를 달성할 수 있습니다.

MySQL 읽기와 쓰기를 분리하기 위해 PHP를 사용할 때의 장점과 과제 MySQL 읽기와 쓰기를 분리하기 위해 PHP를 사용할 때의 장점과 과제 Mar 04, 2024 pm 03:48 PM

MySQL 읽기 및 쓰기를 분리하기 위해 PHP를 사용하는 경우의 장점 및 과제 웹 애플리케이션의 규모가 지속적으로 확장되고 방문 횟수가 증가함에 따라 데이터베이스 읽기 및 쓰기 성능은 개발자가 직면한 주요 과제가 되었습니다. 이 문제를 해결하기 위해 많은 개발자들은 데이터베이스 처리 능력을 향상시키기 위해 MySQL 읽기-쓰기 분리 기술을 사용하기 시작했습니다. 이 기사에서는 PHP를 사용하여 MySQL 읽기 및 쓰기 분리를 달성하는 방법을 살펴보고 장점과 과제를 분석합니다. 1. MySQL 읽기-쓰기 분리의 장점 로드 밸런싱: 읽기 작업과 쓰기 작업을 서로 다르게 할당함으로써

MySQL 읽기-쓰기 분리를 사용하여 성능을 향상시키는 방법 MySQL 읽기-쓰기 분리를 사용하여 성능을 향상시키는 방법 May 11, 2023 pm 12:42 PM

MySQL은 대규모 웹 애플리케이션에서 일반적으로 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 대규모 애플리케이션을 개발할 때 읽기 및 쓰기 요청이 너무 자주 발생하여 데이터베이스에 과부하가 걸리고 성능이 저하되는 경우가 종종 있습니다. MySQL의 성능을 향상시키기 위해 읽기 및 쓰기 분리 기술을 사용할 수 있습니다. 읽기 및 쓰기 분리는 처리를 위해 읽기 요청과 쓰기 요청을 서로 다른 MySQL 서버에 할당하여 시스템의 동시 처리 기능과 응답 속도를 향상시키는 것을 의미합니다. 특히, 읽기 작업이 많은 개발자는 읽기 작업을 읽기에 할당할 수 있습니다.

MySQL의 마스터-슬레이브 복제를 사용하여 읽기-쓰기 분리 아키텍처를 구현하는 방법 MySQL의 마스터-슬레이브 복제를 사용하여 읽기-쓰기 분리 아키텍처를 구현하는 방법 Aug 02, 2023 am 09:21 AM

MySQL의 마스터-슬레이브 복제를 사용하여 읽기-쓰기 분리 아키텍처를 구현하는 방법 기존 웹 애플리케이션에서 읽기 및 쓰기 작업은 일반적으로 동일한 데이터베이스 서버에 연결됩니다. 애플리케이션이 개발되고 액세스 볼륨이 증가함에 따라 이 아키텍처는 쉽게 데이터베이스 성능 병목 현상을 일으킬 수 있습니다. 이 문제를 해결하기 위해 MySQL의 마스터-슬레이브 복제를 사용하여 읽기-쓰기 분리 아키텍처를 구현할 수 있습니다. 이 기사에서는 MySQL의 마스터-슬레이브 복제를 사용하여 읽기-쓰기 분리를 달성하는 방법을 소개하고 해당 코드 예제를 제공합니다. 환경 준비 먼저 설치되었는지 확인하세요.

MySQL의 읽기-쓰기 분리 및 로드 밸런싱을 학습하는 기술은 무엇입니까? MySQL의 읽기-쓰기 분리 및 로드 밸런싱을 학습하는 기술은 무엇입니까? Aug 02, 2023 pm 07:27 PM

MySQL의 읽기-쓰기 분리 및 로드 밸런싱을 학습하는 기술은 무엇입니까? MySQL은 다양한 웹 애플리케이션과 기업 수준 시스템에서 널리 사용되는 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. 애플리케이션의 규모가 지속적으로 증가함에 따라 데이터베이스에 대한 읽기 및 쓰기 부하가 점점 더 커지고 있습니다. 데이터베이스 성능과 확장성을 향상시키기 위해서는 읽기 및 쓰기 분리 및 로드 밸런싱이 필요한 기술적 수단이 되었습니다. 읽기 및 쓰기 분리는 읽기 작업과 쓰기 작업을 서로 다른 MySQL 서버로 분리하여 데이터베이스의 읽기 효율성과 용량을 향상시키는 것을 의미합니다. 로드 밸런싱은

See all articles