nginx实现一个域名配置多个laravel项目

栏目: PHP · 发布时间: 5年前

内容简介:随着公司的子项目越来越多,会有大大小小十几个工程(仅后端),按照原先的做法,每上线一个项目,那么必须要有一个二级域名映射到对应的工程上,十个工程那么就意味着需要有十个二级域名(还不包含测试环境,次生产环境等),假设域名为:阿里云ECS + centos + Nginx + php-fpm

背景

随着公司的子项目越来越多,会有大大小小十几个工程(仅后端),按照原先的做法,每上线一个项目,那么必须要有一个二级域名映射到对应的工程上,十个工程那么就意味着需要有十个二级域名(还不包含测试环境,次生产环境等), 如此多的域名不仅仅是难于管理,更重要的是比较浪费资源 ,这个问题困扰了我很久,今天终于解决了这个问题,特此记录一下采坑日记,本文不会讲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/

涉及的知识点

  1. Nginx的location指令,用法可以参考: https://www.cnblogs.com/coder...
  2. 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 http://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 项目


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

无界面交互

无界面交互

[美]Golden Krishna / 杨名 / 人民邮电出版社 / 2017-1 / 49.00元

“真希望在硅谷工作的人们已经读过这本书了。”——Doug LeMoine,Cooper总经理 “这本书的写作看似随意,字里行间却透着一种辛辣、幽默的反叛精神,这种精神可以帮助我们走出当今交互设计的界面泥潭。当你心情低落时,不妨翻开这本书,读上几页,你会开始微笑,大笑,并从中学到很多东西。书中的文字有一股振奋人心的力量。”——Don Norman,加州大学圣迭戈分校设计实验室主任,《设计心理学......一起来看看 《无界面交互》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具