背景 会社のサブプロジェクトが増えるにつれて、さまざまなサイズのプロジェクトが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. どのように構築しますか? es5 でクラスを構築する一般的な方法を確認しましょう。まず、es5...
私は SQL の初心者で、オープンソースのインストールは非常に簡単だと思っていましたが、その過程でい...
現在の日付 + 時刻 (日付 + 時刻) を取得する関数: now() mysql> now(...
オリジナルリンクhttps://github.com/XboxYan/no…ボタンは、おそらく We...
Zabbix独自のWEBインターフェースを例に、Web監視の設定を行います。環境: zabbix4....
Apache では構成ファイルで Web ページまたは Web サイトの書き換えを簡単に設定できる...
目次複数の変数を同時に宣言する場合は、1 行に短縮できます。分割代入は複数の変数に同時に値を割り当て...
目次チュートリアルシリーズ1. MySQL の紹介2. MySQLの開発履歴3. MariaDBの基...
この記事では、MySQL 8.0.16圧縮パッケージのインストールと設定方法を参考までに紹介します。...
具体的な方法: (推奨チュートリアル:MySQLデータベース学習チュートリアル)テーブルロックの状態...
目次遅延読み込みCSS スタイル: HTML部分:スクリプト部分:要約する遅延読み込み名前の通り、私...
2つのケース: 1. 索引あり 2. 索引なし前提条件:方法: コマンドラインを使用してシミュレー...
序文MySQL に精通している読者は、MySQL が非常に迅速に更新されることに気付くかもしれません...
最近、CSS3に関する知識や記事をたくさん読んできましたが、CSS3はとても便利に使えると思います。...
5月の最も重要なインタラクティブデザイン記事!今年、Baiduのデザイナーは体験の観点から出発し、大...