• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    nginx实现一个域名配置多个laravel项目的方法示例

    背景

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

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

    上一篇:如何用Nginx解决前端跨域问题
    下一篇:nginx配置location方法总结
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    nginx实现一个域名配置多个laravel项目的方法示例 nginx,实现,一个,域名,配置,