博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php工作原理以及与lamp的关系
阅读量:5807 次
发布时间:2019-06-18

本文共 2971 字,大约阅读时间需要 9 分钟。

  hot3.png

php是引擎   Apache是web服务器

那么如何优化网站呢?其 实就是触发时间到生成相应的页面过程,这个时间差越小,用户体验越好,那么根绝上面几步,我们可以想到的优化方法就是:客户端提交的数据大小已经并发数量 ----- 都提交给apache服务器处理---apache分配给php引擎---php程序和读取数据库---输出

1:优化 客户端数据提交,不过当用户达到一定级别时候,这个数据还是很大的

2:优化 web服务器,主要是处理高并发的性能

3:优化php引擎程序:samrty模版的引擎很不错

4:优化php程序:主要是数据库读取的方面和php自身程序效率

5:数据库优化:数据库的配置以及优化方式,达到与php读取效率的最完美匹配

6:输出优化:使用js等技术 ajax技术

php,apache和mysql组合的工作过程:

PHP的所有应用程序都是通过WEB服务器(如IIS或Apache)和PHP引擎程序解释执行完成的,工作过程:

(1)当用户在浏览器地址中输入要访问的PHP页面文件名,然后回车就会触发这个PHP请求,并将请求传送化支持PHP的WEB服务器。
(2)WEB服务器接受这个请求,并根据其后缀进行判断如果是一个PHP请求,WEB服务器从硬盘或内存中取出用户要访问的PHP应用程序,并将其发送给PHP引擎程序。
(3)PHP引擎程序将会对WEB服务器传送过来的文件从头到尾进行扫描并根据命令从后台读取,处理数据,并动态地生成相应的HTML页面。
(4)PHP引擎将生成HTML页面返回给WEB服务器。WEB服务器再将HTML页面返回给客户端浏览器。

简言之:apache是WEB服务器,它可以解析php语言。

Apache的工作原理:

Web系统是客户端/服务器式的,所以应该有服务器程序和客户端程序两部分。常用的服务器程序是Apache;常用的客户端程序是浏览器(如IE、 Netscape、Mozilla)。我们可以在浏览器的地址栏内输入统一资源定位地址(URL)来访问Web页面。Web最基本的概念是超文本 (Hypertext)。它使得文本不再是传统的书页式文本,而是可以在阅读过程中从一个页面位置跳转到另一个页面位置。用来书写Web页面的语言称为超 文本标记语言,即HTML。WWW服务遵从HTTP协议,默认的TCP/IP端口是80,客户端与服务器的通信过程简述如下:
(1)客户端(浏览器)和Web服务器建立TCP连接,连接建立以后,向Web服务器发出访问请求(如get)。根据HTTP协议,该请求中包含了客户端的IP地址、浏览器的类型和请求的URL等一系列信息。
(2)Web服务器收到请求后,将客户端要求的页面内容返回到客户端。如果出现错误,那么返回错误代码。

(3)断开与远端Web服务器的连接

 

php工作原理:

如下图所示:

                      

apache,php以及mysql的关系:

apache是web服务器,主要是请求和响应的功能,是一种软件,用于发布网站。在配置文件中可以设置文件根目录,处理的文件类型以及端口等。apache单独不能处理php代码。

php(php 应用程序服务器):不能单独存在的,需要以apache为依托。也可以说php是apache功能模块的一种扩展,php作为apache的外挂,用于解 析php代码。经过解析的动态网页此时就不存在<?php ?>了。当apache服务启动的同时也启动了php。也就是说php必须和apache安装在同一台服务器上,不可以分割。

mysql:一种开源的很流行的关系型数据库。与apache无关,只是在响应php代码中的sql操作的时候才被访问。不需要与apache安装在同一台服务器上,可以单独存在,只需php远程连接即可。

借用一篇文章来加深一下理解:此处注明出处  http://www.51testing.com/html/66/206966-806244.html

