linux centos7 nginx 安装部署和配置
1/什么是Nginx
Nginx("enginex")是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器,在高连接并发的情况下Nginx是Apache服务器不错的替代品.其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好.目前中国大陆使用nginx网站用户有:新浪、网易、腾讯,另外知名的微网志Plurk也使用nginx。
Nginx作为负载均衡服务器,既可以在内部直接支持Rails和PHP程序对外进行服务,也可以支持作为HTTP代理服务器对外进行服务。Nginx采用C进行编写,不论是系统资源开销还是CPU使用效率都比Perlbal要好很多。
Nginx作为邮件代理服务器,是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器)。
Nginx是一个安装非常简单,配置文件非常简洁(还能够支持perl语法),Bugs非常少的服务器;Nginx启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动,还能够不间断服务的情况下进行软件版本的升级。
2Nginx的安装
2.1Nginx安装包下载
Nginx包下载地址:
http://nginx.org/download/nginx-1.8.0.tar.gz
Nginx依赖包下载地址:
1.gzip模块需要zlib库(在http://www.zlib.net/下载http://zlib.net/zlib-1.2.8.tar.gz)
2.rewrite模块需要pcre库(在http://www.pcre.org/下载ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/)
3.ssl功能需要openssl库(在http://www.openssl.org/下载http://www.openssl.org/source/openssl-fips-2.0.9.tar.gz)
或者下载全包openssl-1.0.2o.tar
2.2Nginx安装
          安装前确认linux下这些库已经安装
yum install perl 
yum install gcc
yum install gcc-c++
yum -y install net-tools
1.将安装包放到/home/nginx_install目录下,截图如下:
    
2.安装openssl-fips-2.0.9.tar.gz,执行命令如下:
            OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。,安装OpenSSL(http://www.openssl.org/source/)主要是为了让tengine支持Https的访问请求。具体是否安装看需求。
cd /home/nginx_install  
tar -zxvf openssl-1.0.2o.tar.gz
cd openssl-1.0.2o
#prefix配置安装路径  
./config --prefix=/opt/ldkjdata/nginx/openssl-1.0.2o 
make  
make install
openssl:wget http://www.openssl.org/source/openssl-0.9.8m.tar.gz 解压不make
最新版本为openssl-1.0.2o.tar
3.安装zlib-1.2.8.tar.gz
            Zlib是提供资料压缩之用的函式库,当Tengine想启用GZIP压缩的时候就需要使用到Zlib(http://www.zlib.net/)
cd /home/nginx_install  
tar -zxvf zlib-1.2.11.tar.gz 
cd zlib-1.2.11  
./configure --prefix=/opt/ldkjdata/nginx/zlib-1.2.11 
make  
make install
4.安装pcre-8.37.tar.gz
            PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx rewrite依赖于PCRE库,所以在安装Tengine前一定要先安装PCRE,最新版本的PCRE可在官网(http://www.pcre.org/)获取。
cd /home/nginx_install    
tar -zxvf pcre-8.42.tar.gz   
cd pcre-8.42
./configure --prefix=/opt/ldkjdata/nginx/pcre-8.42  
make  
make install
5.安装nginx-1.8.0.tar.gz
cd /home/nginx_install  
tar -zxvf nginx-1.14.0.tar.gz 
cd nginx-1.14.0
#with-pcre指定依赖包位置,prefix配置安装路径  
./configure --with-pcre=../pcre-8.42 --with-zlib=../zlib-1.2.11 --with-openssl=../openssl-fips-2.0.16 --prefix=/opt/ldkjdata/nginx/nginx-1.14.0
或者 
./configure --with-pcre=../pcre-8.42 --with-zlib=../zlib-1.2.11 --with-openssl=../openssl-1.0.2o --with-http_ssl_module --prefix=/opt/ldkjdata/nginx/nginx-1.14.0
make  
make install
3Nginx检测
cd /opt/ldkjdata/nginx/nginx-1.14.0/sbin
 ./nginx -t
看到如下提示,表示安装成功。
nginx: the configuration file /opt/ldkjdata/nginx/nginx-1.14.0/conf/nginx.conf syntax is ok
nginx: configuration file /opt/ldkjdata/nginx/nginx-1.14.0/conf/nginx.conf test is successful
4.Nginx启动和端口查看
cd /opt/ldkjdata/nginx/nginx-1.14.0/sbin
./nginx     启动
./nginx -s stop  停止
./nginx -s reload  修改配置后重新加载配置
netstat -ntlp   查看tcp是否正常监听
5.一个简单的Nginx转发例子
    1.需求
    短信服务器列表三台,提供服务的地址如下:
http://192.168.88.21:8091/smsserver/services/sendSms?wsdl
    http://192.168.88.22:8091/smsserver/services/sendSms?wsdl
    http://192.168.88.23:8091/smsserver/services/sendSms?wsdl
    彩信服务器列表三台,提供服务的地址如下:
http://192.168.88.21:8092/msserver/services/sendMms?wsdl
    http://192.168.88.22:8092/mmsserver/services/sendMms?wsdl
    http://192.168.88.23:8092/mmsserver/services/sendMms?wsdl
Nginx安装在另外一台单独机器上(公网IP为public_ip),对外提供服务地址如下:
    http://public_ip:8090/smsserver/services/sendSms?wsdl  短信发送服务
    http://public_ip:8090/mmsserver/services/sendMms?wsdl  彩信发送服务
2.对于以上需求,配置/opt/nginx-1.8.0/conf/nginx.conf如下:
#user  nobody;  
worker_processes  1;
#error_log  logs/error.log;  
#error_log  logs/error.log  notice;  
#error_log  logs/error.log  info;
#pid logs/nginx.pid;
events {  
    worker_connections  1024;  
}
http {  
    include       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 logs/access.log main;
sendfile        on;  
    #tcp_nopush     on;
#keepalive_timeout  0;  
    keepalive_timeout  65;  
    #设定请求缓冲, start  
    client_header_buffer_size 1k;  
    large_client_header_buffers 4 4k;  
    #设定请求缓冲, end
#设定提供服务的服务器,start  
    #短信发送服务器  
    upstream smsserver{  
        #weigth       表示权重,权值越大,分配几率越大  
        #max_fails    当有max_fails个请求失败,就表示后端的服务器不可用,默认为1,将其设置为0可以关闭检查  
        #fail_timeout 在以后的fail_timeout时间内nginx不会再把请求发往已检查出标记为不可用的服务器  
        server 192.168.88.21:8091 weight=5 max_fails=5 fail_timeout=600s;  
        server 192.168.88.22:8091 weight=5 max_fails=5 fail_timeout=600s;  
        server 192.168.88.23:8091 weight=5 max_fails=5 fail_timeout=600s;  
    }  
    #彩信发送服务器  
    upstream mmsserver{  
        #weigth       表示权重,权值越大,分配几率越大  
        #max_fails    当有max_fails个请求失败,就表示后端的服务器不可用,默认为1,将其设置为0可以关闭检查  
        #fail_timeout 在以后的fail_timeout时间内nginx不会再把请求发往已检查出标记为不可用的服务器  
        server 192.168.88.21:8092 weight=5 max_fails=5 fail_timeout=600s;  
        server 192.168.88.22:8092 weight=5 max_fails=5 fail_timeout=600s;  
        server 192.168.88.23:8092 weight=5 max_fails=5 fail_timeout=600s;  
    }  
    #设定提供服务的服务器,end
#gzip on;
server {  
        listen       8090;  
        server_name  localhost;  
    #设定请求转发规则, start  
    #规则采用最长匹配,/smsserver/*优先匹配/smsserver,/mmsserver/*优先匹配/mmsserver,/aaaaaaaa/*因为没有任何匹配,最后匹配到/  
        #规则一  
    location / {  
            proxy_pass http://localhost:80;  
        }  
        #规则二  
        location /smsserver {  
        proxy_pass http://smsserver;   
        }  
        #规则三  
        location /mmsserver {  
        proxy_pass http://mmsserver;   
        }  
    #设定请求转发规则, end  
        error_page   500 502 503 504  /50x.html;  
        location = /50x.html {  
            root   html;  
        }  
    }
server {  
        listen       80;  
        server_name  localhost;  
    #设定请求转发规则, start  
        location / {  
            #定义服务器的默认网站根目录位置    
            root /home/work/statichtml/index.html;   
            #定义首页索引文件的名称      
    #index index.php index.html index.htm;   
    #请求转向orderServer定义的服务器列表     
    # proxy_pass http://server;
#以下是一些反向代理的配置可删除.     
    # proxy_redirect off;      
    # proxy_set_header Host $host;      
    # proxy_set_header X-Real-IP $remote_addr;      
    # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;     
    #允许客户端请求的最大单文件字节数       
    # client_max_body_size 10m;   
    #缓冲区代理缓冲用户端请求的最大字节数,  
    # client_body_buffer_size 128k;       
    #nginx跟后端服务器连接超时时间(代理连接超时)     
    # proxy_connect_timeout 90;    
    #后端服务器数据回传时间(代理发送超时)   
    # proxy_send_timeout 90;      
    #连接成功后,后端服务器响应时间(代理接收超时)   
    # proxy_read_timeout 90;      
    #设置代理服务器(nginx)保存用户头信息的缓冲区大小    
    # proxy_buffer_size 4k;     
        #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置   
        # proxy_buffers 4 32k;      
        #高负荷下缓冲大小(proxy_buffers*2)   
    # proxy_busy_buffers_size 64k;      
    #设定缓存文件夹大小,大于这个值,将从upstream服务器传   
    # proxy_temp_file_write_size 64k;   
        }  
    #设定请求转发规则, end  
        error_page   500 502 503 504  /50x.html;  
        location = /50x.html {  
            root   html;  
        }  
    }  
}
6.例子2(暴露接口,但隐藏web项目的根目录)
   上面6中例子有个问题是,直接将我整个web根目录smsserver和mmsserver暴露到公网了,其实我的目的只是想暴露两个接口地址,所以6有待优化,举个例子如下:
1.需求
    接口服务器列表两台台,提供服务的地址如下:
    接口一:
    http://192.168.88.21:8082/myweb/interface/getData
    http://192.168.88.22:8082/myweb/interface/getData
    接口二:
    http://192.168.88.21:8082/myweb/interface/sendData
    http://192.168.88.22:8082/myweb/interface/sendData
Nginx安装在另外一台单独机器上(公网IP为public_ip),对外提供服务地址如下:                        
     http://public_ip:8081/myweb/interface/getData   接口一    
     http://public_ip:8081/myweb/interface/sendData  接口二
    2.对于以上需求,配置/opt/nginx-1.8.0/conf/nginx.conf如下:
#user  nobody;  
worker_processes  1;  
#error_log  logs/error.log;  
#error_log  logs/error.log  notice;  
#error_log  logs/error.log  info;  
#pid  logs/nginx.pid;  
events {  
    worker_connections  1024;  
}  
http {  
    include       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 logs/access.log main;
sendfile        on;  
    #tcp_nopush     on;
#keepalive_timeout  0;  
    keepalive_timeout  65;  
    #设定请求缓冲, start  
    client_header_buffer_size 1k;  
    large_client_header_buffers 4 4k;  
    #设定请求缓冲, end
#设定提供服务的服务器,start  
    #我的接口服务器,两台  
    upstream myweb{  
        #weigth       表示权重,权值越大,分配几率越大  
        #max_fails    当有max_fails个请求失败,就表示后端的服务器不可用,默认为1,将其设置为0可以关闭检查  
        #fail_timeout 在以后的fail_timeout时间内nginx不会再把请求发往已检查出标记为不可用的服务器  
        server 192.168.88.23:8082 weight=5 max_fails=5 fail_timeout=600s;  
        server 192.168.88.24:8082 weight=5 max_fails=5 fail_timeout=600s;  
    }  
    #设定提供服务的服务器,end
#gzip on;
server {  
        listen       80;  
        server_name  localhost;  
    #设定请求转发规则, start  
    #规则采用最长匹配,即长度最长优先匹配,最后不匹配的走/进行匹配  
    #规则一  
    location / {  
            root   html;  
            index  index.html index.htm;  
        }  
    #设定请求转发规则, end  
        error_page   500 502 503 504  /50x.html;  
        location = /50x.html {  
            root   html;  
        }  
    }
server {  
        listen       8081;  
        server_name  localhost;  
    #设定请求转发规则, start  
    #规则采用最长匹配,即长度最长优先匹配,最后不匹配的走/进行匹配  
    #规则一  
    location / {  
            root   html;  
            index  index.html index.htm;  
        }  
    #规则二,查询接口一  
    location /myweb/interface/getData {  
        proxy_pass http://myweb;  
    #转发请求的原IP地址,程序中通过request.getHeader("Proxy-Client-IP")获得ip  
        proxy_set_header Host      $host;  
    #如果是有涉及redirect的服务,一定要加上端口8081,否则默认tomcat在redirect时候默认找80端口  
        #proxy_set_header Host $host:8081;  
        proxy_set_header Proxy-Client-IP $remote_addr;  
        }  
    #规则三,查询接口二  
    location /myweb/interface/sendData {  
        proxy_pass http://myweb;  
    #转发请求的原IP地址,程序中通过request.getHeader("Proxy-Client-IP")获得ip  
        proxy_set_header Host      $host;  
    #如果是有涉及redirect的服务,一定要加上端口8081,否则默认tomcat在redirect时候默认找80端口  
        #proxy_set_header Host $host:8081;  
        proxy_set_header Proxy-Client-IP $remote_addr;  
    }  
    #设定请求转发规则, end  
        error_page   500 502 503 504  /50x.html;  
        location = /50x.html {  
            root   html;  
        }  
    }  
}
7.例子3  文件映射
/conf/nginx.conf中第一行的运行用户改为
user  root;
  location /uploadfile {
            root  /opt/staticdata/;
            access_log /opt/nginx/logs/upload_access.log;
            proxy_store_access user:rw group:rw all:rw;
        }
当访问http://ip:port/uploadfile/aa/bb/cc.jpg
相当于访问 /opt/staticdata/uploadfile/aa/bb/cc.jpg
8.说明
 以上安装教程经过亲自实践并优化,主要参考https://www.cnblogs.com/IPYQ/p/6609969.html
linux centos7 nginx 安装部署和配置的更多相关文章
- Linux(CENTOS7) Nginx负载均衡简单配置
		负载均衡的作用 1.转发功能 按照一定的算法[权重.轮询],将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量. 2.故障移除 通过心跳检测的方式,判断应用服务器当前是否可以正常工 ... 
- Linux Centos7.x 安装部署Mysql5.7几种方式的操作手册
		简述 Linux Centos7.x 操作系统版本下针对Mysql的安装和使用多少跟之前的Centos6之前版本有所不同的,下面介绍下在centos7.x环境里安装mysql5.7的几种方法: 一. ... 
- Linux中Nginx安装部署
		前言 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sys ... 
- Linux(CENTOS7) Nginx安装
		1.下载nginx 在disk目录下,输入以下命令进行下载: wget http://nginx.org/download/nginx-1.12.2.tar.gz 2.解压nginx 在disk目录 ... 
- centos7 下 安装部署nginx
		centos7 下 安装部署nginx 1.nginx安装依赖于三个包,注意安装顺序 a.SSL功能需要openssl库,直接通过yum安装: #yum install openssl b.gzip模 ... 
- Linux中Nginx安装与配置详解
		转载自:http://www.linuxidc.com/Linux/2016-08/134110.htm Linux中Nginx安装与配置详解(CentOS-6.5:nginx-1.5.0). 1 N ... 
- VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三)
		首先启动Nginx 1. 相关浏览 两个 Tomcat 配置: VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二) Nginx 安装配置启动: VMware Linu ... 
- VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二)
		准备工作 相关浏览: VMware Linux 下 Nginx 安装配置 (一) 1. 选在 /usr/local/ 下创建 softs 文件夹,通过 ftp 命令 把 apache-tomcat-7 ... 
- centos7.8 安装部署 k8s 集群
		centos7.8 安装部署 k8s 集群 目录 centos7.8 安装部署 k8s 集群 环境说明 Docker 安装 k8s 安装准备工作 Master 节点安装 k8s 版本查看 安装 kub ... 
随机推荐
- 【原创】Apache ab出现 apr_pollset_poll: The timeout specified has expired 错误
			使用如下参数可避免 -s timeout Seconds to max. wait for each response Default is 30 seconds -k Use HTTP KeepAl ... 
- 【node.js】GET/POST请求、Web 模块
			获取GET请求内容 node.js 中 url 模块中的 parse 函数提供了这个功能. var http = require('http'); var url = require('url'); ... 
- memcached/memcache安装
			memcached安装 查找memcached: yum search memcached安装 memcached yum -y install memca ... 
- Docker实战(七)之为镜像添加SSH服务
			1.基于commit命令创建 Docker提供了docker commit命令,支持用户提交自己对制定容器的修改,并生成新的镜像.命令格式为docker commit CONTAINER [REPOS ... 
- 记一次js之button问题
			问题描述:记得某天,发现一件让我非常气愤的事情,居然因为一个按钮导致页面跳转失败或者是根本跳转不了界面,哪怕404也不给我报. 问题回现步骤: (1)正常输入url localhost:8080/te ... 
- RadioButtonFor值为false.默认选中的问题
			(自己看了下.图片有点宽.显示的不全.可以右键新标签查看) 作为一个新手.今天又开始了mvc的学习之旅.然而学习过程中又遇到了一个奇妙的问题.... 一切按部就班到了这里.注册界面. 一眼看上去就不对 ... 
- 【绝密】为什么现在的CAN收发器通信距离越来越短?
			[绝密]为什么现在的CAN收发器通信距离越来越短? CAN收发器的改良和隔离器件引入,大大提高了通信的可靠性,但同时也引入了额外的延时,导致通信距离变短,或总线错误帧增加,本文以1Mbps波特率下 ... 
- 升序排列的数组中是否存在A[i]=i
			#include<stdio.h> void equal(int a[],int N) { int i; ;i<N;i++) { if(i<a[i]) { printf(&qu ... 
- java 快速开发框架平台 二次开发 代码生成器 springmvc SSM后台框架源码
			官网 http://www.fhadmin.org/D 集成安全权限框架shiro Shiro 是一个用 Java 语言实现的框架,通过一个简单易用的 API 提供身份验证和授权,更安全,更可靠E ... 
- Python虚拟环境包导出
			一.导出包文件 1.进入虚拟环境 2.进入项目目录下创建放置包文件的文件夹(whls) mkdir whls 3.进入whls文件夹,执行导出命令 (导入包时有网络) cd whls pip free ... 
