centos6.6安装MySQL5.5

 

使用系统CentOS 6.6本来已经系统自带安装了mysql 5.1,但是奈何5.1不支持utf8mb4字符集(详见:http://blog.csdn.net/shootyou/article/details/8236024),只能想办法将Mysql升级到5.5。

安装如下方法可以安装成功。

完整步骤:

1.首先备份数据,虽说成功的升级数据不会丢失,但是保险起见备份下。

  1. mysqldump -u xxx -h xxx -P 3306 -p --all-databases > databases.sql  

最好连数据文件和配置文件也备份一份。

  1. cp -R /data/mysql mysql-5.1-data  
  2. cp /etc/my.cnf my.cnf-5.1  

备份完之后停止mysql服务。

  1. service mysqld stop  

好了,开始进入正题。

2.卸载旧版本的Mysql

  1. yum remove mysql mysql-*  

执行之后再看看是不是残余一些mysql-libs之类的

  1. yum list installed | grep mysql  

如果有,并确认没用之后也可以删除。

  1. yum remove mysql-libs  

注意删除mysql-libs可能会对一些依赖软件产生影响,这里我们不讨论。

好了,卸载的动作基本结束。

3.安装Mysql5.5

如果你不偷懒,那么选择编译安装可能会更好,可以参考:http://my.oschina.net/laiwanshan/blog/72903

这里我们讨论使用yum安装的过程。

在走了N多弯路之后我发现需要首先安装一些新的repo。

  1. rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm  
  2. rpm -Uvh http://mirrors.neusoft.edu.cn/epel/6/i386/epel-release-6-8.noarch.rpm  
  3. rpm -Uvh http://packages.sw.be/rpmforge-release/rpmforge-release-0.5.2-2.el6.rf.x86_64.rpm  
  4. rpm -Uvh http://dl.iuscommunity.org/pub/ius/stable/Redhat/6/x86_64/epel-release-6-5.noarch.rpm  
  5. rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-6.rpm  

这个时候你再运行:

  1. yum --enablerepo=remi,remi-test info mysql mysql-server  

就会发现mysql的版本已经是5.5.x了。毫不犹豫安装之。

  1. yum --enablerepo=remi,remi-test install mysql mysql-server  

安装到此结束。接下来是启动和升级。 4.启动和升级

 

这个时候你想直接启动十有八九会报错,主要的问题两块:一是配置文件,5.5相比5.1有些配置改名了,这个需要你对照启动错误日志一点点改进。二是没有执行mysql_upgrade。

在确保配置文件没问题之后运行:

 

在测试环境中安装后是能够顺利启动的,所以按照本博中centos安装amp中mysql安装中的章节进行相应设置就可以了。

  1. mysql_upgrade -u root -p  

等他全部ok。

再试试运行mysql。

  1. service mysqld start  

希望上帝保佑你看到的是绿色的[ok]。

 

如果你需要从CentOS 5上升级Mysql那么你可以参考:http://www.ha97.com/4145.html,但是注意这个只适用于CentOS 5,我一开始就是被这个误导了耽误了半天时间。

其他参考:

http://blog.iphoting.com/blog/2012/06/19/upgrading-to-mysql-5-dot-5-on-centos-6/

http://stackoverflow.com/questions/9361720/update-mysql-version-from-5-1-to-5-5-in-centos-6-2

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。