Linux中用cmake编译mysql5.5数据库源码安装教程

MySQL自5.5版本以后,就开始使用cmake编译工具,所以这篇文章主要是讲解如何通过cmkae编译安装mysql5.5及其以后的版本。

注意本篇文章的环境为centos6.5 64bit。

cat /etc/system-release

uname -a

 

在安装mysql数据库之前,我们首先要在系统中新建mysql运行时的用户mysql。如下:

useradd -M -s /sbin/nologin mysql

grep mysql /etc/passwd

cat /etc/passwd |grep mysql

grep mysql /etc/group

 

注意useradd -M -s /sbin/nologin mysql,这条命令中的-M参数,该参数的意思是在创建用户时不为该用户创建其对应的家目录,-s /sbin/nologin表示该用户不能登陆到系统。

用户创建完毕后,我们现在来下载mysql5.5的软件包,使用如下命令:

wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.39.tar.gz

 

mysql5.5下载完毕后,我们现在开始安装mysql编译安装时,所需要的软件包。使用如下命令:

yum -y install gcc gcc-c++ cmake ncurses-devel libtool zilib-devel

 

注意其中cmkae软件包一定要安装,否则我们下面无法安装mysql5.5。

有关cmkae的相关释义,百度百科如下:

cmake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程)。它能够输出各种各样的makefile或者 project文件,能测试编译器所支持的C++特性,类似与UNIX下的automake。只是cmake的组态档取名为 cmakeLists.txt。

cmake并不直接建构出最终的软件,而是产生标准的建构档(如 Unix 的makefile 或 Windows Visual C++ 的 projects/workspaces),然后再依一般的建构方式使用。

 

以上所有软件安装完毕后,我们现在开始解压mysql5.5,使用如下命令:

tar -xvf mysql-5.5.39.tar.gz

 

查看解压后的文档,如下:

 

注意图中标记出来的cmkae目录。这个就是我们要安装是所需要的重要文件。

现在开始正式安装mysql5.5,使用如下命令进行配置mysql5.5.如下:

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql

 

注意这点就是与mysql5.5源码安装之前版本不同的地方。之前版本使用./configure进行配置。

同时还要说明下,-DCMAKE_INSTALL_PREFIX这个参数不容易记忆,但是不需要担心。其实mysql的安装文档已经给出相关的安装步骤。查看INSTALL-SOURCE安装文档。如下:

cat INSTALL-SOURCE |sed -n '5417,5438p'

该命令的作用是显示INSTALL-SOURCE文件5417到5438行之间的内容。

 

配置完毕后,现在开始编译mysql5.5,使用make命令。如下:

make

 

编译完毕后,开始安装mysql5.5,使用make install命令。如下:

make install

 

安装完毕后,我们现在还不能启动mysql数据库的,需要进行一些配置。

修改mysql运行目录的所属用户及用户组,使用如下命令:

chown mysql:mysql -R /usr/local/mysql/

 

为什么要修改呢?是因为mysql运行时,所使用的用户就mysql。

 

mysql运行目录的所属用户修改完毕后,我们还要初始化mysql数据库。

在mysql5.5的安装目录下执行如下的命令:

./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

注意该命令行中的--user=mysql表示运行mysql数据库时所使用的用户,--basedir=/usr/local/mysql表示mysql数据库说安装的位置,--datadir=/usr/local/mysql /data表示mysql数据库的数据文件存储的位置。

在执行该命令时,系统会提示你权限不够。如下:

 

查看mysql_install_db文件的相关权限,如下:

ll scripts/mysql_install_db

 

而且通过上图,我们可以很明显的看到mysql_install_db文件根本没有可执行权限。

我们需要给mysql_install_db文件配置可执行权限,如下:

chmod a+x ./scripts/mysql_install_db

 

权限配置完毕后,我们再次执行上述命令。如下:

./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

 

数据库初始化完毕后,我们还有两个工作要做。一是配置mysql的配置文件my.cnf。二是配置mysql启动文件。

my.cnf文件的内容,我们可以自己填写,也可以根据mysql安装文件中提供的模版进行修改。

该模版文件为support-files目录下的my-medium.cnf等几个文件。我们现在以my-medium.cnf文件为例,我们只需要复制该文件并重命名为my.cnf即可。如下:

cp support-files/my-medium.cnf /etc/my.cnf

 

复制完毕后,再次查看my.cnf文件,如下:

cat /etc/my.cnf |grep -v ^#|grep -v ^$

 

注意该命令中,grep -v ^#表示不显示以#开头的行,grep -v ^$表示不显示以空白开头行。

my.cnf文件配置完毕后,我们还要把support-files目录下的mysql.server文件复制到/etc/init.d/下并重命名为mysqld。mysqld就是把mysql作为服务启动的文件。如下:

cp support-files/mysql.server /etc/init.d/mysqld

 

通过上图我们可以发现,mysqld文件并没有执行权限。我们现在需要给其执行权限,如下:

chmod a+x /etc/init.d/mysqld

 

以上全部修改并配置完毕后,我们就可以启动mysql5.5数据库.

启动并查看如下:

/etc/init.d/mysqld start

