LAMP第三部分php,mysql配置
php配置
一、禁用函数设置
1、查找php配置文件的命令,在不知道配置文件的情况下使用
[root@mysql ~]#/usr/local/php/bin/php -i |head phpinfo() PHP Version => 5.3.28 System => Linux mysql 2.6.32-504.16.2.el6.x86_64 #1 SMP Wed Apr 22 06:48:29 UTC 2015 x86_64 Build Date => Jun 12 2015 23:45:07 Configure Command => './configure' '--prefix=/usr/local/php' '--with-apxs2=/usr/local/apache2/bin/apxs' '--with-config-file-path=/usr/local/php/etc' '--with-mysql=/usr/local/mysql' '--with-libxml-dir' '--with-gd' '--with-jpeg-dir' '--with-png-dir' '--with-freetype-dir' '--with-iconv-dir' '--with-zlib-dir' '--with-bz2' '--with-openssl' '--with-mcrypt' '--enable-soap' '--enable-gd-native-ttf' '--enable-mbstring' '--enable-sockets' '--enable-exif' '--disable-ipv6' Server API => Command Line Interface Virtual Directory Support => disabled Configuration File (php.ini) Path => /usr/local/php/etc Loaded Configuration File => /usr/local/php/etc/php.ini
2、在Windows浏览器中查看php配置文件,需要在网站的根目录下创建一个phpinfo.php脚本,这个更准确一些
进入网站根目录
[root@mysql ~]# cd /data/www/
创建phpinfo.php脚本
[root@mysql www]# vim phpinfo.php
脚本内容:
<?php phpinfo(); ?>
在web浏览器中访问
地址:http://www.guhantai.com.cn/phpinfo.php
2、配置disable_function
disable_function:禁用函数的意思
配置文件路径:/usr/local/php/etc/php.ini,把下面的函数写在disable_functions = 的后面,如图:
禁用函数如下:
eval,assert,popen,passthru,escapeshellarg,escapeshellcmd,passthru,exec,system,chroot,scandir,chgrp,chown,escapeshellcmd,escapeshellarg,shell_exec,proc_get_status,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,leak,popepassthru,stream_socket_server,popen,proc_open,proc_close
其中,shell_exec一定要写,这是个最危险的函数
3、退出保存,要重启apache服务,不然不会生效
[root@mysql ~]# /usr/local/apache2/bin/apachectl restart
4、php的配置有错误,Apache也不会检测出来,所以不使用检测命令
二、配置error_log(错误日志)
也是在/usr/local/php/etc/php.ini配置文件下,
1、display_error=off #关闭日志提醒,这样子做是为了安全
2、log_errors=on #开始错误日志记录功能,默认是开启的
3、error_log=/usr/local/php/logs/error.log
定义错误日子的存放路径,/usr/local/php/logs/error.log就死存放路径,最好写绝对路径,因为相对路径有可能不识别
注意要创建以下日志目录,不然无法生成日志
创建目录:mkdir /usr/local/hph/logs
查看Apache 服务账号
[root@mysql ~]# ps aux |grep httpd root 1232 0.0 1.0 279576 10956 ? Ss 01:46 0:18 /usr/local/apache2/bin/httpd -k start root 1711 0.0 0.4 143536 4472 ? S 09:18 0:00 vim /usr/local/apache2/conf/extra/httpd-vhosts.conf daemon 1969 0.0 0.6 279576 6216 ? S 22:02 0:00 /usr/local/apache2/bin/httpd -k start daemon 1970 0.0 0.6 279576 6216 ? S 22:02 0:00 /usr
授权daemon账号可以对logs目录进行读写权限
chmod 777 /usr/local/php/logs
如果因为某些情况不能自动创建,那么需要手动创建一个错误日志,并且授权
创建:touch /usr/local/php/logs/error.log
授权:chmod 777 /usr/local/php/logs/error.log
4、日志级别
error_reporting = E_ALL | E_STRICT:会记录我们所需要的日志了,应该是说,满足我们所需要的错误信息了
5、错误级别参考:
; E_ALL 所有错误和警告(除E_STRICT外)
; E_ERROR 致命的错误。脚本的执行被暂停。
; E_RECOVERABLE_ERROR 大多数的致命错误。
; E_WARNING 非致命的运行时错误,只是警告,脚本的执行不会停止。
; E_PARSE 编译时解析错误,解析错误应该只由分析器生成。
; E_NOTICE 脚本运行时产生的提醒(往往是我们写的脚本里面的一些bug,比如某个变量没有定义),这个错误不会导致任务中断。
; E_STRICT 脚本运行时产生的提醒信息,会包含一些php抛出的让我们要如何修改的建议信息。
; E_CORE_ERROR 在php启动后发生的致命性错误
; E_CORE_WARNING 在php启动后发生的非致命性错误,也就是警告信息
; E_COMPILE_ERROR php编译时产生的致命性错误
; E_COMPILE_WARNING php编译时产生的警告信息
; E_USER_ERROR 用户生成的错误
; E_USER_WARNING 用户生成的警告
; E_USER_NOTICE 用户生成的提醒
& 表示并且
~ 表示非
| 表示或者
参考文档:http://www.aminglinux.com/bbs/thread-6973-1-1.html
三、 配置open_basedir
作用:将用户可操作的文件限制在某目录下
1、修改/usr/local/php/etc/php.ini 配置文件
open_basedir默认是关闭的,如图:
去掉注释,启用并且修改:
/data/www/:写的是网站的根目录,就是把用户的权限限制在此目录
然后重启apache服务
[root@mysql ~]# /usr/local/apache2/bin/apachectl restart
2、如果有多个网站时,需要在/usr/local/apache2/conf/extra/httpd-vhosts.conf文件中修改配置
如下图所示:
只需要在每个虚拟机配置中增加这一条命令就可以:
php_admin_value open_basedir "/dir1/:/dir2/"
"/dir1/:/dir2/:网站目录
配置完成之后需要检测apache的配置文件是否正确
[root@mysql ~]# /usr/local/apache2/bin/apachectl -t Warning: DocumentRoot [/tmp/tmp] does not exist Syntax OK
Warning: DocumentRoot [/tmp/tmp] does not exist
这个错误信息是提示我没有/tmp/tmp/目目录,因为我只有一个网站,所以不可能有这个目录的,
这里只是演示了一下,如果有多个网站时改怎么处理
重启apache服务
[root@mysql ~]# /usr/local/apache2/bin/apachectl restart
四、安装php的扩展模块(memcache)
1、把所有的源码包都下载到/usr/loacal/src
[root@mysql ~]# cd /usr/local/src/
2、下载源 memcache码包
[root@mysql src]# wget http://www.lishiming.net/data/attachment/forum/memcache-2.2.3.tgz
3、解压 memcache
[root@mysql src]# tar zxvf memcache-2.2.3.tgz
4、进入到源码包
[root@mysql src]# cd memcache-2.2.3
5、memcache-2.2.3目录下你没有configure文件,需要生成文件
[root@mysql memcache-2.2.3]# /usr/local/php/bin/phpize
生成文件之后,查看并没有configure文件,检查是发现提示未安装autocon,如图
安装autocon
[root@mysql ~]# yum install autoconf
再生成文件
[root@mysql memcache-2.2.3]# /usr/local/php/bin/phpize
使用ls查看
6、编译文件
./configure --with-php-config=/usr/local/php/bin/php-config
[root@mysql memcache-2.2.3]# ./configure --with-php-config=/usr/local/php/bin/php-config
7、编译
make
[root@mysql memcache-2.2.3]# make
make install
[root@mysql memcache-2.2.3]# make install
8、用ls查看ls /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/时会多出一个文件来
[root@mysql memcache-2.2.3]# ls /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/
memcache.so
9、 memcache.so文件的用法:去编辑/usr/local/php/etc/php.ini配置文件
[root@mysql memcache-2.2.3]# vim /usr/local/php/etc/php.ini
在/usr/local/php/etc/php.ini文件的末尾写上一下一行:
extension = memcache.so
如图:
然后退出保存
查看php是否有加载刚才的模块,如果就成功了
[root@mysql memcache-2.2.3]# /usr/local/php/bin/php -m
10、如果不知道模块在哪里,需要使用一下命令来查找模块的路径
/usr/local/php/bin/php -i |grep -i extension_dir
[root@mysql memcache-2.2.3]# /usr/local/php/bin/php -i |grep -i extension_dir extension_dir => /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626 => /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626 PHP Warning: Unknown: It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected 'Asia/Chongqing' for 'CST/8.0/no DST' instead in Unknown on line 0 sqlite3.extension_dir => no value => no value
或者在编辑配置文件的时候可与写上绝对路径,这样子就不容易出错
extension = /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so
在浏览器中输入http://www.guhantai.com.cn/phpinfo.php 访问时就会看到memcache模块的
Phpinfo.php:是之前创建的一个,可与看上一篇笔记,当中有记录
mysql配置(部分常用的参数)
mysql配置文件路径:/etc/my.cnf
[mysqld]
socket = /tmp/mysql.sock
# 为MySQL客户程序与服务器之间的本地通信指定一个套接字文件(Linux下默认是/var/lib/mysql/mysql.sock文件)
port = 3306
# 指定MsSQL侦听的端口 ,这个端口可与自己修改
skip-name-resolve
#禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。但需要注意,如果开启该选项, 则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求. 这个一般在配置文件中禁用掉
key_buffer = 384M
# key_buffer是用于索引块的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写)。索引被所有的线程共享,key_buffer的大小视内存大小而定。
table_open_cache = 512
# MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。默认值64, 假定系统有200个并发连接,则需将此参数设置为200*N(N为每个连接所需的文件描述符数目);当把table_open_cache设置为很大时,如果系统处理不了那么多文件描述符,那么就会出现客户端失效,连接不上.
类似于一个缓存区
max_allowed_packet = 4M
# 接受的数据包大小;增加该变量的值十分安全,这是因为仅当需要时才会分配额外内存。例如,仅当你发出长查询或MySQLd必须返回大的结果行时MySQLd才会分配更多内存。 该变量之所以取较小默认值是一种预防措施,以捕获客户端和服务器之间的错误信息包,并确保不会因偶然使用大的信息包而导致内存溢出。
这个值可以适当的调大,比如调到16M
sort_buffer_size = 2M
# MySQL执行排序使用的缓冲大小。如果想要增加ORDER BY的速度,首先看是否可以让MySQL使用索引而不是额外的排序阶段。如果不能,可以尝试增加sort_buffer_size变量的大小
read_buffer_size = 2M
# 读查询操作所能使用的缓冲区大小。和sort_buffer_size一样,该参数对应的分配内存也是每连接独享。对表进行顺序扫描的请求将分配一个读入缓冲区,MySQL会为它分配一段内存缓冲区。 如果对表的顺序扫描请求非常频繁,并且你认为频繁扫描进行得太慢,可以通过增加该变量值以及内存缓冲区大小提高其性能.
join_buffer_size = 2M
# 联合查询操作所能使用的缓冲区大小,和sort_buffer_size一样,该参数对应的分配内存也是每连接独享
query_cache_size = 32M
# 指定MySQL查询结果缓冲区的大小
read_rnd_buffer_size = 2M
# 随机读缓冲区大小。当按任意顺序读取行时(例如,按照排序顺序),将分配一个随机读缓存区。进行排序查询时,MySQL会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySQL会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大
myisam_sort_buffer_size =64M
# MyISAM表发生变化时重新排序所需的缓冲
thread_concurrency = 8
# 最大并发线程数,取值为服务器逻辑CPU数量×2
thread_cache = 8
#该值表示可以重新利用保存在缓存中线程的数量,当断开连接时若缓存中还有空间,那么客户端的线程将被放到缓存中,如果线程重新被请求,那么请求将从缓存中读取,若果缓存中是空的或者是新的请求,那么线程将被重新创建。设置规律为:1G内存设置为8,2G内存设置为16,4G以上设置为64
max_connections = 1000
#MySQL的最大连接数,如果服务器的并发连接请求量比较大,建议调高此值,以增加并行连接数量,当然这建立在机器能支撑的情况下,因为如果连接数越多,介于MySQL会为每个连接提供连接缓冲区,就会开销越多的内存,所以要适当调整该值,不能盲目提高设值。可以过'conn%'通配符查看当前状态的连接数量,以定夺该值的大小。
max_connect_errors = 6000
# 对于同一主机,如果有超出该参数值个数的中断错误连接,则该主机将被禁止连接。如需对该主机进行解禁,执行:FLUSH HOST。
open_files_limit = 65535
# MySQL打开的文件描述符限制,默认最小1024
skip-locking
# 避免MySQL的外部锁定,减少出错几率增强稳定性。
wait_timeout = 8
# 表示空闲的连接超时时间,默认是28800s,这个参数是和interactive_timeout一起使用的,也就是说要想让wait_timeout 生效,必须同时设置interactive_timeout
interactive_timeout = 8
long_query_time = 1
#慢查询日志的超时时间
log_slow_queries = /path/to/slow_queries
# 慢查询日志路径,必须配合上面的参数一同使用
笔记有错误的地方还请大神指正,小白会继续修改