zoukankan      html  css  js  c++  java
  • 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

      

  • 相关阅读:
    批量下载文件方法
    批量下载文件技术
    批量下载文件插件
    Java实现 LeetCode 539 最小时间差(单位转换)
    Java实现 LeetCode 535 TinyURL 的加密与解密(位运算加密)
    2018-8-10-git-提交添加-emoij-文字
    2018-8-10-git-提交添加-emoij-文字
    2018-8-10-win10-uwp-使用-Geometry-resources-在-xaml
    【树莓派】树莓派4无痛安装系统(NOOBS篇)
    SSH流量转发的姿势
  • 原文地址:https://www.cnblogs.com/Latiny/p/5894467.html
Copyright © 2011-2022 走看看