本人微信公众号"aeolian"~

Ngix

Ngix安装

官网地址,下载为源码,需要编译安装    

http://nginx.org/

环境

1、需要安装gcc的环境。

yum install gcc-c++

2、第三方的开发包。

  • 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

安装

第一步:把nginx的源码包上传到linux系统

第二步:解压缩

[root@localhost ~]# tar zxf nginx-x.x.x.tar.gz

第三步:使用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

注意:启动nginx之前,上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录

[root@localhost sbin]# mkdir /var/temp/nginx/client -p

第四步:make

第五步:make install       #装在–prefix=/usr/local/nginx中

启动

进入sbin目录

《Ngix》

启动命令

[root@localhost sbin]# ./sbin/nginx

 

关闭nginx:

[root@localhost sbin]# ./nginx -s stop

推荐使用:

[root@localhost sbin]# ./nginx -s quit

 

重启nginx:

1、先关闭后启动。

2、刷新配置文件:

[root@localhost sbin]# ./nginx -s reload

配置虚拟主机

就是在一台服务器启动多个网站。

如何区分不同的网站:

1、端口不同

2、域名不同

通过端口区分不同虚拟机

Nginx的配置文件

/usr/local/nginx/conf/nginx.conf

《Ngix》

可以配置多个server,配置了多个虚拟主机。

《Ngix》

重新加载配置文件

[root@localhost nginx]# sbin/nginx -s reload

通过域名区分虚拟主机

本地测试可以修改hosts文件。

修改window的hosts文件:(C:\Windows\System32\drivers\etc)

可以配置域名和ip的映射关系,如果hosts文件中配置了域名和ip的对应关系,不需要走dns服务器。

《Ngix》

反向代理

《Ngix》

 

反向代理服务器决定哪台服务器提供服务。

Nginx实现反向代理

两个域名指向同一台nginx服务器,用户访问不同的域名显示不同的网页内容。

两个域名是www.sian.com.cn和www.sohu.com

《Ngix》

第一步:安装两个tomcat,分别运行在8080和8081端口。

第二步:启动两个tomcat。

第三步:反向代理服务器的配置

    upstream tomcat1 {     
        server 192.168.182.3:8080;    #被代理的服务器节点
    }
    server {
        listen       80;
        server_name  www.sina.com.cn;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
    }

    upstream tomcat2 {
        server 192.168.182.3:8081;    #被代理的服务器节点
    }
    server {
        listen       80;
        server_name  www.sohu.com;

        location / {
            proxy_pass   http://tomcat2;
            index  index.html index.htm;
        }
    }

负载均衡

如果一个服务由多条服务器提供,需要把负载分配到不同的服务器处理,需要负载均衡。

 upstream tomcat2 {
       server 192.168.182.3:8080;
       server 192.168.182.4:8080;
 }

可以根据服务器的实际情况调整服务器权重。权重越高分配的请求越多,权重越低,请求越少。默认是都是1

upstream tomcat2 {
       server 192.168.182.3:8080;
       server 192.168.182.3:8080 weight=2;
}

Nginx的高可用

keepalived+nginx实现主备   (七层)

《Ngix》

 

F5   (四层,超过5w并发用)

lvs免费,实现F6百分之六十的性能

ps:Ultraedit->主页->FTP->从FTP打开,配置后点击连接可以直接编译服务器上的文件。

《Ngix》

 

点赞
  1. Like!! I blog quite often and I genuinely thank you for your information. The article has truly peaked my interest.

Leave a Reply

Your email address will not be published. Required fields are marked *