LAMP第三部分php,mysql配置

                                   LAMP第三部分php,mysql配置php

                                php配置html

1、禁用函数设置mysql

一、查找php配置文件的命令,在不知道配置文件的状况下使用linux

[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

二、在Windows浏览器中查看php配置文件,须要在网站的根目录下建立一个phpinfo.php脚本,这个更准确一些web

进入网站根目录sql

[root@mysql ~]# cd /data/www/shell

 

建立phpinfo.php脚本apache

[root@mysql www]# vim phpinfo.phpvim

脚本内容:浏览器

<?php
phpinfo();
?>

 

在web浏览器中访问

地址:http://www.guhantai.com.cn/phpinfo.php

wKioL1WCdqOSDRJRAAOIAJwpW0g675.jpg

2配置disable_function

disable_function:禁用函数的意思

配置文件路径:/usr/local/php/etc/php.ini,把下面的函数写在disable_functions = 的后面,如图:

wKioL1WCdszCzXx3AAMHuey4KhY678.jpg

禁用函数以下:

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也不会检测出来,因此不使用检测命令

 

2、配置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


3、 配置open_basedir

做用:将用户可操做的文件限制在某目录下

1、修改/usr/local/php/etc/php.ini 配置文件

      open_basedir默认是关闭的,如图:

     

wKioL1WCd2qhje0IAAC7sRQkc9M588.jpg


去掉注释,启用而且修改:

wKiom1WCddKgU6ZyAAEvUIlNVtM521.jpg

/data/www/:写的是网站的根目录,就是把用户的权限限制在此目录

 

而后重启apache服务

  [root@mysql ~]# /usr/local/apache2/bin/apachectl restart  

2、若是有多个网站时,须要在/usr/local/apache2/conf/extra/httpd-vhosts.conf文件中修改配置

      以下图所示:

wKiom1WCderitxfdAAKql9cvEGc883.jpg

只须要在每一个虚拟机配置中增长这一条命令就能够:

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

4、安装php的扩展模块(memcache)

1、把全部的源码包都下载到/usr/loacal/src

     [root@mysql ~]# cd /usr/local/src/

2、下载源 memcache码包

[root@mysql src]#  wget http://www.lishiming.net/data/p_w_upload/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,如图

wKiom1WCdlDRgPlkAAQqSM-XgyE595.jpg

安装autocon

[root@mysql ~]# yum install autoconf

 

再生成文件

[root@mysql memcache-2.2.3]# /usr/local/php/bin/phpize

 

使用ls查看

wKioL1WCeCWjj-WCAAKW9k4dSzE465.jpg

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

如图:

wKioL1WCeFiwH7jKAACgZ0nK88A182.jpg

而后退出保存

 

查看php是否有加载刚才的模块,若是就成功了

[root@mysql memcache-2.2.3]# /usr/local/php/bin/php -m

wKiom1WCdseRvBgrAAD6d4d5hNU448.jpg

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 

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


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

相关文章
相关标签/搜索