通过上一节的实验,我们学会了如何去配置 Apache 环境。使用一些 apache 意想不到的功能,这节将带领大家简单的了解一下 PHP 与 Mysql 的配置参数。
PHP 的配置文件在 /etc/php5/
中,并且使用 apt-get 装的话,针对的模块不同,配置文件也不同,我们可以看见在该目录下有这样几个文件夹:
并且我们还可以在每个文件夹下面看见 php.ini 文件与 conf.d 文件夹。由此我们可以得知 php 的配置文件氛围两部分:
进入该文件中,其实配置文件的语法很简单:
###常用的配置
engine = On //允许 php 引擎在 apache 中运行
short_open_tag = Off #tags识别
asp_tags = Off #asp tags识别
precision = 14 #浮点类型数显示时的有效位数
output_buffering = 4096 #输出缓存允许你在输出正文内容之后发送 header
implicit_flush = Off #告诉输出层在每个输出块之后自动刷新自身数据
disable_functions = #关闭特定函数
display_errors = Off #显示错误信息
log_errors = On #在日志文件里记录错误
request_order = "GP" #GET POST
register_argc_argv = On #是否声明 argv和argc 变量
post_max_size = 8M #最大POST大小
file_uploads = On #是否允许HTTP方式文件上载
upload_tmp_dir = #用于HTTP上载的文件的临时目录
upload_max_filesize = 2M #上载文件的最大大小
max_file_uploads = 20 #每次最大上传文件个数
allow_url_fopen = On #是否允许把URLs当作http:.. 或把文件当作ftp:...
default_socket_timeout = 60 #默认socker超时时间
#MySQL相关
mysql.allow_persistent = On #允许持久连接
mysql.cache_size = 2000 #缓存大小
mysql.max_persistent = -1 #持久连接的最大数目 -1不限制
mysql.max_links = -1 #最大链接
mysql.connect_timeout = 60 #连接超时时间
#session相关
session.save_handler = files #用于保存/取回数据的控制方式
session.use_cookies = 1 #是否使用cookies
session.name = PHPSESSID #设置cookies名
session.use_only_cookies = 1 #强制SESSION ID必须以COOKIE传递
session.auto_start = 0 #在请求启动时初始化session
session.cookie_lifetime = 0 #cookies保持时间
#session垃圾回收参数
session.gc_probability = 1 #按百分比整理
session.gc_divisor = 1000 #每次请求时有1/1000的机会启动"垃圾回收"进程
#Session ID传递参数
session.use_trans_sid = 0 #使用URL的方式传递session id
session.hash_function = 0 #生成SID MD5算法
session.hash_bits_per_character = 5 #指定在SID字符串中的每个字符内保存多少bit
PHP配置相关链接:
mysql 的配置文件在这个文件中 /etc/mysql/my.cnf
。
在配置 MySQL 之前我们先要了解到 MyISAM 与 InnoDB 两个常用的表存储引擎,
> MyISAM是MySQL关系数据库管理系统的默认储存引擎。这种MySQL表存储结构从旧的ISAM(Indexed Sequential Access Method,MySQL5.0已经不支持ISAM了)代码扩展出许多有用的功能。在新版本的MySQL中,InnoDB引擎由于其对事务,参照完整性,以及更高的并发性等优点开始广泛的取代MyISAM。
> InnoDB是MySQL存储引擎。MySQL 5.5和以后使用它的默认。它提供标准的符合 ACID 事务特性,随着国外重点支持(声明引用完整性)。它包括作为标准在大多数双星由MySQL AB分布,唯一的例外是一些OEM版本。
关于两者的比较,可以参看这篇博文。
在使用这两个引擎的时候有这样一个小建议,仅供参考:
如果仅使用MyISAM存储引擎,设置 keybuffersize为可用内存的20%,(再加上设置 innodbbufferpool_size = 0 );
如果仅使用InnoDB存储引擎,设置 innodbbufferpoolsize为可用内存的 70%, (设置 keybuffer_size = 10M,很小但不是0)。
MyISAM引擎的缓存分为两部分:
InnoDB将所有缓存都放在 “buffer pool” 中, 缓存池的大小通过 innodbbufferpool_size 控制。包含被打开表(open tables)中的 16KB一块的数据/索引块,此外还有一些附加开销。
MySQL 5.5(以及带插件的 5.1版本)允许您指定 块大小(block size)为 8 KB或4 KB. MySQL 5.5可以有多个缓冲池,因为每个缓存池有一个互斥锁, 所以设置多个池可以缓解一些互斥锁瓶颈。
一般情况下主机不是太差,默认配置即可,但是也要根据站点的情况作相应的处理,具体的一些调优参数大家可以参看这篇博文。
LAMP环境下的调优,以下所有参数均来自于网络,请根据实际环境进行调整。
基于稳定的perfork工作模式,调整apache主配置文件以下参数。
StartServers 50 #预创建50个进程
MinSpareServers 15 #保持最小空闲进程
MaxSpareServers 30 #保持最大空闲进程
MaxClients 225 #最大进程数
MaxRequestsPerChild 4000 #用来控制每个进程在处理了多少次请求之后自动销毁
请使用ps aux 查看进程占用内存数,以此调整实际环境中的参数,防止此消耗所有的资源。
php.ini常用优化配置参数:
max_execution_time 30 #一个脚本可使用多少 CPU 秒
max_input_time 60 #一个脚本等待输入数据的时间有多长(秒)
memory_limit 32M #在被取消之前,一个脚本可使用多少内存(字节)
output_buffering 4096 #数据发送给客户机之前,有多少数据(字节)需要缓存
[1]mysql调优:<http://mysql.rjweb.org/doc.php/memory> [2]mysql调优博文:<http://www.ha97.com/4110.html>