Nginx实现泛域名CDN节点配置

   如何使用Nginx泛域名解析+反向代理+静态资源缓存呢?

  1.安装nginx,安装过程不再赘述,记得带上pcre、gzip、sub、status这几个模块,另外如果想开通在线清理缓存功能,需要安装ngx_cache_purge这个第三方模块。

  2.删除nginx.conf中默认的server段,此操作不做你会让你抱憾终身。

  3.将以下代码插入nginx.conf尾部,-t测试-s reload重启即可。

 代码如下  

#定义缓存的临时目录以及缓存存储目录
proxy_temp_path /data/temp;
proxy_cache_path /data/cache levels=1:2 keys_zone=cache_one:32m inactive=1d max_size=3g;
server
{
    listen 80;
    #接收泛域名解析,务必保证在这之前没有其他server段干扰。
    server_name _;
    root /tmp;
    access_log off;

    #匹配出对应域名
    if ( $host ~* (.*).(.*).(.*))
    {
        set $domain $1;
    }

    location /
        {
        #定义所使用的缓存以及缓存的目录结构。
        proxy_cache cache_one;
        proxy_cache_valid  200 304 12h;
        proxy_cache_key $host$uri$is_args$args;
        #下面这条灰常重要,告知upstream源服务器所要请求的域名是什么。
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        #把请求扔给upstream,然后等着领赏吧。
        proxy_pass http://jp0129;
        proxy_set_header Accept-Encoding "";
        expires 1d;
        }
    location ~ .*.(php)?$
        {
        #动态请求不缓存
        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_pass http://jp0129;
        proxy_set_header Accept-Encoding "";
        }
}
upstream  jp0129
{
        server 106.187.51.139;
}

  大功告成,根据自身情况上机器,每台部署一个nginx即可,在域名管理中把vcs.xxx.com直接A记录几条轮询,配合一个小脚本来实现检测各个节点是否存活,节点宕掉就直接通过dnspod的api修改vcs.xxx.com的解析记录,剔除无效节点即可。

  附一个Nginx下泛域名解析配置

  在Nginx下支持泛域名解析其实很简单.只要在在编译 Nginx的时候加上以下代码即可

  --with-http_sub_module

  在配置nginx时:

 代码如下  

server {

        # Replace this port with the right one for your requirements

        listen      80;#could also be 1.2.3.4:80

 

        # Multiple hostnames seperated by spaces.  Replace these as well.

        server_name  www.111cn.net *.你的域名.com;

        #Alternately: _ *

        root /PATH/TO/WEBROOT/$host;

        error_page  404              http://yourdomain.com/errors/404.html;

        access_log  logs/yourdomain.com.access.log;

        location / {

            root  /PATH/TO/WEBROOT/$host/;

            index  index.php;

        }

 

        # serve static files directly

        location ~* ^.+.(jpg|jpeg|gif|css|png|js|ico|html)$ {

            access_log        off;

            expires          30d;

        }

 

        location ~ .php$ {  

          # By all means use a different server for the fcgi processes if you need to  

          fastcgi_pass  127.0.0.1:YOURFCGIPORTHERE;

          fastcgi_index  index.php;

 

          fastcgi_param  SCRIPT_FILENAME  /PATH/TO/WEBROOT/$host/$fastcgi_script_name;

          fastcgi_param  QUERY_STRING    $query_string;

          fastcgi_param  REQUEST_METHOD  $request_method;

          fastcgi_param  CONTENT_TYPE    $content_type;

          fastcgi_param  CONTENT_LENGTH  $content_length;

          fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;

          fastcgi_param  REQUEST_URI        $request_uri;

          fastcgi_param  DOCUMENT_URI      $document_uri;

          fastcgi_param  DOCUMENT_ROOT      $document_root;

          fastcgi_param  SERVER_PROTOCOL    $server_protocol;

          fastcgi_param  REMOTE_ADDR        $remote_addr;

          fastcgi_param  REMOTE_PORT        $remote_port;

          fastcgi_param  SERVER_ADDR        $server_addr;

          fastcgi_param  SERVER_PORT        $server_port;

          fastcgi_param  SERVER_NAME        $server_name;

          fastcgi_intercept_errors on;

        }

 

        location ~ /.ht {

            deny  all;

        }

    }

  然后启动nginx就可以实现泛域名解析了

时间: 2024-09-12 02:23:48

Nginx实现泛域名CDN节点配置的相关文章

Nginx中泛域名配置的实例教程_nginx

原本准备换Linux服务器,所以数据迁移暂时需要使用静态页面临时代替一下,之前的article.asp?id=xxx都要重定向到静态文件 article/xxx.htm,nginx的rewrite比apache的强大很多,还可以用if语句,很容易理解,下面看看Nginx是如何进行Rewrite的! 提示:以下rewrite指令写在 nginx.conf 配置的 server { - } 中 最常见的: 静态地址重定向到带参数的动态地址 rewrite "^(.*)/service/(.*)/.h

