Linux下安装MySQL

原文链接:https://www.jianshu.com/p/f4a98a905011

环境:
1、操作系统:CentOS
2、安装版本: mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz
3、特殊说明:Linux下MySQL5.6与MySQL5.7安装方法略有不同,本文以5.6为主

安装步骤

卸载老版本MySQL

1.查找并删除mysql有关的文件

find / -name mysql
rm -rf 上边查找到的路径,多个路径用空格隔开
#或者下边一条命令即可
find / -name mysql|xargs rm -rf
 
 
2、在安装包存放目录下执行命令解压文件:
tar -zxvf mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz
 
 
3、删除安装包,重命名解压后的文件
rm -f mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz
mv mysql-5.6.31-linux-glibc2.5-x86_64/ mysql
 
 

4、添加mysql用户组和mysql用户

先检查是否有mysql用户组和mysql用户

groups mysql
 

若无,则添加;

groupadd mysql
useradd -r -g mysql mysql
 

若有,则跳过;

 

5、进入mysql目录更改权限

cd mysql/
chown -R mysql:mysql ./
 
 

6、执行安装脚本

./scripts/mysql_install_db --user=mysql

出现如下异常:
FATAL ERROR: please install the following Perl modules before executing /usr/bin/mysql_install_db:
Data::Dumper
解决方案:
]# yum install -y perl-Module-Install.noarch

原因:
在centos7环境中没有找到离线安装的办法,只能在线安装,需要调整到可联网状态。虚拟机中的话,可以调整到nat模式下。

先执行yum install -y perl-Module-Install.noarch,然后执行安装脚本 ./scripts/mysql_install_db --user=mysql

 

安装完之后修改当前目录拥有者为root用户,修改data目录拥有者为mysql

chown -R root:root ./
chown -R mysql:mysql data
 
 

7、更改mysql密码

上一步安装脚本执行输出的日志中告诉我们如何更改密码了

 
 

但是如果直接执行这两条命令就会报错

 
 

因为这时还没有启动mysql,这算是一个坑。启动方法如下:

./support-files/mysql.server start
 
 

如果MySQL启动报错,则可能是已经存在MySQL进程,杀掉即可

ps aux|grep mysql
kill -9 上边的进程号
#或者下边一条命令即可杀掉所有MySQL进程
ps aux|grep mysql|awk '{print $2}'|xargs kill -9
 

杀掉后再启动即可。

 
Paste_Image.png

MySQL启动之后再执行如下命令更改密码:

./bin/mysqladmin -u root -h localhost.localdomain password 'root'
 
Paste_Image.png

密码更改后即可登录MySQL

./bin/mysql -h127.0.0.1 -uroot -proot
 

登录之后将其他用户的密码也可改为root

update mysql.user set password=password('root') where user='root';
flush privileges;
 

 

mysql命令 出现-bash: mysql: command not found的方法

原因:因为系统默认会查找/usr/bin下的命令,由于mysql没有在这个目录下,所以出现not found。因此需要做一个软连接到/usr/bin目录下。

执行命令: ln -s  /usr/local/mysql/bin/mysql  /usr/bin  即可。

 

8、增加远程登录权限

上一步即可本地登录,但远程登录会报错

 
Paste_Image.png

为解决这一问题,需要本地登陆MySQL后执行如下命令

grant all privileges on *.* to root@'%' identified by 'root';
flush privileges;
 
Paste_Image.png

执行之后即可远程登录

 

9、将MySQL加入Service系统服务

cp support-files/mysql.server /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on
service mysqld restart
 service mysqld status  
 
 

10、配置my.cnf

vim my.cnf
#添加以下两条语句并保存退出
character-set-server=utf8
lower_case_table_names=1
max_allowed_packet=100M
 
 

配置好之后,重启mysqld服务

 

 

posted @ 2018-11-09 14:58  Nathaniel-e  阅读(281)  评论(0编辑  收藏  举报