编译安装MySQL实记

版本号:5.1.72
OS:RHEL6.5
安装方式:源码编译安装
过程:
1. 访问http://www.mysql.com/downloads/,选择MySQL Community Server,Select Platform中选择source code,下载Generic Linux下的mysql-5.1.72.tar.gz文件。
2. 上传mysql-5.1.72.tar.gz到服务器,解压。
3. 进入解压得到的目录里,在该路径下运行以下命令:

./configure --prefix=/usr/local/mysql --with-charset=utf8 \ 默认字符集
--with-extra-charsets=all \ 安装额外的字符集
--with-unix-socket-path=/share/data/mysql.sock \ 使用套接字
--with-named-curses-libs=/lib64/libncursesw.so.5

注:
1)需要事先安装一些编译需要的软件:

yum install gcc gcc-c++ perl
yum install cmake

(从5.6.10开始,MySQL使用CMAKE替代了configure安装方式,因此对于5.1.72来说,这个软件包可能并不需要,待考证)

yum install ncurses-devel

(--with-named-curses-libs=/lib64/libncursesw.so.5 据说不指定该参数,编译安装会失败,该库文件由ncurses-devel软件包提供)
2)/share/data是我计划放置数据库的目录,为了方便查找和启用,这里将通信用的套接字目录也指定到了这里。

3)(很关键)前几次的编译安装结束后,我在登录MySQL时出现了问题,提示段错误 (Segmentation fault),后来在网上查找了一个方法,需要对源码包中一个文件进行修改并重新编译安装,之后再次登录就没有遇到这个错误了:

1. 在源码包里,编辑文件 cmd-line-utils/libedit/terminal.c
2. 找到代码段类似 char buf[TC_BUFSIZE]; 的,将其注释,并找到下面的变量 area = buf; 
将其更改为 area = NULL;
更正后的代码类似:
865 protected int
866 terminal_set(EditLine *el, const char *term)
867 {
868 int i;
869 /*char buf[TC_BUFSIZE];*/
870 char *area;
871 const struct termcapstr *t;
872 sigset_t oset, nset;
873 int lins, cols;
874
875 (void) sigemptyset(&nset);
876 (void) sigaddset(&nset, SIGWINCH);
877 (void) sigprocmask(SIG_BLOCK, &nset, &oset);
878
879 area = NULL;
该方法来自http://www.111cn.net/database/mysql/79897.htm

4. make && make install
5. MySQL 5.1.72编译安装完成,接下来是启动MySQL服务和初始化数据库:
建议使用系统用户mysql来启停mysql服务,因此需要在操作系统中添加mysql用户和mysql组,并将mysql安装位置和数据库存放位置的目录属主属组修改为mysql:

chown -R mysql:mysql /usr/loca/mysql
chown -R mysql:mysql /share/data/

6. 进入/usr/local/mysql/,进行数据库初始化操作:

/usr/local/mysql/bin/mysql_install_db --basedir=/usr/local/mysql/ \ prefix 
--datadir=/share/data/ \ 数据库所在位置
--user=mysql \ 使用mysql用户启停mysql服务

7. 启动mysql服务

/usr/local/mysql/bin/mysqld_safe --basedir=/usr/local/mysql --datadir=/share/data --user=mysql &

8. 查看进程和端口,验证是否安装成功:

# /usr/local/mysql/bin/mysql -uroot -p
Enter password: \ 此时不需要输入密码
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.1.72 Source distribution
Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.
mysql>

出现提示符,安装成功。

注:
1)进入源码所在目录下的support-files目录下,查找*.cnf名称的文件,这是mysql提供的不同运行环境的配置文件,拷贝一个合适的到/etc/下,命名为默认的配置文件my.cnf:

cp ~/mysql-5.1.72/support-files/my-small.cnf /etc/my.cnf

有必要对/etc/init.d/mysqld中的相关变量值进行修改或指定,如修改如下项:

[client]
socket          = /share/data/mysql.sock
[mysqld]
socket          = /share/data/mysql.sock

2)该目录下还有一个mysql.server文件,该文件是mysql提供的LSB脚本,可以将其拷贝到/etc/init.d/下,重命名为mysqld:

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

有必要对/etc/init.d/mysqld中的相关变量值进行修改或指定,如修改如下项:

basedir=/usr/local/mysql/
datadir=/share/data/

