国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

nginx實現一個域名配置多個laravel項目

wums / 1309人閱讀

摘要:背景隨著公司的子項目越來越多,會有大大小小十幾個工程僅后端,按照原先的做法,每上線一個項目,那么必須要有一個二級域名映射到對應的工程上,十個工程那么就意味著需要有十個二級域名還不包含測試環境,次生產環境等,如此多的域名不僅僅是難于管理,更重

背景

隨著公司的子項目越來越多,會有大大小小十幾個工程(僅后端),按照原先的做法,每上線一個項目,那么必須要有一個二級域名映射到對應的工程上,十個工程那么就意味著需要有十個二級域名(還不包含測試環境,次生產環境等),如此多的域名不僅僅是難于管理,更重要的是比較浪費資源,這個問題困擾了我很久,今天終于解決了這個問題,特此記錄一下采坑日記,本文不會講nginx中各個指令的原理,而是用實際的項目配置來練習nginx指令的用法并舉一反三。

事先準備 域名

假設域名為:http://www.dev.com

實驗環境

阿里云ECS + centos + Nginx + php-fpm

項目1

1.工程路徑: /data/wwwroot/project1/
2.訪問路徑:http://www.dev.com/project1/

項目2

1.工程路徑: /data/wwwroot/project2/
2.訪問路徑:http://www.dev.com/project2/

項目3

1.工程路徑: /data/wwwroot/project3/
2.訪問路徑:http://www.dev.com/project3/

涉及的知識點

Nginx的location指令,用法可以參考:https://www.cnblogs.com/coder...

Nginx的alias指令,用法可以參考:https://www.jianshu.com/p/4be...

實現步驟

為了實現以上的訪問形式,我們需要用到nginx里面的location指令和alias指令,配置如下

location ^~ /${PROJECT}/ {
    alias  {$PATH};
    try_files $uri $uri/ @${PROJECT};

    location ~ .php$ {
            fastcgi_pass unix:/dev/shm/php-cgi.sock;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $request_filename;
            include fastcgi_params;
    }
}

location @${PROJECT}{
    rewrite /${PROJECT}/(.*)$ /${PROJECT}/index.php?/$1 last;
}

說明: 上面的這個配置中的${PROJECT}和{$PATH}都是屬于在實際過程中需要替換的部分,其中${PROJECT}為url需要訪問的path部分,如project1,{$PATH}則代表的是項目的真實訪問路徑,如/data/wwwroot/project1,以http://www.dev.com/project1 訪問為例,那么對應的Nginx的配置是這樣子的

location ^~ /project1/ {
    alias  /data/wwwroot/project1/public;
    try_files $uri $uri/ @project1;

    location ~ .php$ {
            fastcgi_pass unix:/dev/shm/php-cgi.sock;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $request_filename;
            include fastcgi_params;
    }
}

location @project1{
    rewrite /project1/(.*)$ /project1/index.php?/$1 last;
}

對于project2和project3的配置只需要按照上面的配置模板依葫蘆畫瓢就可以了,最后完整nginx配置如下

