怎么使用nginx充当mysql的负载均衡器

说明:nginx版本要求是1.9以上 ,编译nginx的时候需要加上 –with-stream

如:

./configure --prefix=/data/apps/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_realip_module --with-http_image_filter_module --with-stream

注意

1.因为mysql默认使用了3306端口所以配置nginx tcp反向代理mysql的时候注意端口不要与mysql监听的端口一样比如我使用的是3307

2.确保能root用户能远程连接mysql

如数据库mysql 表user

怎么使用nginx充当mysql的负载均衡器

nginx.conf

此段代码追加在nginx.conf文件末尾,注意不能加在http{}内

stream{ include /data/apps/nginx/conf/stream/*.conf; }

stream/db.conf

server { listen 3307; #注意端口不能跟mysql监听的一样 proxy_pass db; } upstream db { server 127.0.0.1:3306; server 192.168.233.1:3306; }

重启nginx, 查看nginx是否监听了3307端口

怎么使用nginx充当mysql的负载均衡器

然后php代码是这样子

#其实就是new mysqli的时候只需改端口号与nginx反向代理设置的端口号一样就可以了 $mysqli = new mysqli('127.0.0.1','root','root','test',3307);

完整的php代码

<?php class mysqlclass { private static $obj = null; //mysqlclass对象 public $host; public $database; public $user; public $pwd; public $port; public $mysqli = null; //禁止对象被克隆 private function __clone(){} //禁止外部实例化 private function __construct($host="127.0.0.1",$database="test",$user="root",$pwd="root",$port="3307") { $this->host = $host; $this-&gt;database = $database; $this-&gt;user = $user; $this-&gt;pwd = $pwd; $this-&gt;port = $port; $this-&gt;mysqli = $this-&gt;db_connect(); } //获取mysqli连接 private function db_connect() { $mysqli = new mysqli($this-&gt;host,$this-&gt;user,$this-&gt;pwd,$this-&gt;database,$this-&gt;port); if($mysqli-&gt;connect_errno) { printf("connect failed: %sn", $mysqli-&gt;connect_errno); exit(); } $mysqli-&gt;query("set names utf8 "); return $mysqli; } //获取db实例 public static function get_db() { if(self::$obj === null) { self::$obj = new self(); } return self::$obj; } public function db_query($sql) { $result = $this-&gt;mysqli-&gt;query($sql); $arr = []; while ($row = $result-&gt;fetch_assoc()) { $arr[] = $row; } $result-&gt;close(); $this-&gt;mysqli-&gt;close(); return $arr; } public function db_insert() { } public function db_update() { } public function __destruct() { $this-&gt;mysqli-&gt;close(); } } $db = mysqlclass::get_db(); $r = $db-&gt;db_query("show tables"); var_dump($r);

结果

怎么使用nginx充当mysql的负载均衡器

怎么使用nginx充当mysql的负载均衡器

© 版权声明
THE END
喜欢就支持一下吧
点赞15 分享