码迷,mamicode.com
首页 > 数据库 > 详细

LAMP第三部分php,mysql配置

时间:2015-06-18 20:12:28      阅读:333      评论:0      收藏:0      [点我收藏+]

标签:mysql   配置文件   local   

                                   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

4php的配置有错误,Apache也不会检测出来,所以不使用检测命令

 

二、配置error_log(错误日志)

也是在/usr/local/php/etc/php.ini配置文件下,

1display_error=off  #关闭日志提醒,这样子做是为了安全

2log_errors=on #开始错误日志记录功能,默认是开启的

3error_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

5memcache-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 

# 慢查询日志路径,必须配合上面的参数一同使用


笔记有错误的地方还请大神指正,小白会继续修改

本文出自 “IT交流学习” 博客,请务必保留此出处http://sxct168.blog.51cto.com/824373/1663195

LAMP第三部分php,mysql配置

标签:mysql   配置文件   local   

原文地址:http://sxct168.blog.51cto.com/824373/1663195

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!