这是一篇超级详细的配置mac os下面php+mysql+apache的文章。非常详细
我的大部分配置就是参考上面的内容的,比如,PHP不能连接数据库,就是改一下默认的php.ini中pdo_mysql.default_socket【因为现在都用PDO了嘛。不用mysql的连接库了】
因为我是用navicat的,所以对phpmyadmin那一块的配置就不太关心了。不过MCrypt的安装可以参考。
原文来自:在Mac OS X中配置Apache + PHP + MySQL
内容如下:
Mac OS X 内置了Apache 和 PHP,这样使用起来非常方便。本文以Mac OS X 10.6.3为例。主要内容包括:
- 启动Apache
- 运行PHP
- 安装MySQL
- 使用phpMyAdmin
- 配置PHP的MCrypt扩展库
- 设置虚拟主机
启动Apache
有两种方法:
- 打开“系统设置偏好(System Preferences)” -> “共享(Sharing)” -> “Web共享(Web Sharing)”
- 打开“终端(terminal)”,然后(注意:sudo需要的密码就是系统的root帐号密码)
- 运行“sudo apachectl start”,再输入帐号密码,这样Apache就运行了。
- 运行“sudo apachectl -v”,你会看到Mac OS X 10.6.3中的Apache版本号:
Server version: Apache/2.2.14 (Unix) Server built: Feb 11 2010 14:40:31
这样在浏览器中输入“http://localhost”,就可以看到出现一个内容为“It works!”的页面,它位于“/Library(资源库)/WebServer/Documents/”下,这是Apache的默认根目录。
注意:开启了Apache就是开启了“Web共享”,这时联网的用户就会通过“http://[本地IP]/”来访问“/Library(资源库) /WebServer/Documents/”目录,通过“http://[本地IP]/~[用户名]”来访问“/Users/[用户名]/Sites /”目录,可以通过设置“系统偏好设置”的“安全(Security)”中的“防火墙(Firewall)”来禁止这种访问。
运行PHP
- 在终端中运行“sudo vi /etc/apache2/httpd.conf”,打开Apache的配置文件。(如果不习惯操作终端和vi的可以设置在Finder中显示所有的系统隐藏文件,记得需要重启Finder,这样就可以找到对应文件,随心所欲编辑了,但需要注意的是某些文件的修改需要开启root帐号,但整体上还是在终端上使用sudo来临时获取root权限比较安全。)
- 找到“#LoadModule php5_module libexec/apache2/libphp5.so”,把前面的#号去掉,保存(在命令行输入:w)并退出vi(在命令行输入:q)。
- 运行“sudo cp /etc/php.ini.default /etc/php.ini”,这样就可以通过php.ini来配置各种PHP功能了。比如:
;通过下面两项来调整PHP提交文件的最大值,比如phpMyAdmin中导入数据的最大值 upload_max_filesize = 2M post_max_size = 8M ;比如通过display_errors来控制是否显示PHP程序的报错 display_errors = Off
- 运行“sudo apachectl restart”,重启Apache,这样PHP就可以用了。
- 运行“cp /Library/WebServer/Documents/index.html.en /Library/WebServer/Documents/info.php”,即在Apache的根目录下复制index.html.en文件并重命名为info.php
- 在终端中运行“vi /Library/WebServer/Document/info.php”,这样就可以在vi中编辑info.php文件了。在“It’s works!”后面加上“<?php phpinfo(); ?>”,然后保存之。这样就可以在http://localhost/info.php中看到有关PHP的信息,比如版本号是5.3.1。
安装MySQL
由于Mac OS X中并没有预装MySQL,所以需要自己手动安装,目前MySQL的最稳定版本是5.1。MySQL提供了Mac OS X下的安装说明。
- 下载MySQL 5.1。选择合适的版本,比如这里选择的是mysql-5.1.46-osx10.6-x86_64.dmg。
- 运行dmg,会发现里面有4个文件。首先点击安装mysql-5.1.46-osx10.6-x86_64.pkg,这是MySQL的主安装包。 一般情况下,安装文件会自动把MySQL安装到/usr/local下的同名文件夹下。比如点击运行“mysql-5.1.46-osx10.6- x86_64.dmg”会把MySQ安装到“/usr/local/mysql-5.1.46-osx10.6-x86_64”中。一路默认安装完毕即可。
- 点击安装第2个文件MySQLStartupItem.pkg,这样MySQL就会自动在开机时自动启动了。
- 点击安装第3个文件MySQL.prefPane,这样就会在“系统设置偏好”中看到名为“MySQL”的ICON,通过它就可以设置MySQL开始还是停止,以及是否开机时自动运行。到这里MySQL就基本安装完毕了。
- 通过运行“sudo vi /etc/bashrc”,在bash的配置文件中加入mysql和mysqladmin的别名
#mysql alias mysql='/usr/local/mysql/bin/mysql' alias mysqladmin='/usr/local/mysql/bin/mysqladmin'
这样就可以在终端中比较简单地通过命令进行相应的操作,比如安装完毕之后MySQL的root默认密码为空,如果要设置密码可以在终端运行“mysqladmin -u root password "mysqlpassword"”来设置,其中mysqlpassword即root的密码。更多相关内容可以参考B.5.4.1. How to Reset the Root Password。
注意:Mac OS X的升级或者其他原因可能会导致MySQL启动或者开机自动运行,在MySQL的操作面板上会提示“Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql' ”,或者在命令行下提示“Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)”,这应该是某种情况下导致/usr/local/mysql/data的宿主发生了改变,只需要运行“sudo chown -R mysql /usr/local/mysql/data”即可。
另外,使用PHP连接MySQL可能会报错“Can’t connect to local MySQL server through socket ‘/var/mysql/mysql.sock’”,或者使用localhost无法连接MySQL而需要127.0.0.1,原因是连接时候php默认 去找/var/mysql/mysql.sock了,但是MAC版本的MYSQL改动了文件的位置,放在/tmp下了。处理办法是按如下修改 php.ini:
mysql.default_socket = /tmp/mysql.sock
使用phpMyAdmin
phpMyAdmin是用PHP开发的管理MySQL的程序,非常的流行和实用。能够实用phpMyAdmin管理MySQL是检验前面几步成果的非常有效方式。
- 下载phpMyAdmin。选择合适的版本,比如我选择的是phpMyAdmin-3.3.2-all-languages.tar.bz2这个版本。
- 把“下载(downloads)”中的phpMyAdmin-3.32-all-languages文件夹复制到“/Users/[用户名]/Sites”中,名改名为phpmyadmin。
- 复制“/Users/[用户名]/Sites/phpmyadmin/”中的config.sample.inc.php,并命名为config.inc.php
- 打开config.inc.php,做如下修改:
用于Cookie加密,随意的长字符串 $cfg['blowfish_secret'] = ''; 当phpMyAdmin中出现“#2002 无法登录 MySQL 服务器”时, 请把localhost改成127.0.0.1就ok了, 这是因为MySQL守护程序做了IP绑定(bind-address =127.0.0.1)造成的 $cfg['Servers'][$i]['host'] = 'localhost'; 把false改成true,这样就可以访问无密码的MySQL了, 即使MySQL设置了密码也可以这样设置,然后在登录phpMyAdmin时输入密码 $cfg['Servers'][$i]['AllowNoPassword'] = false;
- 这样就可以通过http://localhost/~[用户名]/phpmyadmin访问phpMyAdmin了。这个时候就看到一个提示“无法加载 mcrypt 扩展,请检查您的 PHP 配置。”,这就涉及到下一节安装MCrypt扩展了。
配置PHP的MCrypt扩展
MCrypt是一个功能强大的加密算法扩展库,它包括有22种算法,phpMyAdmin依赖这个PHP扩展库。但是它在Mac OS X下的安装却不那么友善,具体如下:
- 下载并解压libmcrypt-2.5.8.tar.bz2。
- 在终端执行如下命令(注意如下命令需要安装xcode支持):
XML/HTML代码
- cd ~/Downloads/libmcrypt-2.5.8/
- ./configure --disable-posix-threads --enable-static
- make
- sudo make install
- 下载并解压PHP源码文件php-5.3.1.tar.bz2。Mac OS X 10.6.3中预装的PHP版本是5.3.1,而现在最新的PHP版本是5.3.2,你需要依据自己的实际情况选择对应的版本。
- 在终端执行如下命令:
XML/HTML代码
- cd ~/Downloads/php-5.3.1/ext/mcrypt
- phpize
- ./configure
- make
- cd modules
- sudo cp mcrypt.so /usr/lib/php/extensions/no-debug-non-zts-20090626/
- 打开php.ini
sudo vi /etc/php.ini
在php.ini中加入如下代码,并保存后退出,然后重启Apache
extension=/usr/lib/php/extensions/no-debug-non-zts-20090626/mcrypt.so
当你再访问http://localhost/~[用户名]/phpmyadmin时,你会发现“无法加载 mcrypt 扩展,请检查您的 PHP 配置。”的提示没有了,这就表示MCrypt扩展库安装成功了。
设置虚拟主机
- 在终端运行“sudo vi /etc/apache2/httpd.conf”,打开Apche的配置文件
- 在httpd.conf中找到“#Include /private/etc/apache2/extra/httpd-vhosts.conf”,去掉前面的“#”,保存并退出。
- 运行“sudo apachectl restart”,重启Apache后就开启了它的虚拟主机配置功能。
- 运行“sudo vi /etc/apache2/extra/httpd-vhosts.conf”,这样就打开了配置虚拟主机的文件httpd-vhost.conf,配置你需要的虚拟主机了。需要注意的是该文件默认开启了两个作为例子的虚拟主机:
XML/HTML代码
- <VirtualHost *:80>
- ServerAdmin webmaster@dummy-host.example.com
- DocumentRoot "/usr/docs/dummy-host.example.com"
- ServerName dummy-host.example.com
- ErrorLog "/private/var/log/apache2/dummy-host.example.com-error_log"
- CustomLog "/private/var/log/apache2/dummy-host.example.com-access_log" common
- </VirtualHost>
- <VirtualHost *:80>
- ServerAdmin webmaster@dummy-host2.example.com
- DocumentRoot "/usr/docs/dummy-host2.example.com"
- ServerName dummy-host2.example.com
- ErrorLog "/private/var/log/apache2/dummy-host2.example.com-error_log"
- CustomLog "/private/var/log/apache2/dummy-host2.example.com-access_log" common
- </VirtualHost>
而实际上,这两个虚拟主机是不存在的,在没有配置任何其他虚拟主机时,可能会导致访问localhost时出现如下提示:
Forbidden You don't have permission to access /index.php on this server
最简单的办法就是在它们每行前面加上#,注释掉就好了,这样既能参考又不导致其他问题。
- 增加如下配置
XML/HTML代码
- <VirtualHost *:80>
- DocumentRoot "/Users/[用户名]/Sites"
- ServerName sites
- ErrorLog "/private/var/log/apache2/sites-error_log"
- CustomLog "/private/var/log/apache2/sites-access_log" common
- </VirtualHost>
保存退出,并重启Apache。
- 运行“sudo vi /etc/hosts”,打开hosts配置文件,加入”127.0.0.1 sites“,这样就可以配置完成sites虚拟主机了,这样就可以用“http://sites”访问了,其内容和“http://localhost/~[用户名]”完全一致。
这是利用Mac OS X 10.6.3中原生支持的方式来实现的配置,也可以参考“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(一) ”和“Mac OS X Leopard: 配置Apache, PHP, SQLite, MySQL, and phpMyAdmin(二) ”。实际上,你还可以使用XAMPP或MacPorts这种第三方提供的集成方案来实现简单的安装和使用。
--------
值得一观
对于my.cnf,我一向是懒得看的,因为在windows下面mysql默认有四个ini文件,只要拿其中的一个改为my.ini就行了。一般是拿最大的那个改,而且因为很少用innodb之类的,所以真正改的也就是第一个区块的内容。
看到冰山上的播客上面有翻译,于是COPY过来,与大家分享一下,毕竟即使不是你自己配置数据库,但了解一下也好。
XML/HTML代码
- #BEGIN CONFIG INFO
- #DESCR: 4GB RAM, 只使用InnoDB, ACID, 少量的连接, 队列负载大
- #TYPE: SYSTEM
- #END CONFIG INFO
- #
- # 此mysql配置文件例子针对4G内存,并在www.bt285.cn bt下载与 www.5a520.cn 小说520,这两个日ip 2w ,pv 20w 测试过的。
- # 主要使用INNODB
- #处理复杂队列并且连接数量较少的mysql服务器
- #
- # 将此文件复制到/etc/my.cnf 作为全局设置,
- # mysql-data-dir/my.cnf 作为服务器指定设置
- # (@localstatedir@ for this installation) 或者放入
- # ~/.my.cnf 作为用户设置.
- #
- # 在此配置文件中, 你可以使用所有程序支持的长选项.
- # 如果想获悉程序支持的所有选项
- # 请在程序后加上”–help”参数运行程序.
- #
- # 关于独立选项更多的细节信息可以在手册内找到
- #
- #
- # 以下选项会被MySQL客户端应用读取.
- # 注意只有MySQL附带的客户端应用程序保证可以读取这段内容.
- # 如果你想你自己的MySQL应用程序获取这些值
- # 需要在MySQL客户端库初始化的时候指定这些选项
- #
- [client]
- #password = [your_password]
- port = @MYSQL_TCP_PORT@
- socket = @MYSQL_UNIX_ADDR@
- # *** 应用定制选项 ***
- #
- # MySQL 服务端
- #
- [mysqld]
- # 一般配置选项
- port = @MYSQL_TCP_PORT@
- socket = @MYSQL_UNIX_ADDR@
- # back_log 是操作系统在监听队列中所能保持的连接数,
- # 队列保存了在MySQL连接管理器线程处理之前的连接.
- # 如果你有非常高的连接率并且出现”connection refused” 报错,
- # 你就应该增加此处的值.
- # 检查你的操作系统文档来获取这个变量的最大值.
- # 如果将back_log设定到比你操作系统限制更高的值,将会没有效果
- back_log = 50
- # 不在TCP/IP端口上进行监听.
- # 如果所有的进程都是在同一台服务器连接到本地的mysqld,
- # 这样设置将是增强安全的方法
- # 所有mysqld的连接都是通过Unix sockets 或者命名管道进行的.
- # 注意在windows下如果没有打开命名管道选项而只是用此项
- # (通过 “enable-named-pipe” 选项) 将会导致mysql服务没有任何作用!
- #skip-networking
- # MySQL 服务所允许的同时会话数的上限
- # 其中一个连接将被SUPER权限保留作为管理员登录.
- # 即便已经达到了连接数的上限.
- max_connections = 100
- 一般像在我这个www.bt285.cn pv 10w max_connections=30 就够了。但是如果页面都像http://www.bt285.cn/content.php?id=1196863 这个甜性涩爱页面一样,max_connections=30是不够的。
- # 每个客户端连接最大的错误允许数量,如果达到了此限制.
- # 这个客户端将会被MySQL服务阻止直到执行了”FLUSH HOSTS” 或者服务重启
- # 非法的密码以及其他在链接时的错误会增加此值.
- # 查看 “Aborted_connects” 状态来获取全局计数器.
- max_connect_errors = 10
- # 所有线程所打开表的数量.
- # 增加此值就增加了mysqld所需要的文件描述符的数量
- # 这样你需要确认在[mysqld_safe]中 “open-files-limit” 变量设置打开文件数量允许至少4096
- table_cache = 2048
- # 允许外部文件级别的锁. 打开文件锁会对性能造成负面影响
- # 所以只有在你在同样的文件上运行多个数据库实例时才使用此选项(注意仍会有其他约束!)
- # 或者你在文件层面上使用了其他一些软件依赖来锁定MyISAM表
- #external-locking
- # 服务所能处理的请求包的最大大小以及服务所能处理的最大的请求大小(当与大的BLOB字段一起工作时相当必要)
- # 每个连接独立的大小.大小动态增加
- max_allowed_packet = 16M
- # 在一个事务中binlog为了记录SQL状态所持有的cache大小
- # 如果你经常使用大的,多声明的事务,你可以增加此值来获取更大的性能.
- # 所有从事务来的状态都将被缓冲在binlog缓冲中然后在提交后一次性写入到binlog中
- # 如果事务比此值大, 会使用磁盘上的临时文件来替代.
- # 此缓冲在每个连接的事务第一次更新状态时被创建
- binlog_cache_size = 1M
- # 独立的内存表所允许的最大容量.
- # 此选项为了防止意外创建一个超大的内存表导致永尽所有的内存资源.
- max_heap_table_size = 64M
- # 排序缓冲被用来处理类似ORDER BY以及GROUP BY队列所引起的排序
- # 如果排序后的数据无法放入排序缓冲,
- # 一个用来替代的基于磁盘的合并分类会被使用
- # 查看 “Sort_merge_passes” 状态变量.
- # 在排序发生时由每个线程分配
- sort_buffer_size = 8M
- # 此缓冲被使用来优化全联合(full JOINs 不带索引的联合).
- # 类似的联合在极大多数情况下有非常糟糕的性能表现,
- # 但是将此值设大能够减轻性能影响.
- # 通过 “Select_full_join” 状态变量查看全联合的数量
- # 当全联合发生时,在每个线程中分配
- join_buffer_size = 8M
- # 我们在cache中保留多少线程用于重用
- # 当一个客户端断开连接后,如果cache中的线程还少于thread_cache_size,
- # 则客户端线程被放入cache中.
- # 这可以在你需要大量新连接的时候极大的减少线程创建的开销
- # (一般来说如果你有好的线程模型的话,这不会有明显的性能提升.)
- thread_cache_size = 8
- # 此允许应用程序给予线程系统一个提示在同一时间给予渴望被运行的线程的数量.
- # 此值只对于支持 thread_concurrency() 函数的系统有意义( 例如Sun Solaris).
- # 你可可以尝试使用 [CPU数量]*(2..4) 来作为thread_concurrency的值
- thread_concurrency = 8
- # 查询缓冲常被用来缓冲 SELECT 的结果并且在下一次同样查询的时候不再执行直接返回结果.
- # 打开查询缓冲可以极大的提高服务器速度, 如果你有大量的相同的查询并且很少修改表.
- # 查看 “Qcache_lowmem_prunes” 状态变量来检查是否当前值对于你的负载来说是否足够高.
- # 注意: 在你表经常变化的情况下或者如果你的查询原文每次都不同,
- # 查询缓冲也许引起性能下降而不是性能提升.
- query_cache_size = 64M
- # 只有小于此设定值的结果才会被缓冲
- # 此设置用来保护查询缓冲,防止一个极大的结果集将其他所有的查询结果都覆盖.
- query_cache_limit = 2M
- # 被全文检索索引的最小的字长.
- # 你也许希望减少它,如果你需要搜索更短字的时候.
- # 注意在你修改此值之后,
- # 你需要重建你的 FULLTEXT 索引
- ft_min_word_len = 4
- # 如果你的系统支持 memlock() 函数,你也许希望打开此选项用以让运行中的mysql在在内存高度紧张的时候,数据在内存中保持锁定并且防止可能被swapping out
- # 此选项对于性能有益
- #memlock
- # 当创建新表时作为默认使用的表类型,
- # 如果在创建表示没有特别执行表类型,将会使用此值
- default_table_type = MYISAM
- # 线程使用的堆大小. 此容量的内存在每次连接时被预留.
- # MySQL 本身常不会需要超过64K的内存
- # 如果你使用你自己的需要大量堆的UDF函数
- # 或者你的操作系统对于某些操作需要更多的堆,
- # 你也许需要将其设置的更高一点.
- thread_stack = 192K
- # 设定默认的事务隔离级别.可用的级别如下:
- # READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
- transaction_isolation = REPEATABLE-READ
- # 内部(内存中)临时表的最大大小
- # 如果一个表增长到比此值更大,将会自动转换为基于磁盘的表.
- # 此限制是针对单个表的,而不是总和.
- tmp_table_size = 64M
- # 打开二进制日志功能.
- # 在复制(replication)配置中,作为MASTER主服务器必须打开此项
- # 如果你需要从你最后的备份中做基于时间点的恢复,你也同样需要二进制日志.
- log-bin=mysql-bin
- # 如果你在使用链式从服务器结构的复制模式 (A->B->C),
- # 你需要在服务器B上打开此项.
- # 此选项打开在从线程上重做过的更新的日志,
- # 并将其写入从服务器的二进制日志.
- #log_slave_updates
- # 打开全查询日志. 所有的由服务器接收到的查询 (甚至对于一个错误语法的查询)
- # 都会被记录下来. 这对于调试非常有用, 在生产环境中常常关闭此项.
- #log
- # 将警告打印输出到错误log文件. 如果你对于MySQL有任何问题
- # 你应该打开警告log并且仔细审查错误日志,查出可能的原因.
- #log_warnings
- # 记录慢速查询. 慢速查询是指消耗了比 “long_query_time” 定义的更多时间的查询.
- # 如果 log_long_format 被打开,那些没有使用索引的查询也会被记录.
- # 如果你经常增加新查询到已有的系统内的话. 一般来说这是一个好主意,
- log_slow_queries
- # 所有的使用了比这个时间(以秒为单位)更多的查询会被认为是慢速查询.
- # 不要在这里使用”1″, 否则会导致所有的查询,甚至非常快的查询页被记录下来(由于MySQL 目前时间的精确度只能达到秒的级别).
- long_query_time = 2
- # 在慢速日志中记录更多的信息.
- # 一般此项最好打开.
- # 打开此项会记录使得那些没有使用索引的查询也被作为到慢速查询附加到慢速日志里
- log_long_format
- # 此目录被MySQL用来保存临时文件.例如,
- # 它被用来处理基于磁盘的大型排序,和内部排序一样.
- # 以及简单的临时表.
- # 如果你不创建非常大的临时文件,将其放置到 swapfs/tmpfs 文件系统上也许比较好
- # 另一种选择是你也可以将其放置在独立的磁盘上.
- # 你可以使用”;”来放置多个路径
- # 他们会按照roud-robin方法被轮询使用.
- #tmpdir = /tmp
- # *** 复制有关的设置
- # 唯一的服务辨识号,数值位于 1 到 2^32-1之间.
- # 此值在master和slave上都需要设置.
- # 如果 “master-host” 没有被设置,则默认为1, 但是如果忽略此选项,MySQL不会作为master生效.
- server-id = 1
- # 复制的Slave (去掉master段的注释来使其生效)
- #
- # 为了配置此主机作为复制的slave服务器,你可以选择两种方法:
- #
- # 1) 使用 CHANGE MASTER TO 命令 (在我们的手册中有完整描述) -
- # 语法如下:
- #
- # CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>,
- # MASTER_USER=<user>, MASTER_PASSWORD=<password> ;
- #
- # 你需要替换掉 <host>, <user>, <password> 等被尖括号包围的字段以及使用master的端口号替换<port> (默认3306).
- #
- # 例子:
- #
- # CHANGE MASTER TO MASTER_HOST=’125.564.12.1′, MASTER_PORT=3306,
- # MASTER_USER=’joe’, MASTER_PASSWORD=’secret’;
- #
- # 或者
- #
- # 2) 设置以下的变量. 不论如何, 在你选择这种方法的情况下, 然后第一次启动复制(甚至不成功的情况下,
- # 例如如果你输入错密码在master-password字段并且slave无法连接),
- # slave会创建一个 master.info 文件,并且之后任何对于包含在此文件内的参数的变化都会被忽略
- # 并且由 master.info 文件内的内容覆盖, 除非你关闭slave服务, 删除 master.info 并且重启slave 服务.
- # 由于这个原因,你也许不想碰一下的配置(注释掉的) 并且使用 CHANGE MASTER TO (查看上面) 来代替
- #
- # 所需要的唯一id号位于 2 和 2^32 - 1之间
- # (并且和master不同)
- # 如果master-host被设置了.则默认值是2
- # 但是如果省略,则不会生效
- #server-id = 2
- #
- # 复制结构中的master - 必须
- #master-host = <hostname>
- #
- # 当连接到master上时slave所用来认证的用户名 - 必须
- #master-user = <username>
- #
- # 当连接到master上时slave所用来认证的密码 - 必须
- #master-password = <password>
- #
- # master监听的端口.
- # 可选 - 默认是3306
- #master-port = <port>
- # 使得slave只读.只有用户拥有SUPER权限和在上面的slave线程能够修改数据.
- # 你可以使用此项去保证没有应用程序会意外的修改slave而不是master上的数据
- #read_only
- #*** MyISAM 相关选项
- # 关键词缓冲的大小, 一般用来缓冲MyISAM表的索引块.
- # 不要将其设置大于你可用内存的30%,
- # 因为一部分内存同样被OS用来缓冲行数据
- # 甚至在你并不使用MyISAM 表的情况下, 你也需要仍旧设置起 8-64M 内存由于它同样会被内部临时磁盘表使用.
- key_buffer_size = 32M
- # 用来做MyISAM表全表扫描的缓冲大小.
- # 当全表扫描需要时,在对应线程中分配.
- read_buffer_size = 2M
- # 当在排序之后,从一个已经排序好的序列中读取行时,行数据将从这个缓冲中读取来防止磁盘寻道.
- # 如果你增高此值,可以提高很多ORDER BY的性能.
- # 当需要时由每个线程分配
- read_rnd_buffer_size = 16M
- # MyISAM 使用特殊的类似树的cache来使得突发插入
- # (这些插入是,INSERT … SELECT, INSERT … VALUES (…), (…), …, 以及 LOAD DATA
- # INFILE) 更快. 此变量限制每个进程中缓冲树的字节数.
- # 设置为 0 会关闭此优化.
- # 为了最优化不要将此值设置大于 “key_buffer_size”.
- # 当突发插入被检测到时此缓冲将被分配.
- bulk_insert_buffer_size = 64M
- # 此缓冲当MySQL需要在 REPAIR, OPTIMIZE, ALTER 以及 LOAD DATA INFILE 到一个空表中引起重建索引时被分配.
- # 这在每个线程中被分配.所以在设置大值时需要小心.
- myisam_sort_buffer_size = 128M
- # MySQL重建索引时所允许的最大临时文件的大小 (当 REPAIR, ALTER TABLE 或者 LOAD DATA INFILE).
- # 如果文件大小比此值更大,索引会通过键值缓冲创建(更慢)
- myisam_max_sort_file_size = 10G
- # 如果被用来更快的索引创建索引所使用临时文件大于制定的值,那就使用键值缓冲方法.
- # 这主要用来强制在大表中长字串键去使用慢速的键值缓冲方法来创建索引.
- myisam_max_extra_sort_file_size = 10G
- # 如果一个表拥有超过一个索引, MyISAM 可以通过并行排序使用超过一个线程去修复他们.
- # 这对于拥有多个CPU以及大量内存情况的用户,是一个很好的选择.
- myisam_repair_threads = 1
- # 自动检查和修复没有适当关闭的 MyISAM 表.
- myisam_recover
- # 默认关闭 Federated
- skip-federated
- # *** BDB 相关选项 ***
- # 如果你运行的MySQL服务有BDB支持但是你不准备使用的时候使用此选项. 这会节省内存并且可能加速一些事.
- skip-bdb
- # *** INNODB 相关选项 ***
- # 如果你的MySQL服务包含InnoDB支持但是并不打算使用的话,
- # 使用此选项会节省内存以及磁盘空间,并且加速某些部分
- #skip-innodb
- # 附加的内存池被InnoDB用来保存 metadata 信息
- # 如果InnoDB为此目的需要更多的内存,它会开始从OS这里申请内存.
- # 由于这个操作在大多数现代操作系统上已经足够快, 你一般不需要修改此值.
- # SHOW INNODB STATUS 命令会显示当先使用的数量.
- innodb_additional_mem_pool_size = 16M
- # InnoDB使用一个缓冲池来保存索引和原始数据, 不像 MyISAM.
- # 这里你设置越大,你在存取表里面数据时所需要的磁盘I/O越少.
- # 在一个独立使用的数据库服务器上,你可以设置这个变量到服务器物理内存大小的80%
- # 不要设置过大,否则,由于物理内存的竞争可能导致操作系统的换页颠簸.
- # 注意在32位系统上你每个进程可能被限制在 2-3.5G 用户层面内存限制,
- # 所以不要设置的太高.
- innodb_buffer_pool_size = 2G
- # InnoDB 将数据保存在一个或者多个数据文件中成为表空间.
- # 如果你只有单个逻辑驱动保存你的数据,一个单个的自增文件就足够好了.
- # 其他情况下.每个设备一个文件一般都是个好的选择.
- # 你也可以配置InnoDB来使用裸盘分区 - 请参考手册来获取更多相关内容
- innodb_data_file_path = ibdata1:10M:autoextend
- # 设置此选项如果你希望InnoDB表空间文件被保存在其他分区.
- # 默认保存在MySQL的datadir中.
- #innodb_data_home_dir = <directory>
- # 用来同步IO操作的IO线程的数量. This value is
- # 此值在Unix下被硬编码为4,但是在Windows磁盘I/O可能在一个大数值下表现的更好.
- innodb_file_io_threads = 4
- # 如果你发现InnoDB表空间损坏, 设置此值为一个非零值可能帮助你导出你的表.
- # 从1开始并且增加此值知道你能够成功的导出表.
- #innodb_force_recovery=1
- # 在InnoDb核心内的允许线程数量.
- # 最优值依赖于应用程序,硬件以及操作系统的调度方式.
- # 过高的值可能导致线程的互斥颠簸.
- innodb_thread_concurrency = 16
- # 如果设置为1 ,InnoDB会在每次提交后刷新(fsync)事务日志到磁盘上,
- # 这提供了完整的ACID行为.
- # 如果你愿意对事务安全折衷, 并且你正在运行一个小的食物, 你可以设置此值到0或者2来减少由事务日志引起的磁盘I/O
- # 0代表日志只大约每秒写入日志文件并且日志文件刷新到磁盘.
- # 2代表日志写入日志文件在每次提交后,但是日志文件只有大约每秒才会刷新到磁盘上.
- innodb_flush_log_at_trx_commit = 1
- # 加速InnoDB的关闭. 这会阻止InnoDB在关闭时做全清除以及插入缓冲合并.
- # 这可能极大增加关机时间, 但是取而代之的是InnoDB可能在下次启动时做这些操作.
- #innodb_fast_shutdown
- # 用来缓冲日志数据的缓冲区的大小.
- # 当此值快满时, InnoDB将必须刷新数据到磁盘上.
- # 由于基本上每秒都会刷新一次,所以没有必要将此值设置的太大(甚至对于长事务而言)
- innodb_log_buffer_size = 8M
- # 在日志组中每个日志文件的大小.
- # 你应该设置日志文件总合大小到你缓冲池大小的25%~100%
- # 来避免在日志文件覆写上不必要的缓冲池刷新行为.
- # 不论如何, 请注意一个大的日志文件大小会增加恢复进程所需要的时间.
- innodb_log_file_size = 256M
- # 在日志组中的文件总数.
- # 通常来说2~3是比较好的.
- innodb_log_files_in_group = 3
- # InnoDB的日志文件所在位置. 默认是MySQL的datadir.
- # 你可以将其指定到一个独立的硬盘上或者一个RAID1卷上来提高其性能
- #innodb_log_group_home_dir
- # 在InnoDB缓冲池中最大允许的脏页面的比例.
- # 如果达到限额, InnoDB会开始刷新他们防止他们妨碍到干净数据页面.
- # 这是一个软限制,不被保证绝对执行.
- innodb_max_dirty_pages_pct = 90
- # InnoDB用来刷新日志的方法.
- # 表空间总是使用双重写入刷新方法
- # 默认值是 “fdatasync”, 另一个是 “O_DSYNC”.
- #innodb_flush_method=O_DSYNC
- # 在被回滚前,一个InnoDB的事务应该等待一个锁被批准多久.
- # InnoDB在其拥有的锁表中自动检测事务死锁并且回滚事务.
- # 如果你使用 LOCK TABLES 指令, 或者在同样事务中使用除了InnoDB以外的其他事务安全的存储引擎
- # 那么一个死锁可能发生而InnoDB无法注意到.
- # 这种情况下这个timeout值对于解决这种问题就非常有帮助.
- innodb_lock_wait_timeout = 120
- [mysqldump]
- # 不要在将内存中的整个结果写入磁盘之前缓存. 在导出非常巨大的表时需要此项
- quick
- max_allowed_packet = 16M
- [mysql]
- no-auto-rehash
- # 仅仅允许使用键值的 UPDATEs 和 DELETEs .
- #safe-updates
- [isamchk]
- key_buffer = 512M
- sort_buffer_size = 512M
- read_buffer = 8M
- write_buffer = 8M
- [myisamchk]
- key_buffer = 512M
- sort_buffer_size = 512M
- read_buffer = 8M
- write_buffer = 8M
- [mysqlhotcopy]
- interactive-timeout
- [mysqld_safe]
- # 增加每个进程的可打开文件数量.
- # 警告: 确认你已经将全系统限制设定的足够高!
- # 打开大量表需要将此值设高 j
- open-files-limit = 8192
文章的内容写的不错,所以转载一下。
原文:http://xinsync.xju.edu.cn/index.php/archives/2946
内容如下:
XML/HTML代码
- 过去当运行一个大的web应用时候意味着运行一个大型的web服务器。因为你的应用吸引了大量的用户,你将不得不在你的服务器里增加更多的内存和处理器。
-
- 今天,’大型服务器’模式已经过去,取而代之的是大量的小服务器,使用各种各样的负载均衡技术。这是一种更可行的方法,将使硬件成本降至最低。
-
- ‘更多小服务器’的优势超过过去的’大型服务器’模式体现在两个方面:
-
- 1. 如果服务器宕机,那么负载均衡系统将停止请求到宕机的服务器,转而分发负载到其他正常运行的服务器上。
- 2. 扩展你的服务器更加容易。你要做的仅仅是加入新的服务器到负载均衡系统。不需要中断你的应用运行。
-
- 所以,把握住这个机会:). 当然,代价就是这要求你的应用开发时增加一点复杂度。这就是本文要覆盖的内容。
-
- 这时你可能对自己说: ‘但是我怎么知道我正在使用负载均衡呢?’。最诚实的回答是,如果你正在问这个问题,那么答案是你多半没有在使用负载均衡系统并且你的系统不需要考虑这个问题。大多数情况,当应用成长足够大的规模时,负载均衡就需要明确提出和设置了。然而,我也偶尔看见虚拟主机公司为客户的应用做这个负载均衡,或者像下面描述的那样要自己来做。
-
- 在继续下面的内容之前,我要指出本文主要描述PHP的负载均衡。将来我可能会写有关数据负载均衡的文字,但是现在你必须等待。
-
- 注意,我一直提“web应用”而不是website,这是想区分’web应用’是那些复杂的站点往往涉及服务器端编程和数据库,而不是website那样只显示简单的静态内容。
- 1. PHP文件
-
- 第一个问题是,如果你有大量的小型服务器,你怎么把你的php文件上传到所有的服务器上?有如下的方法供你参考:
-
- 1. 分别上传所有的文件到每一个服务器 , 这种方法带来的问题是:想像一下你有20个服务器,那么上传过程中这将很容易导致错误,并且更新时极有可能导致不同服务器上有不同版本的文件。
- 2. 使用 ‘rsync ‘ (或类似的软件) . 这样的工具能同步本地目录和多个远程主机目录上的文件。
- 3. 使用版本控制软件(如subversion ) . 这是我最喜欢的方法。用它可以很好地维护我得代码,当发布我的应用时,可以在每一个服务器上运行svn update命令同步。这种方法也使切换服务器得代码到过去的某一个版本更加容易。
- 4. 使用一个文件服务器(你可能发现NFS 非常适合做这件事情). 这种方式是使用一个文件服务器来存放你的web应用. 当然,如果你的文件服务器宕机,那么多所有你的站点将不能使用。这时,你就需要花费更多的开支来恢复它。
-
- 选择哪种方式依赖于你的需求和你掌握的技能。如果你使用版本控制系统,那么你可能得计划一个方法如果同时执行一个更新命令更新所有服务器上的代码。然而,如果使用文件服务器,你就要实现一些失败恢复机制,防止万一服务器宕机导致请求失败。
- 2. 文件上传
-
- 当只有一台服务器时,文件上传不是一个问题。但是当我们有多台服务器时,那么上传的文件应该怎么存放呢?上传文件的问题和跨服务器php文件存储是类似的。下面是几种可能的方案:
-
- 1. 把文件存储到数据库中 。大多数数据允许存储二进制数据。当你请求文件下载时,访问数据把二进制数据和相应的文件名和类型输出给用户。在使用这种方案前应该考虑数据库怎样存储你的文件。该方法的问题在于如果数据库服务器宕机将使文件不可用。
- 2. 在一个文件服务器上存储上传的文件 . 与前面的介绍一样,你要安装一个文件服务器让所有web服务器共享,把所有上传的文件上传到这里,上传后所有的web服务器就都可以使用它。但是,如果文件服务器宕机,那么可能发生图像文件下载中断。
- 3. 设计你自己的上传机制传输文件到服务器到每一个服务器 . 这个方法没有单个文件服务器或者数据库方案的缺陷,但是将增加你代码的复杂度。例如,如果上传到多个服务器过程中,服务器宕机,你要怎么处理?
-
- 用数据库存储上传文件但是设计一个文件缓存机制是一个不错的方案。当服务器接收一个文件下载请求时,首先检查缓存系统中是否有该文件,如果发现那么从缓存系统下载,否则从数据库读取并把它缓存到文件系统中。
- 3. 会话(Sessions)
-
- 如果你熟悉php的session处理,你将可能知道默认情况下,它存储session数据在服务器的临时文件里。而且,这个文件仅仅在你请求处理的那个服务器上,但是接下来的请求可能被另外一个服务器处理,这将在另一个服务器上生成新的session。这导致session频繁地不被识别,如登录用户总是要求重新登录。
-
- 我推荐的方案是,要么重新php内建的session处理机制存储session数据到数据库,或者实现你自己的机制保证发送一个用户的请求到同一台服务器。
- 4. 配置(Configuration)
-
- 尽管这个话题不是和php特别相关,我感觉还是有必要提及。当运行集群服务器时,用某种方法保持服务器之间的配置文件同步是一个好主意。如果配置文件不一致,可能导致一些非常奇怪的断断续续的行为导致很难排查这些问题。
-
- 我推荐使用版本控制系统单独管理他们。这样你可以为不同的项目安装存储不同的php配置文件,也可以保持所有服务器配置文件同步。
- 5. 日志(Logging)
-
- 像配置问题一样,logging不是仅仅和php相关。但是对于保持服务器健康运行它仍然是非常重要的。没有正确的logging系统,你怎么知道如果PHP代码开始产生错误(在系统正式运行时,你总是关闭display_errors 设置,不是吗?)
-
- 有几种方法你可以实现logging:
-
- 1. 在每一个服务器上记录日志。 这是最简单的方法。每一个机器仅仅记录一个文件。好处是简单,可能只要很少的配置。但是,随着服务器数量的增多,监控每台服务器上的日志文件将变得非常困难。
- 2. 记录日志到一个共享 这种方法每一个服务器仍然有这个日志文件,但是他们通过共享机制被存储在一个中央文件服务器上,这将使监控日志变得更简单。该方案的问题在于,如果文件服务器不可用将导致一个简单的日志不能写入问题最终导致整个应用崩溃。
- 3. 记录日志到logging服务器 你可以使用一个logging软件,如syslog 来把所有的日志写到一个中央服务器。尽管这个方法要求更多的配置,但是他也提供了最健壮的方案。
SVN的机制确实是很多人现在所考虑的,一来这样保证了代码的同步,二来也不需要担心开发版和上线版的区别,更重要的是,每次的update你肯定不会有错。
文件上传其实才是一个大头,当你的服务器过多的时候,你如何保证每一台服务器的上传内容同步?如果你同步了,那么这么多的冗余文件是否是一个浪费?如果你不同步,而采用同一个NFS服务器来存储,那么就象文中说的如果NFS宕机了怎么办?给NFS也来一个负载均衡?
总之,当服务器越来越多的时候,你考虑的就不仅仅是代码的问题,而是架构的问题