サーバーに複数のサイトを展開するには、異なるサイトにアクセスするために複数のポートを開く必要があります。プロセスは非常に簡単です。デバッグには 2 時間かかりました。記録は次のとおりです。 メインドメイン名マルチポートアクセス DNSネームサーバーにAレコードを設定する www.xxx.comをサーバーのIPにポイントします 必要なポートを開き、nginx設定ファイルを変更します たとえば、ポート 80 とポート 8080 でそれぞれ 2 つのサービスが開かれているとします。 iptable がある場合は、まずポートを開きます。 iptables -A 入力 -ptcp --dport 80 -j 受け入れる iptables -A 入力 -ptcp --dport 8080 -j 受け入れる 設定ファイルを変更します。 #パス: /usr/local/nginx/conf/nginx.conf サーバー{ 聞く 80; サーバー名 www.xxx.com; access_log /data/www/log/33.33.33.33_nginx.log を結合します。 インデックス index.html index.htm index.php; /usr/local/nginx/conf/rewrite/none.conf を含めます。 ルート /data/www/website/33.33.33.33:80; 場所 ~ [^/]\.php(/|$) { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi.conf をインクルードします。 } 場所 ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ { 有効期限は30日です。 access_log オフ; } 場所 ~ .*\.(js|css)?$ { 有効期限は7日です。 access_log オフ; } } サーバー{ 8080を聴く; サーバー名 A.xxx.com; access_log /data/www/log/33.33.33.33:8080_nginx.log を結合しました。 インデックス index.html index.htm index.php; /usr/local/nginx/conf/rewrite/none.conf を含めます。 ルート /data/www/website/33.33.33.33:8080; 場所 ~ [^/]\.php(/|$) { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi.conf をインクルードします。 } 場所 ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ { 有効期限は30日です。 access_log オフ; } 場所 ~ .*\.(js|css)?$ { 有効期限は7日です。 access_log オフ; } } 鍵となるのは2つのサーバーセクションです。この2つのセクションを2つの構成ファイルに分割して、 nginx.conf は、 ディレクトリの下; サブドメインマルチポートアクセス この種のアクセスは無意味です。ポート 8080 へのアクセスは http://xxx.com:8080 の形式である必要があるためです。 また、2 つの異なる cgi がある場合、たとえば、ポート 80 は PHP Web サービスに対応し、ポート 8080 は nodejs Web サービスに対応します。nodejs には、すでにポート 8080 でリッスンしている Web サービスが付属している場合は、どうすればよいでしょうか。 この時点で、Nginxのリバースプロキシ機能が必要となり、DNSサーバーにAレコードを追加して最終的に実現します。
Aレコードを追加する A.xxx.comをサーバーのIPにポイントする Nginx 構成テンプレートは次のとおりです。 #パス: /usr/local/nginx/conf/nginx.conf サーバー{ 聞く 80; サーバー名 www.xxx.com; access_log /data/www/log/33.33.33.33_nginx.log を結合します。 インデックス index.html index.htm index.php; /usr/local/nginx/conf/rewrite/none.conf を含めます。 ルート /data/www/website/33.33.33.33:80; 場所 ~ [^/]\.php(/|$) { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi.conf をインクルードします。 } 場所 ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ { 有効期限は30日です。 access_log オフ; } 場所 ~ .*\.(js|css)?$ { 有効期限は7日です。 access_log オフ; } } サーバー{ 聞く 80; 聞く [::]:80; サーバー名 A.XXX.com; proxy_connect_timeout 300秒; proxy_send_timeout 300秒; proxy_read_timeout 300秒; fastcgi_send_timeout 300秒; fastcgi_read_timeout 300秒; 位置 / { プロキシパス http://127.0.0.1:3000; プロキシ_http_バージョン 1.1; proxy_set_header アップグレード $http_upgrade; proxy_set_header 接続 'アップグレード'; proxy_set_header ホスト $host; proxy_cache_bypass $http_upgrade; try_files $uri $uri/ =404; } } nginxは設定ファイルを再読み込みします nginx -s リロード 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: React リストバーとショッピングカートコンポーネントの使用の詳細な説明
>>: MySQLデータベースの追加、削除、変更操作の詳細な説明
トランザクション分離レベルを確認するMySQL では、'%tx_isolation%'...
出典: http://www.ruoyi.vip/ 'vue' から Vue をイン...
HTMLはヘッドとボディの2つの部分で構成されています** ヘッド内のタグはヘッドタグです** タイ...
フレーム:スタイル=”border-style:solid;border-width:5px;bor...
目次1. ブロックスコープとは何ですか? 2. ブロックスコープが必要なのはなぜですか? 3. 関数...
ステップ1: Ubuntuソースを追加するルートに切り替える suルートソフトウェアソースファイルの...
背景現在、会社のプロジェクトは、フロントエンドとバックエンドが分離された方法で開発されています。新し...
1. ホット デプロイメント: コンテナの実行中にプロジェクト全体を再デプロイすることを意味します。...
パッシブチェックパッシブ ヘルス チェックでは、NGINX と NGINX Plus はイベントの発...
目次背景仮想ファイルのインポート例書類タイプスクリプトのサポート要約する背景新しいプロジェクトで v...
MySQLは独立した書き込み分離を設定します。コードに次のものを書くと問題が発生する可能性があります...
EXPLAIN ステートメントは、MySQL がステートメントを実行する方法に関する情報を提供します...
目次最初のステップのインストールステップ2: MySQLデータを準備する3 番目のステップは、bin...
序文かつて、難しい問題に遭遇しました。タワークレーンからスイングハウスを落下させる必要がありましたが...
ボリュームデータボリュームは Docker の重要な概念です。データ ボリュームは、1 つ以上のコン...