美文网首页
Centos_Nginx_Configuration

Centos_Nginx_Configuration

作者: zyf_java | 来源:发表于2017-12-27 10:21 被阅读0次

    Nginx:

    nginx 是一个用C语言编写的静态服务器。
    我们可以用它来做反向代理。

    案例1:

    一个网站的访问量很大,如果很大的数据量都用一台服务器来处理,那么就会导致服务器主机压力很大,甚至导致奔溃。

    例如全球都可以访问(当然天朝大不认还是上不了的..) www.google.com ,那么就可以用nginx做分发。在www.google.com 解析一台主机(例如110.110.100.23), 当请求发到该主机的时候, 通过nginx分发到不同的其他服务器主机上, 这样就缓解了当前主机的压力。

    案例2:

    域名解析只能解析到ip, 不能解析到对应到ip主机对应的某一个端口号
    所以你在主机上跑了一个应用是非80端口的,那么你访问你的应用的时候就要域名加上端口才能访问到。

    例如:www.daliandaxue.cn:8443,那么你想隐藏掉这个端口,就可以用Nginx反向代理来做。

    安装Nginx

    环境

    操作系统Centos7.2

    安装命令:yum install nginx

    启动命令:nginx

    优雅启动命令:nginx -s reload

    测试启动情况:nginx -t

    重启nginx:nginx -s reload

    针对案例2,需要添加一些配置

    在/etc/nginx/nginx.conf 有两个关键的地方:

    user nginx; 改为 nginx root;
    

    若不改动, 会在你启动nginx的时候出现权限不允许的error。

    include /etc/nginx/conf.d/*.conf;
    

    这个inclde的意思就是你在conf.d 文件下的所有的 *.conf 文件, 都会在nginx启动的时候加载进去。

    如果在/etc/nginx/下没有conf.d 文件夹,你可以创建conf.d文件夹。

    下创建一个自己的.conf配置文件, 或者你可以直接修改/etc/nginx/nginx.conf文件。

    我选择直接修改nginx.conf这个文件

    修改后的nginx.conf文件(我添加了HTTPS 配置)
    SSL configuration:

    user root;
    worker_processes auto;
    error_log /var/log/nginx/error.log;
    pid /run/nginx.pid;
    
    
    include /usr/share/nginx/modules/*.conf;
    
    events {
    worker_connections 1024;
    }
    
    http {
    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  /var/log/nginx/access.log  main;
    
    sendfileon;
    tcp_nopush  on;
    tcp_nodelay on;
    keepalive_timeout   65;
    types_hash_max_size 2048;
    
    include /etc/nginx/mime.types;
    default_typeapplication/octet-stream;
    
    
    include /etc/nginx/conf.d/*.conf;
    
    server {
    listen   80 default_server;
    listen   [::]:80 default_server;
    server_name  www.daliandaxue.cn;
    root /usr/share/nginx/html;
     
    include /etc/nginx/default.d/*.conf;
    
    location / {
            rewrite ^(.*) https://$server_name$1 permanent;
    }
    
    error_page 404 /404.html;
    location = /40x.html {
    }
    
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    }
    }
    
    
       server {
       listen   443 ssl http2 default_server;
       listen   [::]:443 ssl http2 default_server;
    server_name  www.daliandaxue.cn;
    root /usr/share/nginx/html;
    
            ssl on;
            ssl_certificate /etc/nginx/cert/214327484730823.pem;
            ssl_certificate_key /etc/nginx/cert/214327484730823.key;
            ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
            ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
            ssl_prefer_server_ciphers on;
    
    
    include /etc/nginx/default.d/*.conf;
    
    location / {
                proxy_pass  http://localhost:8443;
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_redirect off; 
                `### Most PHP, Python, Rails, Java App can use this header -> https ###`
                proxy_set_header X-Forwarded-Proto  $scheme;
    }
    
        error_page 404 /404.html;
        location = /40x.html {
        }
    
        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
    }
    }
    

    配置完nginx.conf 文件之后,执行nginx -s reload 就可以通过域名直接访问你的应用了。
    其中的原理就是nginx 监听了服务器主机的80端口。 当有请求通过你设置server_name 访问时,nginx就可以把该请求location 到你的应用上。

    相关文章

      网友评论

          本文标题:Centos_Nginx_Configuration

          本文链接:https://www.haomeiwen.com/subject/olwygxtx.html