今天,在讨论环境问题的时候,突然脑子里面闪过一个问题,LAMP这样的结构,mysql可以独立于其它几个单独存在,然后通过一个$connect = mysql_connect("localhost" user_name  password)来进行跟DB之间的通信,那么我把apache和php能不能也分开独立部署在不同的机器上呢?

  于是,我带着这样的问题,查阅了下apache解析php的原理和php本身的运行原理。其中谈到,当apache在启动之后,动态的加载了一些模块,当 中如果需要处理php的请求,就有对应的mod_php5.so这个模块被动态加载,同时这个模块会做一个ap hook_config的动作,从而使得apache在启动起来之后,就通过hook技术,连带启动mod_php5.so这个模块的加载,接收客户端的 php请求。php请求发送到web server之 后,通过这个模块接收了php请求,那么对应的php文件在运行的时候,通过php内核将相应内容转发给zend 引擎,zend引擎在解析处理的时候,与php的扩展层进行相应的配合处理,最终在扩展层处理完成之后,递归的交还控制权,最后由web server将处理的结果返回给客户端的浏览器。
   那么,在这里最起码可以明确一个问题,如果在A,B两台机器上,B机器仅仅只安装PHP,那么B机器本身是没有办法将来自于客户端的PHP请求解析执行完 成用户需要的内容返回到客户端的浏览器的。道理我想大家都明白了,因为B机器如果连web server都没,根本就无法完成对用户端的请求的接收,那么无法接收到客户端的请求又何来处理呢?尽管这个问题很明显,但是我又有了另外一个疑惑,那么 我在A机器上安装好apache这样的web server,通过在A机器上loadModule对应的PHP集成处理模块mod_php5.so,那么由A机器来接受用户请求,对于PHP请求,由A 机器中的PHP处理模块将其转发给B机器(通过TCP协议建立连接,转发对应的数据)然后在B机器上完成业务逻辑的处理,在通过建立的连接回传处理完成的 数据,最终由A机器将整个页面内容回传给用户的浏览器端,这个可不可以呢?mod_php5.so能不能有这个实现呢?就是在A机器接收到请求后,它能完 成tcp到B机器把请求的参数内容传给这个php逻辑处理文件呢?
  有同事问我,为什么我会想这么做呢?我是这样想的,假设,这样的情况是可以的,那么我们是否可以在A机器上只安装apache,然后A机器主要用来处理客 户端的请求,接收和转发最多还有一个回传内容给浏览器,而更多的逻辑处理我们就可以放在另外的机器上去处理,比如这里的B机器。这样的话,我们就可以尽可 能多的利用A机器的资源来完成更多的请求的处理,从而提升整体的架构的性能处理能力呢?(这个有点类似与nginx的反向代理的意思)
  对于这个问题我还不能确定,打算研读下mod_php5.so的源文件来看看,是否能否确定这个问题?
  以上纯属个人的思考,总结,错误之处,遗漏之处难免,欢迎高人指点迷津,谢谢

转载于:https://my.oschina.net/daquan/blog/496991

你可能感兴趣的文章
考前的焦躁
查看>>
rsync算法原理
查看>>
关闭Jquery Ajax 缓存
查看>>
uva-317-找规律
查看>>
CMakeLists实战解读--YouCompleteMe
查看>>
shutdown用法详解
查看>>
Event事件的兼容性(转)
查看>>
数论 - 同余 + BFS (Find The Multiple)
查看>>
CQRS学习——一个例子(其六)
查看>>
Hadoop 学习资料集锦
查看>>
12.22 repeater 添加
查看>>
leetcode-74-搜索二维矩阵
查看>>
批处理类 RunBaseBatch
查看>>
Remote Desktop Issues
查看>>
IIS7内建账号,应用程序池
查看>>
之字形打印矩阵
查看>>
我的2014-相对奢侈的生活
查看>>
zoj 2412 dfs 求连通分量的个数
查看>>
NLP自然语言处理学习笔记一(环境准备)
查看>>
HDU-1407 测试你是否和LTC水平一样高
查看>>