云服务上使用神奇的nginx --with-stream模块开启mysql外网地址

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了云服务上使用神奇的nginx --with-stream模块开启mysql外网地址相关的知识,希望对你有一定的参考价值。

    因为有时候有那么一个需求,需要云数据库开放外网地址,但是有个别云运营商是没有提供这个操作的,经过几番头脑风暴后,想起了nginx上又一个--with-stream模块可以把内网ip端口映射到外网地址去!这不就解决了这个需求啦吗!!!


首先查看nginx有没有这个模块,没有就编译安装:

[[email protected] ~]# /usr/local/nginx/sbin/nginx -V

nginx version: openresty/1.9.7.4

built by gcc 4.8.5 20150623 (Red Hat 4.8.5-16) (GCC)

built with OpenSSL 1.0.2k-fips  26 Jan 2017

TLS SNI support enabled

configure arguments: --prefix=/usr/local/nginx --with-cc-opt=-O2 --add-module=../ngx_devel_kit-0.2.19 --add-module=../echo-nginx-module-0.58 --add-module=../xss-nginx-module-0.05 --add-module=../ngx_coolkit-0.2rc3 --add-module=../set-misc-nginx-module-0.30 --add-module=../form-input-nginx-module-0.11 --add-module=../encrypted-session-nginx-module-0.04 --add-module=../drizzle-nginx-module-0.1.9 --add-module=../srcache-nginx-module-0.30 --add-module=../ngx_lua-0.10.2 --add-module=../ngx_lua_upstream-0.05 --add-module=../headers-more-nginx-module-0.29 --add-module=../array-var-nginx-module-0.05 --add-module=../memc-nginx-module-0.16 --add-module=../redis2-nginx-module-0.12 --add-module=../redis-nginx-module-0.3.7 --add-module=../rds-json-nginx-module-0.14 --add-module=../rds-csv-nginx-module-0.07 --with-ld-opt=-Wl,-rpath,/usr/local/luajit/lib --conf-path=/etc/nginx/nginx.conf --user=www --group=www --with-http_stub_status_module --with-http_gzip_static_module --with-http_realip_module --with-http_ssl_module --add-module=/root/src/gnosek-nginx-upstream-fair-a18b409 --add-module=/root/src/ngx_cache_purge-2.3 --add-module=/root/src/nginx-http-concat --with-http_v2_module --with-stream


编译安装:

cd /root/src
cd openresty-1.11.2.5
./configure --prefix=/usr/local --conf-path=/etc/nginx/nginx.conf --user=www --group=www --with-http_stub_status_module --with-http_gzip_static_module --with-http_realip_module --with-http_ssl_module --add-module=/root/src/gnosek-nginx-upstream-fair-a18b409 --add-module=/root/src/ngx_cache_purge-2.3 --add-module=/root/src/nginx-http-concat --with-luajit --with-http_v2_module --with-http_drizzle_module --with-stream
if make -j8;then
    make install
else
    exit 1
fi
mkdir -p /etc/nginx/vhost
mkdir -p /usr/local/nginx/temp
mkdir -p /usr/local/nginx/cache
chown www:www /usr/local/nginx/temp
chown www:www /usr/local/nginx/cache
/bin/cp -f /root/src/nginx.conf /etc/nginx/nginx.conf


开始配置stream

[[email protected] ~]# vim /etc/nginx/nginx.conf
user www www;
.................
stream {
    upstream mysql_3306 {
        server 192.168.1.5:3306;
    }
    server {
        listen 3306;
        proxy_connect_timeout 20s;
        proxy_pass mysql_3306;
    }
}


重启nginx:

[[email protected] ~]# /usr/local/nginx/sbin/nginx -t

[[email protected] ~]# /usr/local/nginx/sbin/nginx -s reload


测试:

技术分享图片

测试使用外网地址已经连得上了


以上是关于云服务上使用神奇的nginx --with-stream模块开启mysql外网地址的主要内容,如果未能解决你的问题,请参考以下文章

神奇的nginx之https支持

同源策略引发的跨域问题它都能轻松解决!这到底是什么神奇的东西儿

将一个Vue项目部署的腾讯云ubuntu服务器nginx上

将一个Vue项目部署的腾讯云ubuntu服务器nginx上

使用Nginx+uwsgi在亚马逊云服务器上部署python+django项目完整版——云服务器申请及配置

腾讯云,搭建nginx静态网站服务器