Nginx简单配置

一、Nginx虚拟主机

在Nginx中,我们可以使用多个配置文件来更加人性化的管理不同的站点,首先需要在Nginx的配置文件,nginx.conf中http部分加入这样一行:

    include vhost/*.conf

在当前目录下创建vhost目录,然后在vhost目录下创建一个.conf配置文件,简单的配置大致如下:

server
{
    listen 80 default_server;
    server_name default.com;
    index index.html index.htm index.php;
    root /data/www/default;
}

default_server:这个标记表示默认虚拟主机。

二、域名重定向

server
{
    listen 80;
    server_name www.example.com www.aaa.com;
    index index.html index.htm index.php;
    root /data/www/example;

    if ($host != 'www.example.com'){
        rewrite ^/(.*)$ http://www.example.com/$1 permanent;
    }
}
  • server_name后面支持写多个域名,这里要和httpd的做一个对比。
  • permanent为永久重定向,状态码为301,如果写redirect则为302

也可以这样写:

rewrite ^/(.*)$ http://www.example.com/$1 permanent;

三、Nginx代理

假设有多台服务器,仅有一个公网IP,而为了节约成本,不能为所有的服务器分配公网IP,但是又要提供web服务,这个时候就可以通过配置代理服务器来实现。

代理:

server
{
    listen 80;
    server_name www.example.com;

    location /
    {
        proxy_pass      http://ipaddress;
        proxy_set_header Host   $host;
        # 下面这两个是获取客户端的真实IP和代理IP
        proxy_set_header X-Real-IP      $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

如果是代理本地服务的话:

proxy_pass      http://127.0.0.1:port;

负载均衡:

上面的配置仅仅是代理一台web服务器,在生产环境中,不可能只有两台服务器,如果要同时代理多台服务器,Nginx在这里就可以起到负载均衡的作用。

关于负载均衡的相关配置如下:

# bbs_com可以自定义
upstream diyname
{
    ip_hash;
    # 后端web服务器的IP地址
    server ipaddr1:80;
    server ipaddr2:80;
}
server
{
    listen 80;
    server_name www.example.com;

    location /
    {
        proxy_pass      http://diyname;
        proxy_set_header Host   $host;
        proxy_set_header X-Real-IP      $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

我们也可以进行其他它定义:

server ipaddr1:80 weight 3 max_fails=3 fail_timeout=15;
server ipaddr2:80;
  • weight表示权重,如果有四次访问,怎三次在ipaddr1上,一次在ipaddr2上。
  • max_fails:表示最大的失败次数。
  • fail_timeout:失败时间,如果有3次请求失败,nginx在15秒内,不会将新的请求分配给它。

动态静态文件分离

针对apache和nginx共同协作的网站架构,也可以根据动态内容和静态内容的请求来做负载均衡:


       location ~* .*\.(php|phps|jsp)$ 
       {
            proxy_pass  http://apache.com;
       }

四、防止恶意解析

什么是恶意解析?

假如你们公司里web服务器是多台组成的一个集群,所以IP是不一样的,对方在ping你们域名的时候会出来一个IP,但是这个IP不是万网对应你们域名的IP,然后他们拿到这个IP,在万网上边把他们的域名解析到你这个IP上来,这就造成一个问题:
如果他们的域名没备案的话,公安局就会一直找你们公司。

解决方案

让使用IP直接访问网站的,或者访问恶意解析到你们公司IP的域名,收到501错误:

server {
    listen 80 default_server;
    server_name _;
    return 501;
}

说明:假如nginx多个虚拟主机,如果直接访问IP的话,nginx会默认访问第一个虚拟主机,所以通过IP直接访问的话就是访问第一个虚拟主机,就会报501错误,如果其他域名恶意解析到你这个IP上了也会返回501错误。

标签: web

添加新评论