nginx で第 2 レベルのドメイン名を構成する方法

王林
リリース: 2023-05-27 17:37:29
転載
2057 人が閲覧しました

私の vps には次の 3 つのサービスがあります。

  1. WordPress によって構築されたブログ サービスは、ポート 8000 で実行され、http :/ 経由でアクセスされます。 /fangyuanxiaozhan.com:8000

  2. gogs によって構築された git サービス、ポート 10080 で実行、アクセス方法 http://fangyuanxiaozhan.com:10080

  3. nextcloud によって構築されたネットワーク ディスク サービスは、ポート 8080 で実行されます。アクセス方法は http://fangyuanxiaozhan.com:10080

私のニーズ:

  1. 1. ブログ サービスにアクセスする場合は、「http://fangyuanxiaozhan.com」と直接入力します。

  2. git サービスにアクセスする場合は、 http://git.fangyuanxiaozhan.com

  3. を直接入力してネットワーク ディスク サービスにアクセスし、http://cloud.fangyuanxiaozhan.com

  4. を直接入力します。
実装方法

1. ドメイン名をホストしている Web サイトにアクセスし、DNS 解決を追加します。私のドメイン名 fangyuanxiaozhan.com は Alibaba Cloud でホストされています。私の方法は https://dns にログインすることです.console.aliyun.com /#/dns/domainlist、セカンダリ レコードを追加します

nginx で第 2 レベルのドメイン名を構成する方法

2. centos7 を使用していますが、nginx 構成ファイルのデフォルトの場所は ## です。 #/etc/nginx/nginx .conf

、興味深いことに、 /etc/nginx/nginx.conf は構成フォルダー /etc/nginx/conf.d を導入しています。つまり、 ##/etc/nginx/nginx.conf 内のいくつかのデフォルト設定をコメントアウトして、複数の独立した設定ファイルを /etc/nginx/conf.d. フォルダーに直接設定できます。

nginx で第 2 レベルのドメイン名を構成する方法/etc/nginx/nginx.conf

設定

# for more information on configuration, see:
#  * official english documentation: http://nginx.org/en/docs/
#  * official russian documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# load dynamic modules. see /usr/share/nginx/readme.dynamic.
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;

}
ログイン後にコピー
上記の設定ファイルの最後の行 include に注目してください。 /etc/nginx/conf.d/*.conf;

は、

/etc/nginx/conf.d/ の下で、.conf で終わるすべての設定ファイルがメイン設定ファイルに含まれるようにします。 nginx .conf が導入され、有効になります/etc/nginx/conf.d/

# の下に 3 つの新しいファイルを作成する必要があります

# #blog.conf (第 2 レベルのドメイン名を使用せずに、ポート 8000 をポート 80 にマッピングします)

server { 
  listen 80;
  server_name fangyuanxiaozhan.com;

  location / {
    proxy_set_header  x-real-ip $remote_addr;
    proxy_set_header  host   $http_host;
    proxy_pass     http://0.0.0.0:8000;
  }
}
ログイン後にコピー
nginx で第 2 レベルのドメイン名を構成する方法blog.conf は、fangyuanxiaozhan.com:8000 を fangyuanxiaozhan.com にマッピングします。

git.conf (第 2 レベルのドメイン名

git

を使用してポート 10080 からポート 80 を実現)

server { 
  listen 80;
  server_name git.fangyuanxiaozhan.com;

  location / {
    proxy_set_header  x-real-ip $remote_addr;
    proxy_set_header  host   $http_host;
    proxy_pass     http://0.0.0.0:10080;
  }
}
ログイン後にコピー

git.conf は fangyuanxiaozhan.com:10080 のマッピングを実装します。 git.fangyuanxiaozhan.comnc.conf (第 2 レベルのドメイン名

cloud

を使用して、ポート 10080 をポート 80 にマッピングすることを実現します)

server { 
  listen 80;
  server_name cloud.fangyuanxiaozhan.com;

  location / {
    proxy_set_header  x-real-ip $remote_addr;
    proxy_set_header  host   $http_host;
    proxy_pass     http://0.0.0.0:8080;
  }
}
ログイン後にコピー

git.conf は次のように実現しますfangyuanxiaozhan.com:8080 をcloud.fangyuanxiaozhan.comにマッピング

nginxを再起動して設定を有効にします

#nginxを閉じる

sudo $(which nginx) -s stop
ログイン後にコピー
nginxを開く

sudo $(which nginx)
ログイン後にコピー

エフェクト表示

nginx で第 2 レベルのドメイン名を構成する方法

nginx で第 2 レベルのドメイン名を構成する方法

以上がnginx で第 2 レベルのドメイン名を構成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート