nginx 反向代理mysql集群

762 阅读2分钟

一、安装nginx

1. 下载

nginx 下载官网: nginx.org/en/download…

参考连接: zhuanlan.zhihu.com/p/83890573

2. 安装要求的环境

1.需要安装gcc环境

# yum install gcc-c++

2.第三方的开发包

1 PERE

PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。

nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库

# yum install -y pcre pcre-devel

2 zlib

zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

# yum install -y zlib zlib-devel

3 openssl

OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,

并提供丰富的应用程序供测试或其它目的使用。

nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

# yum install -y openssl openssl-devel

3. nginx安装过程

1. 解压到/usr/local下面

# tar -xvf nginx-1.14.0.tar.gz -C /usr/local

2. 使用cofigure命令创建一个makeFile文件

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi \
--with-http_stub_status_module \
--with-http_ssl_module \
--with-file-aio \
--with-http_realip_module \
--with-stream

注意: --with-stream 是反向代理mysql必须的

--prefix=/usr/local/nginx  表示软件安装到/usr/local/nginx下面。
这个make install 的时候就不用在指定安装路径。
执行完成后查看目录里面已经多了一个Makefile文件

3. 创建目录/var/temp/nginx/

mkdir /var/temp/nginx -p

进入nginx-1.14.0里面执行make; make install 命令进行安装

make;
make install;

二、配置mysql反向代理

本文的前提是已搭建好mysql集群(双主互备)

修改nginx配置文件

user  root;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       /usr/local/nginx/conf/mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    include /etc/nginx/conf.d/*.conf;
}

stream{
    upstream mysql{
        # 两个mysql数据库
        server 192.168.1.113:3306 weight=1; 
        server 192.168.1.113:3307 weight=1;
    }

    server{
        # 延用mysql-proxy 代理的端口
        listen 4040;
        #server_name 192.168.1.113;
        proxy_pass mysql;
    }
}

重启nginx

/usr/local/nginx/sbin/nginx -s reload

测试

image.png