nginx配置多个二级子域名

 配置/etc/nginx/nginx.conf(例子是https)

user nginx;
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;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;
    
    include /etc/nginx/conf.d/*.conf;

    ##
    # 强制https
    ##
    server {
        listen 80;
        server_name *.jindw.cn;
        rewrite ^(.*)$  https://$host$1 permanent;
    }

    server {
        if ( $host ~* (\b(?!www\b)\w+)\.\w+\.\w+ ) {
             set $subdomain /$1;
        }

        location / {
             root html$subdomain;
             index index.html index.php index.htm index;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

}

 

 重点

  •  `include /etc/nginx/conf.d/*.conf;`
  •  `server`内的
if ( $host ~* (\b(?!www\b)\w+)\.\w+\.\w+ ) {
     set $subdomain /$1;
}

location / {
     root html$subdomain;
     index index.html index.php index.htm index;
}

 配置  https://www.xxx.cn

vi  /etc/nginx/conf.d/www.xxx.cn.conf
server {
    gzip on;
    gzip_types text/plain text/css application/javascript application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
    etag on;
    listen 443 ssl;
    server_name www.xxx.cn;

    ssl_certificate       /ssl/www.crt;
    ssl_certificate_key   /ssl/www.key;

    ssl on;
    ssl_session_cache  builtin:1000  shared:SSL:10m;
    ssl_protocols  TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
    ssl_prefer_server_ciphers on;

    access_log            /var/log/nginx/www.log;

    location / {

        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_set_header        X-Forwarded-Proto $scheme;

        proxy_pass          http://localhost:6061;//..
        proxy_read_timeout  90;
    }
}


配置  https://a.xxx.cn
 

vi  /etc/nginx/conf.d/a.xxx.cn.conf
server {
    gzip on;
    gzip_types text/plain text/css application/javascript application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
    etag on;
    listen 443 ssl;
    server_name a.xxx.cn;

    ssl_certificate       /ssl/a.crt;
    ssl_certificate_key   /ssl/a.key;

    ssl on;
    ssl_session_cache  builtin:1000  shared:SSL:10m;
    ssl_protocols  TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4;
    ssl_prefer_server_ciphers on;

    access_log            /var/log/nginx/a.log;

    location / {

        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_set_header        X-Forwarded-Proto $scheme;

        proxy_pass          http://localhost:6062;//..
        proxy_read_timeout  90;
    }
}


> 不同server内容差不多
> service nginx restart 即可

你可能感兴趣的:(nginx配置多个二级子域名)