Score:0

โดเมนย่อยตัวแทนของ Nginx

ธง cn

ฉันได้ตั้งค่าไฟล์กำหนดค่า nginx เป็น:

เซิร์ฟเวอร์ {
   server_name example.com www.example.com;
   ฟัง 80;
   
   ที่ตั้ง = / {
     .....
  }
}

เซิร์ฟเวอร์ {
  server_name *.example.com;
  ฟัง 80;
  ที่ตั้ง = / {
      proxy_pass ...
  }
}

เรียกดูผ่าน example.com และ www.example.com ไม่เป็นไร แต่เมื่อฉันใช้โดเมนย่อย เช่น a.example.com หรือ b.example.com ฉันได้รับข้อความเช่น "301 ถูกย้ายอย่างถาวร" และระบบเปลี่ยนเส้นทางกลับไปที่ example.com

นี่คือไฟล์จริง

nginx: ไฟล์การกำหนดค่า /etc/nginx/nginx.conf ไวยากรณ์ใช้ได้
nginx: การทดสอบไฟล์การกำหนดค่า /etc/nginx/nginx.conf สำเร็จ
# ไฟล์กำหนดค่า /etc/nginx/nginx.conf:
ผู้ใช้ www-data;
worker_processes อัตโนมัติ
pid /run/nginx.pid;
รวม /etc/nginx/modules-enabled/*.conf;

เหตุการณ์ {
    worker_connections 768;
    # multi_accept บน;
}

http {

    ##
    # การตั้งค่าพื้นฐาน
    ##

    ส่งไฟล์บน;
    tcp_nopush บน;
    tcp_nodelay บน;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    # ปิด server_tokens;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect ปิด;
     client_max_body_size 50M;
    รวม /etc/nginx/mime.types;
    แอปพลิเคชัน default_type/octet-stream;

    ##
    # การตั้งค่า SSL
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # วาง SSLv3 อ้างอิง: พุดเดิ้ล
    เปิด ssl_prefer_server_ciphers;

    ##
    # การตั้งค่าการบันทึก
    ##

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # การตั้งค่า Gzip
    ##

    เปิด gzip;

    # gzip_vary บน;
    # gzip_proxyed ใด ๆ ;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types ข้อความ/ข้อความล้วน/แอปพลิเคชัน css/แอปพลิเคชัน json/ข้อความจาวาสคริปต์/แอปพลิเคชัน xml/แอปพลิเคชัน xml/xml+rss ข้อความ/จาวาสคริปต์;

    ##
    # การกำหนดค่าโฮสต์เสมือน
    ##

    รวม /etc/nginx/conf.d/*.conf;
    รวม /etc/nginx/sites-enabled/*;
}


#จดหมาย {
# # ดูตัวอย่างสคริปต์การตรวจสอบได้ที่:
# # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
# 
# # auth_http localhost/auth.php;
# # pop3_capabilities "TOP" "ผู้ใช้";
# # imap_capabilities "IMAP4rev1" "UIDPLUS";
# 
# เซิร์ฟเวอร์ {
# ฟัง localhost:110;
#โปรโตคอลpop3;
# เปิดพร็อกซี;
# }
# 
# เซิร์ฟเวอร์ {
# ฟัง localhost:143;
# โปรโตคอล imap;
# เปิดพร็อกซี;
# }
#}

# ไฟล์กำหนดค่า /etc/nginx/modules-enabled/50-mod-http-image-filter.conf:
load_module โมดูล/ngx_http_image_filter_module.so;

# ไฟล์กำหนดค่า /etc/nginx/modules-enabled/50-mod-http-xslt-filter.conf:
load_module โมดูล/ngx_http_xslt_filter_module.so;

# ไฟล์กำหนดค่า /etc/nginx/modules-enabled/50-mod-mail.conf:
load_module โมดูล/ngx_mail_module.so;

# ไฟล์การกำหนดค่า /etc/nginx/modules-enabled/50-mod-stream.conf:
load_module โมดูล/ngx_stream_module.so;

# ไฟล์กำหนดค่า /etc/nginx/mime.types:

ประเภท {
    ข้อความ/html html htm shtml;
    ข้อความ/css css;
    ข้อความ/xml xml;
    รูปภาพ/gif gif;
    รูปภาพ/jpeg jpeg jpg;
    แอปพลิเคชัน/จาวาสคริปต์ js;
    แอ็พพลิเคชัน/atom+xml อะตอม;
    แอปพลิเคชัน/rss+xml rss;

    ข้อความ/mathml mml;
    ข้อความ/ธรรมดา txt;
    text/vnd.sun.j2me.app-descriptor jad;
    ข้อความ/vnd.wap.wml wml;
    ข้อความ/x-คอมโพเนนต์ htc;

    รูปภาพ/png png;
    รูปภาพ/tiff tif tiff;
    ภาพ/vnd.wap.wbmp wbmp;
    ไอคอนรูปภาพ/x-icon;
    ภาพ/x-jng jng;
    ภาพ/x-ms-bmp bmp;
    ภาพ/svg+xml svg svgz;
    รูปภาพ/เว็บเพจ เว็บเพจ;

    แอปพลิเคชัน/ฟอนต์-woff woff;
    แอปพลิเคชัน / java-archive jar war ear;
    แอปพลิเคชัน/json json;
    แอปพลิเคชัน/mac-binhex40 hqx;
    เอกสารแอปพลิเคชัน/msword;
    ใบสมัคร/pdf pdf;
    ใบสมัคร/postscript ps eps ai;
    แอปพลิเคชัน/rtf rtf;
    แอปพลิเคชัน/vnd.apple.mpegurl m3u8;
    แอปพลิเคชัน/vnd.ms-excel xls;
    application/vnd.ms-fontobject eot;
    แอปพลิเคชัน/vnd.ms-powerpoint ppt;
    แอปพลิเคชัน/vnd.wap.wmlc wmlc;
    application/vnd.google-earth.kml+xml kml;
    แอปพลิเคชัน/vnd.google-earth.kmz kmz;
    แอปพลิเคชัน/x-7z-บีบอัด 7z;
    ใบสมัคร/x-cocoa cco;
    แอปพลิเคชัน/x-java-archive-diff jardiff;
    แอปพลิเคชัน/x-java-jnlp-file jnlp;
    เรียกใช้แอปพลิเคชัน / x-makeself;
    แอปพลิเคชัน/x-perl pl pm;
    แอปพลิเคชัน/x-pilot prc pdb;
    แอปพลิเคชั่น/x-rar-บีบอัด rar;
    แอปพลิเคชั่น / x-redhat-package-manager รอบต่อนาที;
    ใบสมัคร / ทะเล x-sea;
    แอปพลิเคชั่น/x-shockwave-แฟลช swf;
    แอปพลิเคชั่น / นั่ง x-stuffit;
    ใบสมัคร/x-tcl tcl tk;
    ใบสมัคร/x-x509-ca-cert จาก pem crt;
    แอปพลิเคชัน/x-xpinstall xpi;
    แอปพลิเคชัน/xhtml+xml xhtml;
    แอปพลิเคชัน/xspf+xml xspf;
    แอปพลิเคชั่น / ซิปซิป;

    แอปพลิเคชัน / octet-stream bin exe dll;
    แอ็พพลิเคชัน/octet-stream deb;
    แอปพลิเคชัน/octet-stream dmg;
    แอปพลิเคชั่น/octet-stream iso img;
    แอปพลิเคชัน/ออคเต็ตสตรีม msi msp msm;

    แอปพลิเคชัน/vnd.openxmlformats-officedocument.wordprocessingml.document docx;
    แอปพลิเคชัน/vnd.openxmlformats-officedocument.spreadsheetml.sheet xlsx;
    แอปพลิเคชัน/vnd.openxmlformats-officedocument.presentationml.การนำเสนอ pptx;

    เสียง/midi กลาง midi kar;
    เสียง/mpeg mp3;
    เสียง/ogg ogg;
    เสียง/x-m4a m4a;
    เสียง/x-realaudio ra;

    วิดีโอ/3gpp 3gpp 3gp;
    วิดีโอ/mp2t ts;
    วิดีโอ/mp4 mp4;
    วิดีโอ/mpeg mpeg mpg;
    วิดีโอ/quicktime mov;
    วิดีโอ/เว็บเอ็ม เว็บเอ็ม;
    วิดีโอ/x-flv flv;
    วิดีโอ/x-m4v m4v;
    วิดีโอ/x-mng mng;
    วิดีโอ/x-ms-asf asx asf;
    วิดีโอ/x-ms-wmv wmv;
    วิดีโอ/x-msvideo avi;
}

# ไฟล์กำหนดค่า /etc/nginx/sites-enabled/default.old:
ssl_certificate /etc/letsencrypt/live/billspree.work/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/billspree.work/privkey.pem;


เซิร์ฟเวอร์ {
        ฟัง 80;
        ฟัง [::]:80;
        รูท /var/www/html/billspree.work;
        ดัชนี index.php index.html index.htm index.nginx-debian.html testing.html;
        server_name billspree.work www.billspree.work;

        ที่ตั้ง = / {
                try_files $uri $uri/ /index.php?args;
        }

        ตำแหน่ง ~ \.php$ {
                รวมตัวอย่าง/fastcgi-php.conf;
                fastcgi_pass ยูนิกซ์:/run/php/php7.4-fpm.sock;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        }


        ที่ตั้ง ^~ /ผู้เช่า {
                proxy_pass http://localhost:9003;
               # proxy_http_version 1.1;
               # proxy_set_header อัพเกรด $http_upgrade;
               # proxy_set_header การเชื่อมต่อ 'อัปเกรด';
               # proxy_set_header โฮสต์ $host;
               # proxy_cache_bypass $http_upgrade;
        }


        ที่ตั้ง ^~ /ผู้เช่า/พอร์ทัล {
                proxy_pass http://localhost:7172/prod/tenant/portal;
                # proxy_http_version 1.1;
                # proxy_set_header อัพเกรด $http_upgrade;
                # proxy_set_header การเชื่อมต่อ 'อัปเกรด';
                #proxy_set_header โฮสต์ $host;
                #proxy_cache_bypass $http_upgrade;
        }


        #ปฏิเสธการเข้าถึงไฟล์ .htaccess ถ้าเอกสารของ Apache เป็นรูท
        #เห็นด้วยกับของ nginx

        ตำแหน่ง ~ /\.ht {
                ปฏิเสธทั้งหมด
        }

    ฟัง [::]:443 ssl ipv6only=เปิด; # จัดการโดย Certbot
    ฟัง 443 ssl; # จัดการโดย Certbot
   # ssl_certificate /etc/letsencrypt/live/billspree.work/fullchain.pem; # จัดการโดย Certbot
   # ssl_certificate_key /etc/letsencrypt/live/billspree.work/privkey.pem; # จัดการโดย Certbot
   # รวม /etc/letsencrypt/options-ssl-nginx.conf; # จัดการโดย Certbot
   # ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # จัดการโดย Certbot
# ส่งคืน 301 https://www.billspree.com$request_uri;  


}

เซิร์ฟเวอร์ {
    ฟัง [::]:80 ssl ipv6only=เปิด;
    ฟัง 80 ssl;
    server_name *.billspree.work;

    สถานที่ = / พอร์ทัล {
        proxy_pass http://localhost:7172/portal;
    }
}

# ทดสอบการกำหนดค่าเซิร์ฟเวอร์ด้วยพอร์ต 1027
เซิร์ฟเวอร์ {

    server_name *.billspree.work;
    ฟัง [::]:1027 ssl ipv6only=เปิด; # จัดการโดย Certbot
    ฟัง 1027 ssl; # จัดการโดย Certbot

    ssl_certificate /etc/letsencrypt/live/billspree.work/fullchain.pem; # $
    ssl_certificate_key /etc/letsencrypt/live/billspree.work/privkey.pem;
 # รวม /etc/letsencrypt/options-ssl-nginx.conf; # จัดการโดย Certbot
  # ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # จัดการโดย Certbot

ที่ตั้ง ^~ / {
        proxy_pass http://localhost:9001;
        proxy_http_version 1.1;
        proxy_set_header อัพเกรด $http_upgrade;
        proxy_set_header การเชื่อมต่อ 'อัปเกรด';
        proxy_set_header โฮสต์ $host;
        proxy_cache_bypass $http_upgrade;
    }
}

#เซิร์ฟเวอร์ {
# ถ้า ($host = billspree.work) {
# ส่งคืน 301 https://www.$host$request_uri;
# } # จัดการโดย Certbot
# ถ้า ($host = www.billspree.work) {
# ส่งคืน 301 https://$host$request_uri;
# } # จัดการโดย Certbot

# server_name www.billspree.work billspree.work#
# ฟัง [::]:80 ipv6only=เปิด;
# ฟัง 80;
#}

# ไฟล์การกำหนดค่า /etc/nginx/snippets/fastcgi-php.conf:
# regex เพื่อแบ่ง $uri เป็น $fastcgi_script_name และ $fastcgi_path
fastcgi_split_path_info ^(.+?\.php)(/.*)$;

# ตรวจสอบว่ามีสคริปต์ PHP อยู่ก่อนที่จะส่งต่อ
try_files $fastcgi_script_name =404;

# ข้ามความจริงที่ว่า try_files รีเซ็ต $fastcgi_path_info
# ดู: http://trac.nginx.org/nginx/ticket/321
ตั้ง $path_info $fastcgi_path_info;
fastcgi_param PATH_INFO $path_info;

fastcgi_index index.php;
รวมถึง fastcgi.conf;

# ไฟล์กำหนดค่า /etc/nginx/fastcgi.conf:

fastcgi_param SCRIPT_FILENAME $document_root$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 REQUEST_SCHEME โครงการ $;
fastcgi_param HTTPS $https if_not_empty;

fastcgi_param GATEWAY_INTERFACE CGI/1.1;
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;

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;

# PHP เท่านั้น จำเป็นหากสร้าง PHP ด้วย --enable-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;

jp flag
แสดงการกำหนดค่าทั้งหมดด้วย `nginx -T` นอกจากนี้ ตรวจสอบให้แน่ใจว่าระเบียน DNS ของ `a.example.com` และ `b.example.com` ชี้ไปที่เซิร์ฟเวอร์เดียวกันกับ `example.com` และ `www.example.com`
Al Malik Umair avatar
cn flag
ที่จริงแล้ว ไม่มีโดเมนย่อยใดทำงานในกรณีของฉัน แม้แต่ www.example.com มีเพียง example.com เท่านั้นที่ใช้งานได้
in flag
ไม่มีการกำหนดค่าการเปลี่ยนเส้นทางในการกำหนดค่า nginx ของคุณ การเปลี่ยนเส้นทางส่วนใหญ่อาจมาจากเซิร์ฟเวอร์ส่วนหลังของคุณ
Al Malik Umair avatar
cn flag
เรากำลังพูดถึงเซิร์ฟเวอร์ส่วนหลังใดที่นี่
in flag
อะไรก็ตามที่คุณมอบฉันทะให้กับคำขอของคุณ
Score:1
ธง us

การกำหนดค่าสำหรับ *.billspree.ทำงาน ไม่ถูกต้อง

ฟัง 80 ssl;

หมายความว่า nginx ได้รับการกำหนดค่าให้ใช้ TLS บนพอร์ต 80 ซึ่งไม่ใช่การกำหนดค่าที่ถูกต้อง

โพสต์คำตอบ

คนส่วนใหญ่ไม่เข้าใจว่าการถามคำถามมากมายจะปลดล็อกการเรียนรู้และปรับปรุงความสัมพันธ์ระหว่างบุคคล ตัวอย่างเช่น ในการศึกษาของ Alison แม้ว่าผู้คนจะจำได้อย่างแม่นยำว่ามีคำถามกี่ข้อที่ถูกถามในการสนทนา แต่พวกเขาไม่เข้าใจความเชื่อมโยงระหว่างคำถามและความชอบ จากการศึกษาทั้ง 4 เรื่องที่ผู้เข้าร่วมมีส่วนร่วมในการสนทนาด้วยตนเองหรืออ่านบันทึกการสนทนาของผู้อื่น ผู้คนมักไม่ตระหนักว่าการถามคำถามจะมีอิทธิพลหรือมีอิทธิพลต่อระดับมิตรภาพระหว่างผู้สนทนา