扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
你需要下列工具构造并安装MySQL源代码:
gunzip
解压缩该分发。
tar
解包分发。GNU tar
已知可以工作。
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
程序。GNU make
总是被推荐且有时必须。如果你有问题,我们推荐试一试GNU make
3.75或更新。 如果你遇到问题,当向mysql@lists.mysql.com邮寄问题时,请一直使用mysqlbug
。就算问题不是一个bug,mysqlbug
收集系统信息,将有助于其它人解决你的问题。如果不使用mysqlbug
,你减少得到关你问题的一个解决方案的可能性!在你解包分发后,你会在“scripts”目录下找到mysqlbug
。见2.3 怎样报告错误或问题。
你必须执行的安装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 安装后期的设置与测试,进行安装后期的初始化与测试。
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
用户来运行这个命令。
shell>scripts/mysql_install_db
注意,在运行mysql_install_db
时,那些比3.22.10旧的MySQL版本启动MySQL服务器。现在不是这样了!
DBI
/DBD
接口的支持,见4.10 Perl安装注意说明。
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 安装后期的设置与测试。
有时补丁出现在邮件列表上或放在MySQL FTP地点的补丁区。
为了使用来自邮件列表的一个补丁,保存补丁出现在文件的消息,进入你的MySQL源代码树的顶级目录并运行这些命令:
shell>patch - p1 <patch-file-name shell>rm config.cache shell>make clean
来自FTP地点的补丁是作为普通文本文件或作为被压缩了的gzip
文件分发。运用一个文本的补丁如上述邮件列表补丁,为了使用一个压缩的补丁,进入你的MySQL源代码树顶级目录并运行这些命令:
shell>gunzip <patch-file-name.gz |patch - p1 shell>rm config.cache shell>make clean
在使用一个补丁以后,按照正常的源代码安装的指令,开始./configure
步骤。在运行make install
后,重启你的MySQL服务器。
在运行make install
前,你可能需要关闭所有正在运行的服务器(使用mysqladmin shutdown
)。如果一个程序的新版本替代当前正在执行的版本,一些系统不允许你安装它。
的configure
选项configure
脚本给你一个很大的控制权来如何配置你的MySQL分发。典型地,你使用configure
命令行的选项进行。你也可以用正确的环境变量作用于configure
。对于一个由configure
支持的选择列表,运行这个命令:
shell> ./configure -- help
一些更常用的configure
选项见下面的描述:
--without-server
选项: shell> ./configure --without-server
如果你没有一个 C++ 编译器,mysql
将不编译(有一个客户程序需要C++)。在这种情况下,你可以去掉configure
里面测试C++编译器的代码,然后运行带有 --without-server
选项的./configure
。编译步骤步将仍然尝试构造mysql
,但是你可以忽略任何关于“ mysql.cc ”的警告。(如果make
停止,试试make -k
告诉它即使出错继续剩下的构造步骤)。
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
.
configure
的命令: shell> ./configure -- with-unix-socket-path=/usr/local/mysql/tmp/mysql.sock
注意给出的文件必须是一个绝对路径!
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.#
库。
NULL
的列不使用DEFAULT
列值(即,不允许列是NULL
)。这导致INSERT
语句产生一个错误,除非你明确地为所有要求非NULL
值的列指定值。为了禁止使用缺省值,这样运行configure
: shell> CXXFLAGS=-DDONT_USE_DEFAULT_FIELDS ./configure
--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.25 SET OPTION
句法。警告:如果你在创建了任何数据库表之后改变字符集,你将必须对每个表运行myisamchk -r -q
,否则你的索引可能不正确地排序。(如果你安装了MySQL,创建一些表,然后重新配置MySQL使用一个不同的字符集并且重新安装它,这时就可能发生这种情况。)
--with-debug
选项: shell> ./configure --with-debug
这导致包含一个安全的内存分配器,能发现一些错误和并提供关于正在发生的事情的输出。见G.1调试一个MySQL服务器。
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者