性能-其他解决方案,而不是NGINX的.htaccess

前端之家收集整理的这篇文章主要介绍了性能-其他解决方案,而不是NGINX的.htaccess 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在开发一个较大的基于Web的项目,在以后的某个阶段(或更多)可能每分钟必须处理数百个请求.

我从没与Nginx一起工作过,但是用apache阅读比较,看来我可能应该走Nginx的路线.读到它,我总是看到’.htaccess’文件是一个懒惰的解决方案.现在,我想避免依赖.htaccess文件,但是我的问题是如何?

我的意思是-如果.htaccess被认为是懒惰,棘手的解决方案,那么针对此问题的干净解决方案到底是什么:

>将所有特定的URL(除了CSS / Images和类似的东西)重定向到单个PHP文件(顺便说一句,如果像index.PHP这样的单个文件处理URL并包括所需的模板,是否会对性能产生影响?我应该避免这种情况,并拆分成几十个文件吗?)
>在CSS文件中读取PHP标签(“ AddHandler application / x-httpd-PHP .css …”)
>另一层登录(.htaccess身份验证,带有一个小的弹出窗口)

这基本上是我使用.htaccess的三件事.尤其是第一个,基本上使整个应用程序都能工作.

但是对于这个项目,我实际上是在尝试保持清洁和最新的解决方案.我有什么可能?我在哪里可以提高表现?我该如何解决上述3个问题,而无法使用.htaccess在Nginx上进行开发?

非常感谢您的时间和精力.

最佳答案
为了充分利用Nginx,您必须了解它不是Web服务器(例如Apache),而是代理.简单来说,它就像巨型规则引擎一样,可以根据请求的模式匹配将内容传递给其他应用程序.

因此,要使用Nginx运行PHP,您需要一个单独的运行PHP的服务器(或进程).可以是Apache,但PHP包含FastCGI Process Manager (FPM).

这是让您开始的基本样板:

server {
   listen 80;
   server_name www.example.com example.com;
   access_log /var/www/www.example.com/logs/access.log;
   error_log /var/www/www.example.com/logs/error.log;
   root /var/www/www.example.com/public_html;

   location / {
       index  index.html index.htm index.PHP;
       auth_basic            "Username required";
       auth_basic_user_file  /etc/Nginx/htpasswd;
   }

   location ~ (\.PHP|\.css)${
       try_files $uri =404;

       include /etc/Nginx/fastcgi_params;
       fastcgi_index index.PHP;
       fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
       fastcgi_pass PHP;
   } 
}

猜你在找的Nginx相关文章