集中式:就是中间有个中央的服务器,然后所有的客户机都会把版本信息上传到中央服务器里面,也就是说版本信息只在中央服务器里面保存。当我们去上传或下载的时候,都是从中央服务器里面进行链接的。也就是说一旦中央服务器挂掉,客户机可能就没办法去上传或下载版本库的内容。而且客户机需要连接网络才能完成上传和下载。
相比之下对于分布式的版本控制器来说就方便的多了:没有中央服务器,一个版本控制下的所有客户机都拥有一套完整的版本库信息,这一点和集中式不太一样,因为集中式只在中央服务器里面存储版本库信息,所以对于分布式来说,容灾性更好,而且不用取连接网络
集中式代表CVS和SVN:
分布式代表git
需要总结git的简单命令
PHP的运行原理:
php解析器与webserver通信:
首先了解CGI的概念:本身早期的一些web server只能处理简单的html静态文件,随着技术的发展,出现了动态语言,php、python。如果要处理php的话,可以交给php解析器处理,但是php处理完,怎么和webserver来通信?这是一个问题,为了解决不同的语言处理与webserver之间的通讯,就出现了CGI协议,只要按照CGI去编写程序,就能够实现语言解析器与webserver的通信。比如PHPCGI程序,就是php解析器跟web server当中的一个协议桥梁。
FASTCGI的进程管理器:
CGI虽然解决了php解析器与web server之间的通讯问题,但是他的效率很低,因为web server每收到一个请求都会fork一个CGI进程,然后请求结束的时候再kill掉这个进程。这个时候如果有10w、100w的请求的话,就会fork 10w、100w个进程,然后再去kill掉。这样的话本身来说就非常浪费资源,所以此时FASTCGI就出现了,主要是以CGI的改良版本出现的,FASTCGI每次处理完请求以后,不会kill掉进程,而是保留这个进程,使这个进程可以一次处理多个请求。这样就不用每次都重新fork一个进程了,大大提升了处理效率
PHP-FPM:
php-fpm叫:php fastcgi process manager,FASTCGI的进程管理器,本身FPM是FASTCGI的一个实现,并且提供进程管理的功能,进程包括master进程和worker进程,这两种进程,其中master进程只有一个,负责监听端口,接受来自webservr的请求;而worker进程一般会有多个,这个具体的数量会在FPM的配置当中来进行定义,每个进程的内部会嵌入到一个php解析器,就是php代码真正执行的地方,也就是说worker来进行处理PHP代码,而master主要负责监听端口,跟web server来进行接收请求。master监听端口默认是9000,然后通过nginx的反向代理,去代理9000端口。完成FPM的相关的处理。
以上就是基本原理。
PHP常见配置项:
register_globals :注册全局变量,注入变量,当这一项打开的时候,各种变量都会被注入代码,例如来自于html表单的一个请求变量,再加上php在使用变量之前,是无需进行初始化的,这就使得更容易出现写出不安全的代码。这是很艰难的抉择。php社区决定默认关闭此选项。以免当打开的时候人们使用变量的时候,确实不知道变量从哪里来的。只能想当然
allow_url_fopen:是否允许打开远程文件
allow_url_include:是否允许远程包含文件
date.timezone:设置时间的时区
display_errors:是否显示错误、通常在开发环境下,display_errors是要开启的,而在生产环境下一定要关闭掉。而register_globals建议一直都关闭掉,不要去用。
error_reporting: 显示错误的级别设置
safe_mode:是否开启安全模式
upload_max_filesize:设置上传最大的文件大小
max_file_uploads:上传的文件最大数量
post_max_size:是提交post数据最大大小
CGI是为了联系web server和php解析器当中的一个协议,相当于一个桥梁,FastCGI是CGI改良的一个版本,PHP-FPM是FastCGI process manager ,FastCGI 进程管理器