ps aux |grep mysqld

netstat -tunlp |grep 3306

 

通过上图,我们可以看到mysql数据库已经成功启动。

下面我们登录mysql数据库看下,要使用mysql命令。我们需要把/usr/local/mysql/bin/路径加入到系统的环境变量中,否则mysql命令无法使用。如下:

 

现在把/usr/local/mysql/bin/路径加入到系统的环境变量中,如下:

echo $PATH

echo PATH=$PATH:/usr/local/mysql/bin >>/etc/profile

source /etc/profile

mysql -u root -p

 

通过上图,我们可以看到mysql命令已经可以正常使用。

到此mysql5.5的cmake源码安装就完毕了。

如果mysql客户端连接,mysql服务比较慢的话。我们需要在my.cnf文件中加入skip-name-resolve,如下:

 

时间: 2024-11-08 18:22:24

Linux中用cmake编译mysql5.5数据库源码安装教程的相关文章

Linux下MySQL-5.6的源码安装

本文主要介绍centos下源码安装MySQL 5.6的方法,centos的版本为5.8. 1)首先,你需要到MySQL官网下载源码tar包,点击MySQL Community Server,选择Source Code,源码包不大,只有 34M左右. 注:以下操作没有特殊说明,都是以root账户执行. 2)先安装cmake(mysql5.5以后源码安装都得通过cmake编译) # yum install cmake 并确保以下两个包已安装最新版: ncurses ncurses-devel 3)添

mysql-5.5.28源码安装过程中错误总结_Mysql

介绍一下关于mysql-5.5.28源码安装过程中几大错误总结,希望此文章对各位同学有所帮助.系统centOS 6.3 mini (没有任何编译环境)预编译环境首先装了众所周知的 cmake(yum install cmake -y) 复制代码 代码如下: ../bootstrap Error when bootstrapping CMake: Cannot find appropriate C compiler on this system. Please specify one using

mysql5.0数据库源码编译安装

本次实验的mysql.OS相关信息如下: Mysql:5.0.96 OS:centos 32 bit 最近公司要上新的业务,指明数据库使用的是mysql5.0版本.如果是使用rpm包安装的话,那就很简单了.直接使用yum安装即可,命令如下: yum –y install mysql mysql-server Yum方式安装完毕后,直接启动mysql数据库服务即可.如下图: 这样基本上就可以了. 但是这样安装mysql数据库,没有进行定制.比如mysql数据库的数据文件存储位置.rpm形式安装的数

mysql-5.5.28源码安装过程中几大错误总结

系统centOS 6.3 mini (没有任何编译环境) 预编译环境首先装了众所周知的 cmake(yum install cmake -y)  代码如下 复制代码 1../bootstrap Error when bootstrapping CMake: Cannot find appropriate C compiler on this system. Please specify one using environment variable CC. See cmake_bootstrap.

Linux MySQL源码安装缺少ncurses-devel包

在Red Hat Enterprise Linux Server release 5.7 上用源码安装MySQL-5.6.23时,遇到了" remove CMakeCache.txt and rerun cmake.On Debian/Ubuntu, package name is libncurses5-dev, on Redhat and derivates it is ncurses-devel."错误,如下所示 [root@DB-Server mysql-5.6.23]# cm

MySQL的源码安装及使用UDFs进行数据自动更新的教程_Mysql

MySQL的源码安装 1. 安装依赖组件 # yum install gcc gcc-c++ ncurses-devel perl -y 2. 安装cmake # wget http://www.cmake.org/files/v2.8/cmake-2.8.12.tar.gz # tar zxvf cmake-2.8.12.tar.gz # cd cmake-2.8.12 # ./bootstrap # make && make install 3. 安装bison # wget http

Debian8上源码安装MySQL5.6.19数据库方法

最近换了份新工作,以前一直接触的是CentOS操作系统,并且是RPM安装MySQL的,现在新公司使用Debian系统,并用源码安装MySQL,所以赶紧将新知识纪录下来== 安装编译软件cmake,make # 安装cmake apt-get install -y cmake # 安装make apt-get install -y make 获得MySQL源码 http://dev.mysql.com/downloads/mysql/ 创建MySQL根目录 # 创建MySQL根目录 mkdir -

Linux编译内核,内核源码在哪里?

Linux编译内核,内核源码在哪里? 1.一般在发行版的盘里都有,比如 RedHat,一般在第二.第三张上 2.4 内核的叫 kernel-source-2.4.xx-xx.rpm2.6 内核的叫 kernel-devel-2.6.xx-xx.rpm 2.去www.kernel.org 下载一份你喜欢的内核版本,重新编译安装也可以.

linux下mysql 5.5.38 源码安装笔记

接上一篇<linux下mysql 5.1.73 源码安装笔记>,继续安装一个mysql 5.5.38 版.同样使用源码安装.并且实现两个实例同时运行,互不冲突. 这篇笔记记录的简单些,省略一些和上篇笔记相同的步骤. 第一步,下载: mysql 5.5.38官方下载地址: http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.38.tar.gz df5071c49764c3ad65df04ff20866a86 解压的步骤就不重复了. 第二步