server {
    listen 80;
    server_name www.dev.com;
    access_log /data/wwwlogs/nginx/access_log/www.dev.com_nginx.log combined;
    error_log /data/wwwlogs/nginx/error_log/www.dev.com_errr_log;
    index index.html index.htm index.php;

    # project1開始的配置
    location ^~ /project1/ {
        alias  /data/wwwroot/project1/public;
        try_files $uri $uri/ @project1;
        location ~ .php$ {
                fastcgi_pass unix:/dev/shm/php-cgi.sock;
                fastcgi_index index.php;
                fastcgi_param SCRIPT_FILENAME $request_filename;
                include fastcgi_params;
        }
    }
    
    location @project1{
        rewrite /project1/(.*)$ /project1/index.php?/$1 last;
    }
    
    # project2開始的配置
    location ^~ /project2/ {
        alias  /data/wwwroot/project2/public;
        try_files $uri $uri/ @project2;
    
        location ~ .php$ {
                fastcgi_pass unix:/dev/shm/php-cgi.sock;
                fastcgi_index index.php;
                fastcgi_param SCRIPT_FILENAME $request_filename;
                include fastcgi_params;
        }
    }
    
    location @project2{
        rewrite /project2/(.*)$ /project2/index.php?/$1 last;
    }
    
    # project2開始的配置
    location ^~ /project3/ {
        alias  /data/wwwroot/project3/public;
        try_files $uri $uri/ @project3;
    
        location ~ .php$ {
                fastcgi_pass unix:/dev/shm/php-cgi.sock;
                fastcgi_index index.php;
                fastcgi_param SCRIPT_FILENAME $request_filename;
                include fastcgi_params;
        }
    }
    
    location @project3{
        rewrite /project3/(.*)$ /project3/index.php?/$1 last;
    }
    
    
    # 解析所有的.php
    location ~ .php$ {
        fastcgi_pass unix:/dev/shm/php-cgi.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        #fastcgi_param SCRIPT_FILENAME $request_filename;
        include fastcgi_params;
    }
   
    #圖片、視頻的的鏈接,此處是做緩存 ,緩存30天,不寫入訪問日志
    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|flv|mp4|ico)$ {
        expires 30d;
        access_log off;
    }
       
       #js css文件的配置,此處是做緩存 ,緩存7天,不寫入訪問日志
    location ~ .*.(js|css)?$ {
        expires 7d;
        access_log off;
    }

    location ~ /.ht {
        deny all;
    }
}
參考地址

怎么在 localhost 下訪問多個 Laravel 項目

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29946.html

相關文章

  • nginx實現一個域名配置多個laravel項目

    摘要:背景隨著公司的子項目越來越多,會有大大小小十幾個工程僅后端,按照原先的做法,每上線一個項目,那么必須要有一個二級域名映射到對應的工程上,十個工程那么就意味著需要有十個二級域名還不包含測試環境,次生產環境等,如此多的域名不僅僅是難于管理,更重 背景 隨著公司的子項目越來越多,會有大大小小十幾個工程(僅后端),按照原先的做法,每上線一個項目,那么必須要有一個二級域名映射到對應的工程上,十個...

    CarlBenjamin 評論0 收藏0
  • 在 Docker 中運行 Laravel 項目

    摘要:本篇承接使用構建環境,介紹如何在該文所用的容器中運行項目。接下來可以新建一個項目或是通過轉移項目。從上同步項目一般服務器中運行的項目都是在本地開發完成后同步上去的。生成文件文件含有項目所需的配置以及用于加密解密的隨機字符串。 本篇承接 使用 Docker 構建 LNMP 環境,介紹如何在該文所用的容器中運行 Laravel 項目。主要步驟為:轉移 Laravel 項目到數據卷 => 配...

    luxixing 評論0 收藏0
  • laravel學習之nginx配置站點

    摘要:前言設置項目的域名站點的時候,需要對做一些對應的重寫配置,用來做相關路由,否則會報。 前言 設置laravel項目的域名站點的時候,需要對nginx做一些對應的重寫rewrite配置,用來做相關路由,否則會報404。 nginx.conf配置 server { listen 80; server_name xxx.com; #域名 root /data/www...

    frank_fun 評論0 收藏0
  • laravel學習之nginx配置站點

    摘要:前言設置項目的域名站點的時候,需要對做一些對應的重寫配置,用來做相關路由,否則會報。 前言 設置laravel項目的域名站點的時候,需要對nginx做一些對應的重寫rewrite配置,用來做相關路由,否則會報404。 nginx.conf配置 server { listen 80; server_name xxx.com; #域名 root /data/www...

    Jaden 評論0 收藏0
  • 基礎版服務器部署Laravel項目

    摘要:解密服務器文件,再次進入網站,找到首頁中的,輸入密碼,生成解密后的服務器修改配置文件,打開配置的,修改其,執行測試配置文件是否修改修改配置文件,打開配置的,加入一行使其訪問端口時直接重定向到。 showImg(https://segmentfault.com/img/remote/1460000009562820?w=729&h=351); 說明 部署Laravel項目 從現在開始 ...

    shiguibiao 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<