zoukankan      html  css  js  c++  java
  • CentOS下编译安装MySQL 5.6.21

    一、编译安装MySQL前的准备工作

    安装编译源码所需的工具和库

    yum install gcc gcc-c++ ncurses-devel perl  

    安装cmake:http://www.cnblogs.com/jiu0821/p/5680830.html

    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 cmake-2.8.10.2   
    ./bootstrap ; gmake ; gmake install  

    二、设置MySQL用户和组

    新增mysql用户组

    groupadd mysql  

    新增mysql用户

    useradd -r -g mysql mysql  

    三、新建MySQL所需要的目录

    新建mysql安装目录

    mkdir -p /usr/local/mysql  

    新建mysql数据库数据文件目录

    mkdir -p /data/mysqldb  

    四、下载MySQL源码包并解压

     源码下载地址:http://download.csdn.net/detail/jiu12jiu/9579834

    tar -zxv -f mysql-5.6.21.tar.gz  
    cd mysql-5.6.21  

    五、编译安装MySQL

    从mysql5.5起,mysql源码安装开始使用cmake了,设置源码编译配置脚本。

    设置编译参数

    # cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 
    > -DDEFAULT_CHARSET=gbk 
    > -DDEFAULT_COLLATION=gbk_chinese_ci 
    > -DENABLED_LOCAL_INFILE=ON 
    > -DWITH_INNOBASE_STORAGE_ENGINE=1 
    > -DWITH_FEDERATED_STORAGE_ENGINE=1 
    > -DWITH_BLACKHOLE_STORAGE_ENGINE=1 
    > -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock 
    > -DWITH_DEBUG=0 
    > -DMYSQL_TCP_PORT=3306

    解释说明:

    -DCMAKE_INSTALL_PREFIX=dir_name 设置mysql安装目录
    -DMYSQL_UNIX_ADDR=file_name 设置监听套接字路径,这必须是一个绝对路径名。默认为/tmp/mysql.sock
    -DDEFAULT_CHARSET=charset_name 设置服务器的字符集。
    缺省情况下,MySQL使用latin1的(CP1252西欧)字符集。cmake/character_sets.cmake文件包含允许的字符集名称列表。
    -DDEFAULT_COLLATION=collation_name 设置服务器的排序规则。
    -DWITH_INNOBASE_STORAGE_ENGINE=1 
    -DWITH_ARCHIVE_STORAGE_ENGINE=1
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 
    -DWITH_PERFSCHEMA_STORAGE_ENGINE=1
    存储引擎选项:

    MyISAM,MERGE,MEMORY,和CSV引擎是默认编译到服务器中,并不需要明确地安装。

    静态编译一个存储引擎到服务器,使用-DWITH_engine_STORAGE_ENGINE= 1

    可用的存储引擎值有:ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE (InnoDB), PARTITION (partitioning support), 和PERFSCHEMA (Performance Schema)
    -DMYSQL_DATADIR=dir_name 设置mysql数据库文件目录
    -DMYSQL_TCP_PORT=port_num 设置mysql服务器监听端口,默认为3306
    -DENABLE_DOWNLOADS=bool 是否要下载可选的文件。例如,启用此选项(设置为1),cmake将下载谷歌所使用的测试套件运行单元测试。















    注:若重新运行配置,需要删除CMakeCache.txt文件;否则,略去下步。

    rm -f CMakeCache.txt  

    编译源码

    make

    安装

    make install

    六、修改mysql目录所有者和组

    修改mysql安装目录

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

    修改mysql数据库文件目录

    cd /data/mysqldb  
    chown -R mysql:mysql . 

    七、初始化mysql数据库

    特别提醒:这一步往往都会失败,说是什么权限不够,本质上是源码问题。两种错误可能:一者,源码本身有误,建议更换源码重新编译安装(我就这么做的,上面提供的源码是经过我测试通过的);二者,操作有误,切记不要自行把mysql源码目录名字mysql-5.6.21改为mysql,在该目录下编译安装,源码与生成的代码混在一起,又怎么可能不出问题呢,严格按照步骤来,自然不出现问题。

    cd /usr/local/mysql   
    scripts/mysql_install_db --user=mysql --datadir=/data/mysqldb  

    八、复制mysql服务启动配置文件

    cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf  

    注:如果/etc/my.cnf文件存在,则覆盖。

    九、复制mysql服务启动脚本及加入PATH路径

    cp support-files/mysql.server /etc/init.d/mysqld   
      
    vim /etc/profile   
      
          PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH  
      
          export PATH  
      
    source /etc/profile  

    十、启动mysql服务并加入开机自启动(可选这个步骤,以后可以自己启动的)

    service mysqld start
    chkconfig --level 35 mysqld on

    注:如果这里出错,下面有一些错误的对应解决方案,莫要着急。

    十一、检查mysql服务是否启动

    netstat -tulnp | grep 3306   
    mysql -u root -p   

    密码为空,如果能登陆上,则安装成功。

    十二、修改MySQL用户root的密码

    mysqladmin -u root password '123456'   

    注:也可运行安全设置脚本,修改MySQL用户root的密码,同时可禁止root远程连接,移除test数据库和匿名用户。

    /usr/local/mysql/bin/mysql_secure_installation 

    十三、可能会出现的错误

        问题:   
        Starting MySQL..The server quit without updating PID file ([FAILED]/mysql/Server03.mylinux.com.pid).   
        解决:   
        修改/etc/my.cnf 中datadir,指向正确的mysql数据库文件目录  
        问题:   
        ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)   
        解决:   
        新建一个链接或在mysql中加入-S参数,直接指出mysql.sock位置。   
        ln -s /usr/local/mysql/data/mysql.sock /tmp/mysql.sock   
          
        /usr/local/mysql/bin/mysql -u root -S /usr/local/mysql/data/mysql.sock  
        MySQL问题解决:-bash:mysql:command not found  
        因为mysql命令的路径在/usr/local/mysql/bin下面,所以你直接使用mysql命令时,  
        系统在/usr/bin下面查此命令,所以找不到了   
           解决办法是:  
         ln -s /usr/local/mysql/bin/mysql /usr/bin 做个链接即可  
  • 相关阅读:
    [转]HTML5 classList API
    高质量CSS编写规范
    CSS Hack
    谈谈JSON数据格式
    Eclipse启动时报需要安装"Java SE 6 Runtime"致无法启动解决方案
    站长问题纠结
    做站长的经验
    网站如何提高PR值
    Progit Update Check Page
    WPF随手小记之二 ——改变DataGrid样式
  • 原文地址:https://www.cnblogs.com/jiu0821/p/5683524.html
Copyright © 2011-2022 走看看