Linux搭建Nginx服务器

Nginx的概述

什么是Nginx

Nginx是一个使用c语言开发的高性能的http服务器及反向代理服务器。Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

Nginx应用场景

  • 1、http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
  • 2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
  • 3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

在Linux环境中安装Nginx

Nginx的下载地址:http://nginx.org/en/download.html
第一步:准备Nginx依赖的包

  • 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
  • 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源码包

wget http://nginx.org/download/nginx-1.12.2.tar.gz

第三步:解压Nginx源码包

tar -zxvf nginx-1.12.2.tar.gz

第四步:进入解压后的nginx-1.12.2文件中运行configure文件设置参数

./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

说明:–prefix参数是指定安装nginx的安装路径,其他参数都按照上面的默认就可。
注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录;

第五步:编译源文件(在解压后的目录中进行编译)

make

第六步:安装nginx

make install

说明:nginx服务去的默认端口为80

启动Nginx服务器和停止Nginx服务器

启动服务
第一步:进入安装目录/usr/local/nginx

cd /usr/local/nginx

第二步:启动Nginx服务器

./sbin/nginx

这样就启动了Nginx服务器


关闭服务
方式一
在Linux系统中直接通过kill命令关闭Nginx服务器的进程(但是:这种昂方式不推荐);
方式二

./sbin/nginx -s stop

如果我们修改了Nginx的配置文件,要怎么才能使修改后的配置文件生效呢?方式有两种:方式一:关闭Nginx服务器再重新开启Nginx服务器。方式二:通过 sbin目录下的可执行文件nginx执行命令./nginx -s reload

使用Nginx配置虚拟机

通过端口区分虚拟机
在Nginx安装目录中的conf目录中的nginx.conf文件中添加一个Service节点,修改端口号就可以:
说明:在Nginx中的nginx.conf配置文件中每个server代表一个虚拟机

server {
        listen       81;  #监听虚拟主机的端口号(通过端口不一样可以进行区分虚拟机)
        server_name  localhost;  #虚拟主机名

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html1;  #虚拟主机的根路径
            index  index.html index.htm; #默认访问页面
        }
   }

通过域名区分虚拟机
关于域名不懂的可以进行百度;
修改nginx.conf配置文件:

server {
        listen       80; #这里使用默认端口
        server_name  test.taotao.com;#这里使用域名对虚拟机进行区分(关于在本机中如何自定义域名,大家可以去了解下域名的解析过程就知道了)

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-test3;
            index  index.html index.htm;
        }
   }

使用Nginx作为负载均衡服务器

负载均衡:当我们把应用程序部署到多个服务器上时,由于每个服务器执行请求的繁忙不一样,这样,我们就可以在用户发送请求的时候通过Nginx作为反向代理服务器,把用户的请求分配到相对来说比较轻松的应用服务器中去。

    #在upstream下配置需要代理的服务器
    upstream tomcats{
    #下面每个server都是反向代理的服务器,既然代理服务器就需要配置代理服务器的ip和端口
    #weight是Nginx对代理服务器的发送转送请求的权重,默认都是1(如果某个服务器的运行效率低就可以设置权重相对低点)
        server 10.201.232.235:8080 weight=1;
        server 10.201.232.235:80 weight=2;
    } 
    #create service
    server {
        listen       80;
        server_name  www.taotao.com;

        #charset koi8-r; 

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass http://tomcats; #配置代理路径
            index  index.html index.htm index.jsp;
        }
     }

说明:负载均衡是采用的反向代理的方式实现的。关于正向代理和反向代理,我这里就不再多做阐述了,不懂的观客们可以百度下

猜你喜欢

转载自blog.csdn.net/ititii/article/details/80232430