后记:

1. 可以将datadir指定为共享目录提供给多台mysql服务器来使用,此时只需在一台机器上运行mysql_install_db操作,其他服务器即可以通过mysql服务进行访问。

2. 编译安装一次不成功很正常,多次尝试终会成功。

时间: 2024-08-07 05:58:58

编译安装MySQL实记的相关文章

手工编译安装mysql数据库服务

实验要求:手工编译安装mysql数据库服务 实验步骤: 首先挂载并且建立yum仓库,查看yum有没有建好,在创建lamp文件 然后把宿主机的LAMP共享文件夹挂载到lamp目录下 将mysql归档包解压到/opt目录下 安装 gcc . gcc-c++. make .cmake(编译).后面都是开发包ncurses-devel.bison.libaio-devel的软件包(gcc . gcc-c++用yum装,其他用rpm装),在查看下有没有安装make 和cmake,诶有就安装 添加一个叫做m

CentOS 6.5最小化编译安装mysql 5.5.35

1.关闭防火墙: [[email protected] ~]# service iptables stop iptables: Setting chains to policy ACCEPT: filter          [  OK  ] iptables: Flushing firewall rules:                         [  OK  ] iptables: Unloading modules:                               [

CentOS 6.5最小化编译安装mysql 5.5.35配置多实例

1.关闭防火墙 [[email protected] ~]# service iptables stop iptables: Setting chains to policy ACCEPT: filter          [  OK  ] iptables: Flushing firewall rules:                         [  OK  ] iptables: Unloading modules:                               [ 

Cmake编译安装mysql

在实际应用中,大多数公司一般都会采用编译安装mysql 下载地址:http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.22.tar.gz/ 系统环境:CentOS 6.7 finall 1,安装所需要的依赖包 yum install -y ncurses-devel.x86_64 yum install -y cmake.x86_64 yum install -y libaio.x86_64 yum install -y bison.x8

Linux CentOS6.5下编译安装MySQL 5.6.16【给力详细教程】

一.编译安装MySQL前的准备工作 安装编译源码所需的工具和库 [sql] view plaincopy yum install gcc gcc-c++ ncurses-devel perl 安装cmake,从http://www.cmake.org下载源码并编译安装 [sql] view plaincopy wget http://www.cmake.org/files/v2.8/cmake-2.8.10.2.tar.gz tar -xzvf cmake-2.8.10.2.tar.gz cd 

CentOS 6.4下编译安装MySQL 5.6.16

一.卸载旧版本MySql 1.rpm卸载: 1> 检查安装包: rpm -qa | grep mysql 2> 普通删除: rpm -e mysql-5.6.16.rpm 3> 强力删除.如果使用上面命令删除时,提示有依赖的其他文件,则使用该命令可以对其进行强力删除. rpm -e --nodeps mysql-5.6.16.rpm 2.tar卸载: 1> 删除临时文件: make clean 2> 卸载 make uninstall 3> 删除解压文件 rm  -rf

linux学习笔记——源码编译安装Mysql

#######Redhat6.5源码编译安装Mysql########实验环境:1.IP:172.25.8.32.磁盘要大于20G先添加一块大于20G的磁盘fdisk /dev/vdb        ##得到/dev/vdb1 8e linuxpvcreate /dev/vdb1    ##把物理分区做成物理卷vgextend vg_server1 /dev/vdb1    ##把新建立的/dev/vdb1添加到vg_server1中lvextend -L 20G /dev/vg_server1

编译安装mysql

编译安装mysql源码包和多实例登录 1.编译安装mysql 1)首先查看这个包是否安装 [[email protected] ~]# rpm -qa ncurses-devel libaio-devel [[email protected] ~]# 2)如果没有安装请安装 yum install ncurses-devel libaio-devel -y 3)安装cmake编译命令 yum install cmake -y 4)创建mysql虚拟用户不指定家目录 user add mysql-

CentOS源码编译安装MySQL 5.5.15

CentOS源码编译安装MySQL 5.5.15 文章目录 [隐藏] 安装编译工具 下载源码 安装cmake和bison 编译安装MySQL 一些相关设置 安装编译工具 yum install gcc gcc-c++ yum install ncurses-devel 下载源码 mkdir -p /tmp cd /tmp wget http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.15.tar.gz/from/http://mysql.