CentOS 6.4 源码安装MySQL 5.6
1、安装前准备工作
1.1 必备的包
gcc/g++ :MySQL 5.6开始,需要使用g++进行编译。
cmake  :MySQL 5.5开始,使用cmake进行工程管理,cmake需要2.8以上版本。
bison  :MySQL语法解析器需要使用bison进行编译。
ncurses-devel :用于终端操作的开发包。
1.2 MySQL编译参数
CMAKE_BUILD_TYPE            编译的版本类型:RelWithDebInfo和Debug,不同之处是RelWithDebInfo会进行优化。
CMAKE_INSTALL_PREFIX        指定make install安装的目标路径。
SYSCONFDIR                  指定配置文件的默认路径。
MYSQL_DATADIR              指定data目录的默认路径。
WITH_DEBUG                  指定是否有debugging信息,一般用于源码调试时,打开WITH_DEBUG,生产环境关闭。
ENABLED_PROFILING          指定是否可以使用show profile显示操作执行的详细信息。
DEFAULT_CHARSET            指定默认字符集,可以在启动的配置文件中指定。
DEFAULT_COLLATION          指定默认字符比较、排序的规则。
WITH_EXTRA_CHARSETS        指定其他可能使用的字符集。
WITH_SSL                    指定SSL的类型,从5.6.6开始默认bundled类型,此外也可以指定SSL库的路径地址。
WITH_ZLIB                  指定zlib的类型,用于压缩功能。
ENABLED_LOCAL_INFILE        指定是否允许使用load data infile功能。
WITH_EMBEDDED_SERVER        指定是否编译libmysqld嵌入式库。
INSTALL_LAYOUT              指定安装的布局类型。
WITH_storage_STORAGE_ENGINE 指定编译支持的存储引擎,默认支持MyISAM,MERGE,MEMORY,CSV存储引擎。
1.3 本次安装环境
服务器版本:CentOS 6.4
		MySQL版本:5.6.24.tar.gz
		安装目录为:/app/soft/mysql
		数据目录为:/data/mysqldata 
		存储引擎包括:MEMORY,MyISAM,InnoDB等 
		字符集为:UTF8
2、源码安装MySQL 
  
2.1 先安装需要用到的库:
yum -y install gcc gcc-c++
yum -y install ncurses-devel
2.2 下载所需软件包:
  #将下载的文件都放到/usr/local/src目录下,如下
  # cd /usr/local/src
  # wget http://www.cmake.org/files/v3.2/cmake-3.2.0.tar.gz
  # wget http://ftp.gnu.org/gnu/bison/bison-2.7.tar.gz
  # wget http://ftp.gnu.org/gnu/m4/m4-1.4.16.tar.gz
  # wget http://www.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.24.tar.gz/from/http://cdn.mysql.com/
安装cmake编译器
  # cd /usr/local/src
  # tar -xvf cmake-3.2.0.tar.gz
  # cd cmake-3.2.0
  # ./bootstrap
  # make && make install
安装m4
# cd /usr/local/src
# tar -xvf m4-1.4.16.tar.gz
# cd m4-1.4.16
# ./configure && make && make install
安装bison
# cd /usr/local/src
# tar -xvf bison-2.7.tar.gz
# cd bison-2.7
# ./configure && make && make install
创建mysql用户与组,相关目录
# /usr/sbin/groupadd mysql
# /usr/sbin/useradd -g mysql mysql
# mkdir -p /app/soft/mysql
# chown -R mysql:mysql /app/soft/mysql
# mkdir -p /data/mysqldata
# chown -R mysql:mysql /data/mysqldata/
安装mysql
# cd /usr/local/src
# tar -xvf mysql-5.6.12.tar.gz 
# export CFLAGS="-O3 -g -fno-exceptions -static-libgcc
-fno-omit-frame-pointer -fno-strict-aliasing"
# export CXXFLAGS="-O3 -g -fno-exceptions -fno-rtti -static-libgcc
-fno-omit-frame-pointer -fno-strict-aliasing"
# export CXX=g++
# cd mysql-5.6.12
# cmake -DCMAKE_INSTALL_PREFIX=/app/soft/mysql
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock 
-DDEFAULT_CHARSET=utf8 
-DDEFAULT_COLLATION=utf8_general_ci 
-DWITH_EXTRA_CHARSETS=utf8
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 
-DWITH_FEDERATED_STORAGE_ENGINE=1 
-DWITH_PARTITION_STORAGE_ENGINE=1 
-DWITH_ARCHIVE_STORAGE_ENGINE=1 
-DMYSQL_DATADIR=/data/mysqldata/ 
-DSYSCONFDIR=/app/soft/mysql/ 
-DWITH_SSL=bundled 
-DENABLED_LOCAL_INFILE=1 
-DWITH_INNOBASE_STORAGE_ENGINE=1 
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 
-DENABLE_DOWNLOADS=1
注意事项:
重新编译时,需要清除旧的对象文件和缓存信息。
# make clean
# rm -f CMakeCache.txt
# rm -rf /etc/my.cnf
# make && make install
初始化数据库
# cd /app/soft/mysql/
# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldata
3、安装后的收尾工作
配置运行环境
# vi /etc/profile
# PATH=/app/soft/mysql/bin:/app/soft/mysql/lib:$PATH
# export PATH
# source /etc/profile
创建开机启动
# cp support-files/my-default.cnf /etc/my.cnf  //也可以将my.cnf直接复制到安装文件位置
# cp support-files/mysql.server /etc/init.d/mysqld 
# chkconfig --level 35 mysqld on  //开机启动
# service mysqld start
修改my.cnf 配置文件
注意启动失败
检查存储数据库数据的目录 /data/mysqldata 的权限,如果是root.root,需要修改为mysql.mysql
检查配置文件/etc/my.cnf对于 datadir参数的配置是否为:/data/mysqldata
登陆账号,首次登录无须密码
# mysql -uroot -p
如果报mysql:
command not found
原因:这是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下,当然会找不到命令,我们需要做的就是映射一个链接到/usr/bin目录下,相当于建立一个链接文件。
首先得知道mysql命令或mysqladmin命令的完整路径,比如mysql的路径是:/usr/local/mysql/bin/mysql,我们则可以这样执行命令:
# ln -s /usr/local/mysql/bin/mysql /usr/bin
本随笔主要参考:http://www.linuxidc.com/Linux/2013-07/87640.htm
CentOS 6.4 源码安装MySQL 5.6的更多相关文章
- CentOS 7下源码安装MySQL 5.7
		
