背景 会社のサブプロジェクトが増えるにつれて、さまざまなサイズのプロジェクトが10個以上になります(バックエンドのみ)。 元の慣例によると、開始されたプロジェクトごとに、対応するプロジェクトにマッピングされた第2レベルのドメイン名が必要です。 プロジェクトが10個あるということは、第2レベルのドメイン名が10個あることを意味します(テスト環境、サブプロダクション環境などは含みません)。 ドメイン名の数が多いと、管理が難しいだけでなく、さらに重要なことに、リソースの無駄になります。 この問題は長い間私を悩ませてきました。 今日、ついに解決しました。 ピットダイアリーを記録したいと思います。 この記事では、nginxの各命令の原理を説明するのではなく、実際のプロジェクト構成を使用して、nginx命令の使用方法を実践し、そこから学びます。 準備 ドメイン名 ドメイン名が http://www.dev.com であると仮定します。 実験環境 Alibaba Cloud ECS + CentOS + Nginx + PHP-FPM プロジェクト 1 1. プロジェクト パス: /data/wwwroot/project1/ プロジェクト2 1. プロジェクト パス: /data/wwwroot/project2/ プロジェクト3 1. プロジェクト パス: /data/wwwroot/project3/ 関連する知識ポイント
実装手順 上記のアクセス形式を実現するには、nginxのlocationディレクティブとaliasディレクティブを使用する必要があります。設定は次のとおりです。 場所 ^~ /${PROJECT}/ { エイリアス {$PATH}; try_files $uri $uri/ @${PROJECT}; 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } } 場所 @${PROJECT}{ /${PROJECT}/(.*)$ /${PROJECT}/index.php?/$1 を最後に書き換えます。 } 注: 上記の設定の ${PROJECT} と {$PATH} は、実際のプロセスで置き換える必要がある部分です。${PROJECT} は、project1 など、アクセスする必要がある URL のパス部分であり、{$PATH} は /data/wwwroot/project1 など、プロジェクトの実際のアクセス パスを表します。http://www.dev.com/project1 を例にとると、対応する Nginx 設定は次のようになります。 場所 ^~ /project1/ { エイリアス /data/wwwroot/project1/public; try_files $uri $uri/ @project1; 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } } 場所 @project1{ /project1/(.*)$ /project1/index.php?/$1 を最後に書き換えます。 } project2とproject3の設定は、上記の設定テンプレートに従うだけで済みます。完全なnginx設定は次のとおりです。 サーバー{ 聞く 80; サーバー名 http://www.dev.com; access_log /data/wwwlogs/nginx/access_log/www.dev.com_nginx.log を結合します。 error_log /data/wwwlogs/nginx/error_log/www.dev.com_errr_log; インデックス index.html index.htm index.php; # プロジェクト1の設定場所 ^~ /project1/ { エイリアス /data/wwwroot/project1/public; try_files $uri $uri/ @project1; 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } } 場所 @project1{ /project1/(.*)$ /project1/index.php?/$1 を最後に書き換えます。 } # プロジェクト2の設定場所 ^~ /project2/ { エイリアス /data/wwwroot/project2/public; try_files $uri $uri/ @project2; 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } } 場所 @project2{ /project2/(.*)$ /project2/index.php?/$1 を最後に書き換えます。 } # プロジェクト2の設定場所 ^~ /project3/ { エイリアス /data/wwwroot/project3/public; try_files $uri $uri/ @project3; 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } } 場所 @project3{ /project3/(.*)$ /project3/index.php?/$1 を最後に書き換えます。 } # すべての.phpを解析する 場所 ~ \.php$ { fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index インデックス.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; #fastcgi_param SCRIPT_FILENAME $request_filename; fastcgi_params を含めます。 } #画像とビデオへのリンク。これはキャッシュ用で、30 日間キャッシュされ、アクセス ログの場所は書き込まれません ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|mp4|ico)$ { 有効期限は30日です。 access_log オフ; } #js css ファイルの構成、ここにキャッシュがあります、7 日間キャッシュします、アクセス ログの場所を書き込まない ~ .*\.(js|css)?$ { 有効期限は7日です。 access_log オフ; } 場所 ~ /\.ht { すべてを否定する; } } 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Mysql テーブル、列、データベースの追加、削除、変更、クエリの問題の概要
>>: CentOS で MySQL 5.1 を 5.5.36 にアップグレードする
1. MySQLをインストールする # docker で mysql をダウンロード docker ...
序文CSS がフロントエンド開発の基本的なスキルであるならば、「セレクター」は基礎中の基礎です。これ...
MySQL データベースが Centos7 システムにインストールされており、オペレーティング シス...
この記事の例では、Bootstrap FileInputの具体的なコードを共有して、画像アップロード...
目次1. はじめに2. バックアップとリカバリの簡単な定義3. 復旧計画で考慮すべきいくつかの要素4...
インデックスの2つの主要なカテゴリ使用されるストレージエンジン: MySQL 5.7 InnoDBク...
最近、プロジェクトでは kubernetes (以下、k8s と表記、k と s の間には 8 つの...
目次1. 背景2. 検証プロセス3. 検証を作成する4. フロントエンドコード4.1 コアjsファイ...
目次序文QueryCache の概要クエリキャッシュ構成QueryCache の使用queryCac...
目次基本設定エントリファイル main.jsアプリ.vue表紙ヘッダー検索バー本体当プロジェクトでは...
もちろん、CSS はフレームワークを必要とするほど高度ではないと考えて、反対の意見を持つ人もたくさん...
ダウンロードMySQL 公式ダウンロード、Windows (x86、64 ビット)、ZIP アーカイ...
ウェブ全体を検索して、さまざまな落とし穴を見つけましたが、問題は解決しませんでした。ついに自分でも分...
この記事の例では、コンピュータカメラを呼び出して写真機能を実現するためのvueの具体的なコードを参考...
個人的には、WeChat アプレットの開発フレームワークは VUE と概ね似ていると感じていますが、...