nginx将泛解析的匹配域名绑定到子目录配置方法_nginx

网站的目录结构为:  # tree /home/wwwroot/exehack.net /home/wwwroot/exehack.net ├── bbs │   └── index.html └── www     └── index.html 2 directories, 2 files /home/wwwroot/exehack.net为nginx的安装目录下默认的存放源代码的路径. bbs为论坛程序源代码路径:www为主页程序源代码路径:把相应程序放入上面的路径通过:http://www

LNMP下Nginx设置域名301重定向配置

LNMP下的Nginx如果想将域名111cn.net 301重定向到www.111cn.net,同时www.111cn.net已经通过lnmp vhost add添加上, 可以按如下步骤修改. 编辑对应的虚拟主机配置文件,一般虚拟主机配置文件位于:/usr/local/nginx/conf/vhost/域名.conf ,如添加的域名是www.111cn.net 则配置文件是/usr/local/nginx/conf/vhost/www.111cn.net.conf 在配置文件最后面加上如下代码:

Nginx实现www域名的301跳转的配置

之前,微魔曾经跟大家分享了多篇关于Nginx的教程文章(请以"Nginx"为关键字在本站右侧搜索栏自行搜索),关于伪静态,有一篇集中汇总各个程序的Nginx伪静态的文章(传送),但是却遗忘了最常见的www域名跳转的问题,关于这个跳转,对SEO的友好程度见仁见智,在微魔看来,只是更喜欢自己的站点以www的形式示人而已. #伪静态# Nginx实现www域名的301跳转 1.将example.com定向到www.example.com   server {     listen 80;  

泛域名ssl证书搭建全攻略

  无忧在线项目管理(www.5upm.com)是禅道开发团队给大家提供的一款在线的项目管理服务,它提供了禅道软件专业版本的功能,同时内置了subversion和git的源码托管服务,这样创业型团队或者跨地域团队就可以异地办公,实现跨地域的协同管理. 在实际运营无忧在线过程中,安全是很多客户比较关心的问题.对于这个问题我们通过很多种手段来加以解决,比如操作系统层面,应用程序层面等等.最近无忧在线项目管理又上线了https访问功能,进一步加强了无忧在线的安全性. 下面是笔者配置无忧在线https访

《Linux/UNIX OpenLDAP实战指南》——2.5 OpenLDAP单节点配置案例

2.5 OpenLDAP单节点配置案例 2.5.1 安装环境规划 安装环境的拓扑图如图2-1所示. 安装环境要求如下. 环境平台:VMware ESXi 5.0.0 系统版本:Red Hat Enterprise Linux Server release 6.5 (Santiago) 软件版本:OpenLDAP-2.4.23-32 IP地址及主机名规划如表2-1所示. OpenLDAP相关软件包套件如表2-2所示. 2.5.2 主机名规划配置 LDAP服务端和客户端主机名称及对应的IP地址解析服

关于tomcat的server.xml里host节点配置的一些说明_Tomcat

其实对这个一直搞不清楚,后来公司的网站遭遇与IIS进行整合,然后上面有几个应用需要进行配置,所以对tomcat的server.xml进行了一些深入的了解 Host的节点主要是起一个对域名解析到那个虚拟主机进行配置,其name属性即为访问的域名,默认是127.0.0.1,localhost以及本地Ip,当进行DNS指定之后,可以凭借域名对指定的虚拟主机进行访问. 里面的一些属性就不多讲了,看到单词基本上能明白什么意思. 然后就是context节点,这个节点主要是配置虚拟主机里的访问项目的,默认访问

Apache实现本地建立泛域名虚拟主机的方法_Linux

本文讲述了Apache实现本地建立泛域名虚拟主机的方法.分享给大家供大家参考,具体如下: 在本地建立泛域名虚拟主机,可以修改Apache的安装目录下的conf/httpd.conf,如下: <VirtualHost *:80> ServerName auciou.com ServerAlias *.auciou.com DocumentRoot F:/site/auciou </VirtualHost> 重启Apache,就可以在本地同时使用auciou.com和xxx.aucio

Nginx+Tomcat+Https 服务器负载均衡配置实践方案详解_nginx

由于需要,得搭建个nginx+tomcat+https的服务器,搜了搜网上的发现总是有错,现在整理了些有用的,备忘. 环境:Centos6.5.JDK1.8.Tomcat8.Nginx1.10.1 准备材料: 1.JDK1.8安装包jdk-8u102-linux-x64.tar.gz 2.Tomcat8安装包apache-tomcat-8.0.37.tar.gz 3.Nginx1.10安装包nginx-1.10.1.tar.gz 1.JDK安装配置 解压并安装到/usr/local/jdk [r