设为首页 收藏本站
查看: 648|回复: 0

[经验分享] LAMP第三部分php,mysql配置

[复制链接]

尚未签到

发表于 2018-12-19 07:40:54 | 显示全部楼层 |阅读模式
                                     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,把下面的函数写在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 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

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

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

  

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




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-653006-1-1.html 上篇帖子: PHP中foreach循环中使用引用要注意的地方 下篇帖子: PHP安装FastDFS扩展,测试上传文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表