环境:
1、操作系统:CentOS release 6.8 (Final)
2、安装版本: mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz
3、下载地址:http://dev.mysql.com/downloads/mysql/
4、下载说明:上边的下载地址是最新版的,如果想下载老版本可以点击页面中的超链接“Looking for previous GA versions?”
5、特殊说明:Linux下MySQL5.6与MySQL5.7安装方法略有不同,本文以5.6为主
安装步骤
0、卸载老版本MySQL
查找并删除mysql有关的文件
find / -name mysql rm -rf 上边查找到的路径,多个路径用空格隔开 #或者下边一条命令即可 find / -name mysql|xargs rm -rf
data:image/s3,"s3://crabby-images/1596b/1596b03a9c1e6e5bd079a847bf103bd9fed5c31a" alt=""
1、在安装包存放目录下执行命令解压文件:
tar -zxvf mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz
data:image/s3,"s3://crabby-images/1931d/1931d08c7c0612dc81e4b3ccd2bc4e902f080534" alt=""
2、删除安装包,重命名解压后的文件
rm -f mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz mv mysql-5.6.31-linux-glibc2.5-x86_64/ mysql
data:image/s3,"s3://crabby-images/b9586/b9586a887c6b9d580b6c41cd1349344753fd8ff1" alt=""
3、添加mysql用户组和mysql用户
先检查是否有mysql用户组和mysql用户
groups mysql
data:image/s3,"s3://crabby-images/2b57f/2b57fdb924b4074246979862ec3197384292fb02" alt=""
若无,则添加;
groupadd mysql useradd -r -g mysql mysql
data:image/s3,"s3://crabby-images/d783f/d783f45971a5d57abe2768e1d115220e3c260c86" alt=""
若有,则跳过;
data:image/s3,"s3://crabby-images/6be07/6be074585f592316fb7a6900d2f7b7858bde79fc" alt=""
4、进入mysql目录更改权限
cd mysql/ chown -R mysql:mysql ./
data:image/s3,"s3://crabby-images/80c1c/80c1cb4d63a4ea0c36cc9dcc279ed31ece499c88" alt=""
5、执行安装脚本
./scripts/mysql_install_db --user=mysql
data:image/s3,"s3://crabby-images/ca149/ca149cb798c42ceda329de049a3ba65890bdc3a6" alt=""
安装完之后修改当前目录拥有者为root用户,修改data目录拥有者为mysql
chown -R root:root ./ chown -R mysql:mysql data
data:image/s3,"s3://crabby-images/06aff/06affcd227f7856044d6a060b140b811585c4b1c" alt=""
6、更改mysql密码
上一步安装脚本执行输出的日志中告诉我们如何更改密码了
data:image/s3,"s3://crabby-images/3fdda/3fdda86a3d77c656bd22d87751c7162210c7531d" alt=""
但是如果直接执行这两条命令就会报错
data:image/s3,"s3://crabby-images/7a8f8/7a8f80b005e9f8ad53f3c3f5acd92f985f48120d" alt=""
因为这时还没有启动mysql,这算是一个坑。启动方法如下:
./support-files/mysql.server start
data:image/s3,"s3://crabby-images/d87cf/d87cf1e57deb1db08f23056ce491ebc3da9a3530" alt=""
如果MySQL启动报错,则可能是已经存在MySQL进程,杀掉即可
ps aux|grep mysql kill -9 上边的进程号 #或者下边一条命令即可杀掉所有MySQL进程 ps aux|grep mysql|awk '{print $2}'|xargs kill -9
data:image/s3,"s3://crabby-images/672e7/672e70fa0a224ed1b0fdba4b9454fe29fa5f3066" alt=""
杀掉后再启动即可。
data:image/s3,"s3://crabby-images/bbd64/bbd64e3151e617ca30f65d327f4fd09d3e4373d4" alt=""
MySQL启动之后再执行如下命令更改密码:
./bin/mysqladmin -u root -h localhost.localdomain password 'root'
data:image/s3,"s3://crabby-images/e0839/e083980d1396decf83842cc9b5d4129de0fbf48f" alt=""
密码更改后即可登录MySQL
./bin/mysql -h127.0.0.1 -uroot -proot
data:image/s3,"s3://crabby-images/f849a/f849a2443af9b2cd6defeedccf3d9e797f811eae" alt=""
登录之后将其他用户的密码也可改为root
update mysql.user set password=password('root') where user='root'; flush privileges;
data:image/s3,"s3://crabby-images/c7094/c70941b9638075afdfd4238a027072ba497f4435" alt=""
7、增加远程登录权限
上一步即可本地登录,但远程登录会报错
data:image/s3,"s3://crabby-images/12782/127823ddd3c8f898f9e445130a9290439fa330c4" alt=""
为解决这一问题,需要本地登陆MySQL后执行如下命令
grant all privileges on *.* to root@'%' identified by 'root'; flush privileges;
data:image/s3,"s3://crabby-images/3db06/3db065cbda6cc72a7d3defefd584b584f541c5d1" alt=""