nginx的使用和安装

nginx的使用和安装

1什么是Nginx

Nginx (“engine x”) 是一个高性能的 HTTP和反向代理服务器,也是一个 IMAP/POP3/SMTP 服务器。
很多大网站都是使用nginx做反向代理,应用非常广泛。
Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

2应用场景

1、http服务器,可以做静态网页的http服务器。
2、配置虚拟机。
一个域名可以被多个ip绑定。可以根据域名的不同吧请求转发给运行在不同端口的服务器。
3、反向代理,负载均衡。把请求转发给不同的服务器。

3安装及配置

3.1下载
官方网站:http://nginx.org/
最后的一个稳定版本:1.8.0版本。有两个版本windows版本和linux版本。生产环境都是使用linux版本。

3.2安装
3.2.1环境要求
nginx是C语言开发,建议在linux上运行,本教程使用Centos6.4作为安装环境。
gcc
安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:yum install gcc-c++
PCRE
PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
yum install -y pcre pcre-devel
注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
zlib
zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
yum install -y zlib zlib-devel

openssl
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
yum install -y openssl openssl-devel

3.2.2编译及安装
第一步:把nginx的源码包上传至linux服务器
第二步:解压源码包。 tar -zxf nginx-1.8.0.tar.gz
第三步:进入nginx-1.8.0文件夹。使用configure命令创建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

注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录
第五步:make
第六步 make install

3.3Nginx的启动及关闭
3.3.1启动
在nginx目录下有一个sbin目录,sbin目录下有一个nginx可执行程序。
./nginx

3.3.2关闭nginx
关闭命令:相当于找到nginx进程kill。
./nginx -s stop

退出命令:
./nginx -s quit
等程序执行完毕后关闭,建议使用此命令。

3.3.3动态加载配置文件
./nginx -s reload
可以不关闭nginx的情况下更新配置文件。

4.用nginx在window上搭建一个集群

1.在d盘新建两个目录 tomcat1 tomcat2
2.修改tomcat2的端口 在tomcat1的端口上+100
3.解压nginx
    修改nginx的 nginx.conf文件
    在locatioin / 下添加了反向代理
        proxy_pass 代理服务器
    这是只是代理一台服务器
4.代理集群
    需要在http节点上添加一个
        upstream service_ruipeng{
            server 127.0.0.1:8080;
            server 127.0.0.1:8180;
        }
    修改location /下的反向代理 
        proxy_pass http://servlet_ruipeng
5.session共享问题
    解决方式1:只能在window下好使
        web服务器解决(广播机制)
        注意:tomcat下性能低
        修改两个地方:
            1.修改tomcat的server.xml 支持共享
                将 引擎标签下的 
                    <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
                注释去掉
            2.修改项目的配置文件 web.xml中添加一个节点

    解决方式2:
        可以将session的id放入redis中
    解决方式3:
        保证一个ip地址永远的访问一台web服务器,就不存在session共享问题了,在linux
        在nginx的配置文件中
            upstream中添加 ip_hash;

5.在linux搭建集群

1.先将 nginx上传到linux上
2.解压nginx
3.先编译nginx
    安装依赖包
        yum install gcc-c++
        yum install -y pcre pcre-devel
        yum install -y zlib zlib-devel
        yum install -y openssl openssl-devel
    执行编译
        先进入 nginx的目录
        执行
            ./configure

4.安装nginx
    执行 
        make
        make install
5.启动nginx
    cd nginx目录下
        配置文件 conf
        启动nginx 
            ./nginx 
6.将端口号80 放行
    /sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT
    将该设置添加到防火墙的规则中
    /etc/rc.d/init.d/iptables save
7.修改conf文件 和window下一样
    配置集群

猜你喜欢

转载自blog.csdn.net/ruipeng250/article/details/79396733