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.ini2、在Windows浏览器中查看php配置文件,需要在网站的根目录下创建一个phpinfo.php脚本,这个更准确一些
进入网站根目录
[root@mysql ~]# cd
/data/www/
创建phpinfo.php脚本
[root@mysql www]#
vim phpinfo.php
脚本内容:
在web浏览器中访问
地址: http://www.guhantai.com.cn/phpinfo.php
2 、 配置disable_function
disable_function :禁用函数的意思
配置文件路径: /usr/local/php/etc/php.ini ,把下面的函数写在 dis able_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 目录进行读写权限
ch mod 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 OKWarning:
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
#
慢查询日志路径,必须配合上面的参数一同使用
笔记有错误的地方还请大神指正,小白会继续修改
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com