ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

Web、Mail、Ftp、DNS、Proxy、VPN、Samba、LDAP 等基础网络服务
回复
cnLiuyix
帖子: 32
注册时间: 2010-02-01 22:08
联系:

ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#1

帖子 cnLiuyix » 2011-05-09 14:25

分享一下最近“折腾”ubuntu的成果吧。 :em09 (本文节选自我的blog

为什么要折腾?
首先说明的是ubuntu上安装mysql等软件是非常容易简单的,其简单的程度盖过windows上的安装,一句sudo apt-get install就可以搞定。如果想用最简便的方法安装mysql,那么本文不适合你;如果你喜欢“折腾”,有兴趣了解这一条sudo apt-get install帮你做了什么,有兴趣了解internal linux的细节并想尝试自己编译软件,那么你是本文的目标读者,希望你能从这篇文章中获得收获。

编译安装的几大步骤:
  1. 编译前的准备工作
  2. 初识CMAKE——配置MySQL编译选项
  3. 编译安装
  4. 安装后的MySQL配置
  5. 设置开机自动启动MySQL服务


一、编译前的准备工作
  • 官方网站下载Source Code(点此进入下载页)选择Source Code–>Generic Linux(mysql-VERSION.tar.gz)(PS:chrome访问此页,可能会遇到显示不正常的情况,建议换FF访问)
  • 建议有兴趣的童鞋读一读解压后的mysql目录下的相关文档,有许多重要的信息。比如此文以及大部分的类似文章都参考自INSTALL-SOURCE文档。
  • 创建mysql用户以及用户组,方便管理

    代码: 全选

    sudo groupadd mysql

    代码: 全选

    sudo useradd -r -g mysql mysql
二、初识CMAKE——配置MySQL编译选项
MySQL 5.5的编译工具由Autotool转变为了cmake(有关于更多关于cmake的信息,请大家自行google了解)。MySQL团队也撰写了一篇Autotools to CMake Transition Guide,本文将要列出的各个编译选项以及更多的编译选项的说明可以参考该文档。在troubleshooting时,此文档更是不得不看。编译时我习惯于一些选项(比如安装位置)不按默认的来,因为如果按默认选项出了问题,更不好解决(因为到时你不仅需要知道到底有选项有何含义还要知道默认的是什么,反而更麻烦)。进入解压的源代码目录mysql-VERSION

代码: 全选

cmake . \
-DCMAKE_INSTALL_PREFIX=/usr/mysql \
-DMYSQL_DATADIR=/usr/mysql/data
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
-DWITH_DEBUG=0 \
-DWITH_INNOBASE_STORAGE_ENGINE=1
一些主要的参数说明:
选项名称 选项含义
DCMAKE_INSTALL_PREFIX 安装路径
DMYSQL_DATADIR 数据库路径
DDEFAULT_CHARSET 默认字符
DDEFAULT_COLLATION 默认字符集
DMYSQL_UNIX_ADDR 连接数据库socket路径
DWITH_DEBUG bool值,表示是否开启debug模式
在这里我开始的时候有一个疏忽:只设置DDEFAULT_CHARSET而没有设置DDEFAULT_COLLATION,因此总是出现
COLLATION 'latin1_swedish_ci' is not valid for CHARACTER SET 'utf8'
三、编译安装

代码: 全选

sudo make
sudo make install
这个阶段出现的问题概率较小。但是记得一定要以root权限执行make和make install,因为填写的安装路径不是home,而是/usr,必须有root权限才能进行写操作

四、安装后的MySQL配置
出问题的地方主要是在这里。出现问题的根源在于配置文件以及默认配置。由于是源代码安装且安装的位置不是默认位置,因此有一些选项必须制定才能使MySQL正常运行
  1. 进入安装后的目录执行

    代码: 全选

    sudo chown -R mysql .

    代码: 全选

    chgrp -R mysql .

    代码: 全选

    sudo bin/scripts/mysql_install_db \
    --user=mysql \
    --basedir=/usr/mysql \
    --datadir=/usr/mysql/data \
    --no-defaults
  2. 切记后面有个–no-defaults选项,如果没有该选项,则程序会自动载入默认的配置文件,而目前你还没有完成配置文件的编写,因此很可能载入的是错误的信息。如果该指令能够运行成功,那么恭喜你,你的MySQLy可以成功的启动了。如果这一步出现了错误,不要着急,相关的log以及mysqld的启动信息提供了足够的信息帮助你trouble shooting(我就是这么过来的…)完成之后再执行

    代码: 全选

    chown -R root .
    chown -R mysql data
    这两条指令应该是安全性考虑。
  3. 配置my.cnf——mysql的配置文件,这是很重要的一步,配置得当以后就不需要在启动时写上大段的参数了。
    首先应该知道:MySQL寻找配置文件的路径以及顺序。最开始检索的位置是/etc/my.cnf之后是/etc/mysql/my.cnf因此我们要做的就是在这两个地方之一建立配置文件my.cnf。MySQL为我们准备了几种不同方案的默认配置文件(在/usr/mysql/support-files/中),因此我们可以复制一份到上述的位置

    代码: 全选

    sudo cp /usr/mysql/support-files/my-medium.cnf /etc/mysql/my.cnf
    通常我们是通过脚本传入适当的参数启动mysqld。因此在/etc/mysql/my.cnf中加入如下的内容:
    [mysqld]
    basedir=/usr/mysql
    datadir=/usr/mysql/data
    user=mysql
    更多关于my.cnf的配置限于篇幅就不再讲了,但为了日常的开发需要还应该继续配置的,这部分内容就参考google搜索以及MySQL Manual吧
五、设置开机自动启动MySQL服务
这一部分讲解如何添加MySQL在开机时自动启动。MySQL Manual关于此部分的内容不准确,没有涵盖debian类的linux发行版的做法。
MySQL已经提供了默认的脚本mysql.server(在[mysql安装目录]/support-files/),首先进入该目录,尝试运行该脚本

代码: 全选

sudo ./mysql.server start
运行正常的话则执行

代码: 全选

sudo cp mysql.server /etc/init.d/mysql
Debian/Ubuntu上开机启动服务的管理不是使用chkconfig,而使用的是sysv-rc-conf,尝试执行

代码: 全选

sudo sysv-rc-conf
若提示没有安装,则

代码: 全选

sudo apt-get install sysv-rc-conf
之后运行即可,该工具采用的是图形界面,很直观在此就不介绍如何使用了,我们需要做的是找到【mysql】一栏,选定【3】【4】【5】这三列,这样就完成了开机自动启动MySQL daemon了。

MySQL的安装就基本完成了,希望大家能和我一样在“折腾”的过程中有所收获,“痛并快乐着”!

原文链接:http://liuyix.com/install-mysql-on-ubun ... rom-source
I code.
liuyix.org
头像
退避九舍
帖子: 742
注册时间: 2010-08-08 20:02
系统: Ubuntu 22.04

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#2

帖子 退避九舍 » 2011-05-09 21:14

:em09 :em09
退避九舍:富贵不能淫,贫贱不能移,威武不能屈:坚持ubuntu不动摇!
levee
帖子: 3030
注册时间: 2009-10-03 23:31

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#3

帖子 levee » 2011-05-09 21:45

CMAKE还没接触过,有时间研究研究。

Mysql编译安装很有必要,甚至是必须的。

make不需要root权限,make install才需要,一般建议在/tmp下编译省得手动clean。

Debian/Ubuntu的启动管理比较麻烦,还是Arch这类BSD启动风格来得简单。
ubunran
帖子: 1
注册时间: 2011-05-30 9:29

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#4

帖子 ubunran » 2011-05-30 10:04

要是能配上使用文档就更好了
cowwen
帖子: 5
注册时间: 2011-05-13 13:57

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#5

帖子 cowwen » 2011-05-31 22:17

不错的文章,可以让新手折腾一下~~我装mysql装了一个星期
liuyt123
帖子: 21
注册时间: 2010-01-22 8:25

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#6

帖子 liuyt123 » 2011-06-17 9:19

本来想小白安装的 看了此文果断选择折腾了 :em05
cainiaogaofei
帖子: 16
注册时间: 2011-07-01 10:46

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#7

帖子 cainiaogaofei » 2011-07-08 10:01

我现在是只有痛,没有快乐!
lyyzh78
帖子: 10
注册时间: 2009-11-29 20:33

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#8

帖子 lyyzh78 » 2011-07-26 16:38

:em11 :em11 楼主威武 恩 我也正想折腾呢
wussrc
帖子: 8
注册时间: 2011-06-26 10:31

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#9

帖子 wussrc » 2011-07-31 2:58

谢了,折腾了好久了,终于按你这个方法装成功了。太麻烦了
以前在redhat下安装源码的mysql也没这么折腾,哎
头像
onpduo
帖子: 51
注册时间: 2009-07-23 22:22

Re: ubuntu 10.04 MySQL 5.5.11 源代码编译安装——详细过程——折腾手记

#10

帖子 onpduo » 2012-01-02 15:18

好文,我装在了/opt下,差点就废了 :em01
果断收藏之~
Back to Fedora from Archlinux...
吾辈乃水人一枚,潜水日久。
回复