你需要下列工具构造并安装MySQL源代码:
- GNU
gunzip
解压缩该分发。 - 一个合适的
tar
解包分发。GNUtar
已知可以工作。 - 一个能运行的ANSI C++编译器。
gcc
> = 2.8.1 、egcs
> = 1.0.2 、SGI C++和SunPro C++是一些已知能工作编译器。 当使gcc
用时,不需要libg++
。gcc2.7.x 有一个bug,使得它可能不能编译一些完全合法的C++文件,例如“sql/sql_base.cc”。如果你仅有gcc
2.7.x,你必须升级gcc
才能编译MySQL。 - 一个优秀的
make
程序。GNUmake
总是被推荐且有时必须。如果你有问题,我们推荐试一试GNUmake
3.75或更新。
如果你遇到问题,当向mysql@lists.mysql.com邮寄问题时,请一直使用mysqlbug
。就算问题不是一个bug,mysqlbug
收集系统信息,将有助于其它人解决你的问题。如果不使用mysqlbug
,你减少得到关你问题的一个解决方案的可能性!在你解包分发后,你会在“scripts”目录下找到mysqlbug
。见2.3 怎样报告错误或问题。
4.7.1 快速安装概述
你必须执行的安装MySQL源代码分发的基本命令是(从一个解包的tar
文件):
shell>configure shell>make shell>make install shell>scripts/mysql_install_db shell>/usr/local/mysql/bin/safe_mysqld &
如果你从一个源代码RPM开始,那么执行如下命令。
shell> rpm -- rebuild MySQL-VERSION.src.rpm
这样你制作一个可以安装的二进制RPM。
如果你安装了DBI
和Msql-Mysql-modules
Perl模块,你可以利用bin/mysql_setpermission
脚本增加新用户。
以下是更详细的描述:
为了安装源代码分发,按照下列步骤,然后继续到4.15 安装后期的设置与测试,进行安装后期的初始化与测试。
- 挑选一个你要在其下面解包分发的目录,并且进入该目录。
- 从节4.1 怎样获得MySQL中列出的站点之一获得一个分发文件。MySQL源代码分发以压缩的
tar
档案提供,并且有类似于“mysql-VERSION.tar.gz”的名字,这里的VERSION
是一个类似3.23.7-alpha的数字。 - 在当前目录下解包分发:
shell> gunzip < mysql-VERSION.tar.gz | tar xvf -
这个命令创建名为“mysql-VERSION”的一个目录。
- 进入解包分发的顶级目录:
shell> cd mysql-VERSION
- 设置发行版本并且编译:
shell>./configure--prefix=/usr/local/mysql shell>make
当你运行
configure
时,你可能想要指定一些选项,运行./configure --help
得到一张选项表。4.7.3 典型的configure
选项讨论一些很有用的选项。如果configure
失败,你将发送包含你认为能帮你解决该问题的“config.log”的邮件,如果configure
异常退出,也要包括configure
的最后几行输出。用mysqlbug
脚本邮寄错误报告。见2.3 怎样报告错误和问题。如果编译失败,见节4.8 编译问题?,帮助解决很多常见问题。 - 安装所有东西:
shell>make install
你可能需要
root
用户来运行这个命令。 - 创造MySQL授权表(只有你以前没安装MySQL是必需的):
shell>scripts/mysql_install_db
注意,在运行
mysql_install_db
时,那些比3.22.10旧的MySQL版本启动MySQL服务器。现在不是这样了! - 如果你想要安装对Perl
DBI
/DBD
接口的支持,见4.10 Perl安装注意说明。 - 如果你想要MySQL在你引导机器时自动地启动,你可以拷贝
support-files/mysql.server
到你的系统中有启动文件的地方。更多的信息可以在support-files/mysql.server
脚本里和4.15.3 自动启动和停止MySQL找到。
在所有东西安装完以后,你应该初始化并且测试你的分发。
你可以用下列命令启动MySQL服务器,这里BINDIR
是safe_mysqld
被安装的目录(缺省为“/usr/local/bin”):
shell> BINDIR/safe_mysqld &
如果这个命令提示mysqld daemon ended
并马上失败,那么你能在文件“mysql-data-directory/'hostname'.err”找到一些信息。可能的原因是你已经有另外一个正在运行的mysqld
服务器。见19.3 在同一台机器上运行多个MySQL服务器。
参见4.15 安装后期的设置与测试。
4.7.2 运用补丁
有时补丁出现在邮件列表上或放在MySQL FTP地点的补丁区。
为了使用来自邮件列表的一个补丁,保存补丁出现在文件的消息,进入你的MySQL源代码树的顶级目录并运行这些命令:
shell>patch - p1rm config.cache shell>make clean
来自FTP地点的补丁是作为普通文本文件或作为被压缩了的gzip
文件分发。运用一个文本的补丁如上述邮件列表补丁,为了使用一个压缩的补丁,进入你的MySQL源代码树顶级目录并运行这些命令:
shell>gunziprm config.cache shell>make clean
在使用一个补丁以后,按照正常的源代码安装的指令,开始./configure
步骤。在运行make install
后,重启你的MySQL服务器。
在运行make install
前,你可能需要关闭所有正在运行的服务器(使用mysqladmin shutdown
)。如果一个程序的新版本替代当前正在执行的版本,一些系统不允许你安装它。
4.7.3 典型的configure
选项
configure
脚本给你一个很大的控制权来如何配置你的MySQL分发。典型地,你使用configure
命令行的选项进行。你也可以用正确的环境变量作用于configure
。对于一个由configure
支持的选择列表,运行这个命令:
shell> ./configure -- help
一些更常用的configure
选项见下面的描述:
- 只编译MySQL客户库和客户程序而不是服务器,使用
--without-server
选项:shell> ./configure --without-server
如果你没有一个 C++ 编译器,
mysql
将不编译(有一个客户程序需要C++)。在这种情况下,你可以去掉configure
里面测试C++编译器的代码,然后运行带有--without-server
选项的./configure
。编译步骤步将仍然尝试构造mysql
,但是你可以忽略任何关于“ mysql.cc ”的警告。(如果make
停止,试试make -k
告诉它即使出错继续剩下的构造步骤)。 - 如果你不想要位于“/usr/local/var”目录下面的日志(log)文件和数据库,使用类似于下列
configure
命令的一个:shell>./configure--prefix=/usr/local/mysql shell>./configure--prefix=/usr/local --localstatedir=/usr/local/mysql/data
第一个命令改变安装前缀以便任何东西被安装在“/usr/local/mysql”下面而非缺省的“/usr/local”。第二个命令保留缺省安装前缀,但是覆盖了数据库目录缺省目录(通常是“/usr/local/var”)并且把它改/
usr/local/mysql/data
. - 如果你正在使用Unix并且你想要MySQL的套接字位于缺省地点以外的某个地方(通常在目录“/tmp”或“/var/run”,使用象这样的
configure
的命令:shell> ./configure -- with-unix-socket-path=/usr/local/mysql/tmp/mysql.sock
注意给出的文件必须是一个绝对路径!
- 如果你想编译静态链接程序(例如,制作二进制分发、获得更快的速度或与解决与RedHat分发的一些),像这样运行
configure
:shell>./configure --with-client-ldflags=-all-static --with-mysqld-ldflags=-all-static
- 如果你正在使用
gcc
并且没有安装libg++
或libstdc++
,你可以告诉configure
使用gcc
作为C++编译器:shell> CC=gcc CXX=gcc ./configure
当你使用时
gcc
作为C++编译器是,它将不试图链接libg++
或libstdc++
。如果构造失败并且产生有关编译器或链接器的错误,不能创建共享库“libmysqlclient.so.#”(“#”是一个版本号), 你可以通过为configure
指定--disable-shared
选项来解决此问题。在这种情况下,configure
将不构造一个共享libmysqlclient.so.#
库。 - 你可以设置MySQL对于非
NULL
的列不使用DEFAULT
列值(即,不允许列是NULL
)。这导致INSERT
语句产生一个错误,除非你明确地为所有要求非NULL
值的列指定值。为了禁止使用缺省值,这样运行configure
:shell> CXXFLAGS=-DDONT_USE_DEFAULT_FIELDS ./configure
- 缺省地,MySQL使用ISO-8859-1(Latin1)字符集。为了改变缺省设置,使用
--with-charset
选项目:shell> ./configure -- with-charset=CHARSET
CHARSET
可以是big5
、cp1251
、cp1257
、czech
、danish
、dec8
、dos
、euc_kr
、gb2312
gbk、german1
、hebrew
、hp8
、hungarian
、koi8_ru
、koi8_ukr
、latin1
、latin2
、sjis
、swe7
、tis620
、ujis
、usa7
、win1251
或win1251ukr
之一。见9.1.1 用于数据和排序的字符集。注意:如果你想要改变字符集,你必须在配置期间做make distclean
!如果你想在服务器和客户之间变换字符,你应该看一下SET OPTION CHARACTER SET
命令。见7.25SET OPTION
句法。警告:如果你在创建了任何数据库表之后改变字符集,你将必须对每个表运行myisamchk -r -q
,否则你的索引可能不正确地排序。(如果你安装了MySQL,创建一些表,然后重新配置MySQL使用一个不同的字符集并且重新安装它,这时就可能发生这种情况。) - 为了配置MySQL带有调试代码,使用
--with-debug
选项:shell> ./configure --with-debug
这导致包含一个安全的内存分配器,能发现一些错误和并提供关于正在发生的事情的输出。见G.1调试一个MySQL服务器。
- 属于特定系统的选项可在本章特定系统的小节里找到。见4.11 系统特定的问题。