网上说linux安装mysql服务分两种安装方法: ①源码安装,优点是安装包比较小,只有几十M左右,缺点是安装依赖的库多,安装编译时间长,安装步骤复杂容易出错: ②使用官方编译好的二进制文件安装,优点 ...
 - CentOS 7下源码安装MySQL 5.6
		
本文转载,并非原创. 目录 准备工作 运行环境 确认你的安装版本 下载MySQL 安装MySQL 准备安装环境 编译和安装 配置MySQL 单实例配置 单实例配置方法 添加防火墙 启动MySQL 重启 ...
 - CentOS 6.8 源码安装mysql 5.6
		
一:卸载旧版本 rpm -qa | grep mysql rpm -e mysql #普通删除模式 rpm -e --nodeps xxx(xxx为刚才的显示的列表) # 强力删除模式,如果使用上面命 ...
 - centos 6x系统下源码安装mysql操作记录
		
在运维工作中经常部署各种运维环境,涉及mysql数据库的安装也是时常需要的.mysql数据库安装可以选择yum在线安装,但是这种安装的mysql一般是系统自带的,版本方面可能跟需求不太匹配.可以通过源 ...
 - Centos7源码安装mysql及读写分离,互为主从
		
Linux服务器 -源码安装mysql 及读写分离,互为主从 一.环境介绍: Linux版本: CentOS 7 64位 mysq版本: mysql-5.6.26 这是我安装时所使用的版本, ...
 - centos 6.4 源码安装php5.4 mysql5.5 apahce2
		
centos 6.4 源码安装php5.4 mysql5.5 apahce2 博客分类: php 参考:http://blog.csdn.net/simpleiseasy/article/deta ...
 - lnux下源码安装MySQL 5.6
		
nux下源码安装MySQL 5.6 说明:本文是我自己测试的MySQL5.6源码安装,经本人亲自实践,完全可用,另在5.6之前的版本也是可以按照本文源码安装的.我是在两台linux下一台安装5.5,另 ...
 - Linux平台下源码安装mysql多实例数据库
		
Linux平台下源码安装mysql多实例数据库[root@linux-node1 ~]# netstat -tlunp | grep 330tcp6 0 0 :::3306 :::* LISTEN 6 ...
 - 源码安装mysql,及主从同步
		
源码安装mysql [可选] 如果用源码安装cmake软件: cd /home/oldboy/tools/ tar xf cmake-.tar.gz cd cmake- ./configure #CM ...
 
随机推荐
- D. Equalize Them All  Codeforces Round #550 (Div. 3)
			
D. Equalize Them All time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
 - UVA1354-Mobile Computing(二进制枚举子集)
			
Problem UVA1354-Mobile Computing Accept:267 Submit:2232 Time Limit: 3000 mSec Problem Description ...
 - jira8.0.2安装与破解
			
环境: centos7.4 java1.8 jira版本:8.0.2 mysql :mariadb 软件下载: 破解包: atlassian-extras-3.2.jar 连接mysql驱动: mys ...
 - 【编辑器】sublime 标题栏中文乱码问题
			
首选项--------设置-用户中添加"dpi_scale": 1.0,如下图所示 作者:smile.轉角 QQ:493177502
 - VS2015中配置Eigen
			
Eigen非常方便矩阵操作,当然它的功能不止如此.矩阵操作在算法研究过程中,非常重要,例如在图像处理中二维高斯拟合求取光斑中心时使用Eigen提供的矩阵算法,差不多十来行代码即可实现. 1)下载Eig ...
 - day12--装饰器
			
定义(如何理解装饰器):装饰器本生是闭包函数的一种应用,是指在不改变原函数的情况下为原函数添加新的功能的一个函数.它把被装饰的函数作为外层函数的参数传入装饰器,通过闭包操作后返回一个替代版函数. 遵循 ...
 - Flask框架简介,常用扩展包及两大核心
			
Flask诞生于2010年,是Armin ronacher(人名)用 Python 语言基于 Werkzeug 工具箱编写的轻量级Web开发框架. Flask 本身相当于一个内核,其他几乎所有的功能都 ...
 - 使用java实现快速排序(挖坑填数法和指针交换法)
			
快速排序:通过一趟排序,将数据分为两部分,其中一部分中的所有数据比另外一部分的所有数据要小,然后按照此方法,分别对这两部分进行排序,达到最终的排序结果. 每趟排序选取基准元素,比该基准元素大的数据放在 ...
 - linux防火墙开放和禁用指定端口
			
一.例如:开放8080端口 firewall-cmd --permanent --add-port=8080/tcp 二.重启使设置生效 systemctl restart firewalld.ser ...
 - bsxfun, arrayfun, cellfun, spfun, structfun
			
在使用matlab进行矩阵计算的时候,经常会遇到要使用for循环的情况.但其实很多操作可以用内部的一些函数代替.今天总结一些几个函数的用法: bsxfun, arrayfun, cellfun, sp ...