centos7服务器 安装mysql5.7版本

本文档详细介绍了在Linux环境下安装MySQL 5.7的步骤,包括安装依赖、编译、设置用户和权限,以及解决远程访问问题。在安装过程中提到了可能遇到的错误如缺少依赖包和启动服务失败,并给出了相应的解决办法。最后,针对无法远程连接MySQL的问题,解释了原因并提供了修改用户权限以允许远程访问的解决方案。
摘要由CSDN通过智能技术生成

下载mysql(注:其他版本未测试)
见下留言版

https://cdn.mysql.com/archives/mysql-5.7/mysql-boost-5.7.11.tar.gz

1、安装依赖包

yum -y install make gcc-c++ cmake bison-devel  ncurses-devel   bison perl perl-devel  perl perl-devel 

2、解压到/usr/local目录下

tar -zxvf mysql-boost-5.7.11.tar.gz -C /usr/local

3、创建mysql组和用户

groupadd mysql
useradd -r -g mysql -s /bin/false mysql

4、编译mysql

cd /usr/local/mysql-5.7.11/
cmake -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=boost
make    #注意:此步骤过程非常慢,建议使用 -j 4 4核的方式处理  同时保证服务器的内存至少大于2G
make install

5、把原来的/etc/my.cnf备份

cp /etc/my.cnf /etc/my.cnf.bak
rm -f /etc/my.cnf

6、把安装目录用户和组更改为mysql

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

7、创建一个数据目录

mkdir -p /data/mysql/data/

8、初始化mysql,及开启ssl新功能

bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data 
bin/mysql_ssl_rsa_setup  --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data 

9、 设为root是为了防止普通用户不小心删除数据库

chown -R root .
chown -R mysql /data

10、拷贝配置文件

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

11、修改环境变量

vi /etc/profile 

在profile文件末尾增加两行

PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH
export PATH

使PATH搜索路径立即生效:

source /etc/profile
12、修改配置文件

vi /etc/my.cnf

#修改第19行(取消注释且修改为) datadir = /data/mysql/data/
13、启动

service mysql start

到此,数据库就已经安装完毕了

接下需要打开防火墙3306端口

firewall-cmd --add-port=3306/tcp --permanent

firewall-cmd --reload

firewall-cmd --list-port

但是 mysql -u root -p 不能直接登录,于是更改密码,记录如下:

1)`vi /etc/my.cnf`  
2)[mysqld]下边的某个位置增加: `skip-grant-tables`  ,然后 :wq 保存退出
3)`/usr/local/mysql/bin`目录下执行命令:  `./mysql -u root -p`   ,然后回车两次,进入到mysql
4)执行命令:
use mysql
SET SQL_SAFE_UPDATES = 0
5)update mysql.user set authentication_string=password('root') where User='root';
6)flush privileges ; 
7)执行命令:SET SQL_SAFE_UPDATES = 1
8)vi /etc/my.cnf  ,删除skip-grant-tables 行
9)service mysqld restart
10) 在  /usr/local/mysql/bin目录下执行命令:  ./mysql -u root -p   然后输入新建的密码:root即可进入mysql 
虽然现在可以登录了,但我们需要在其他客户端远程连接此数据库,发现是连不通的

提示:Host ‘xxx’ is not allowed to connect to this MySQL server。网上找了一些资料,是mysql未开启mysql远程访问权限导致。

记录解决方案供以后参考。:

1.登录到`

mysql:  mysql -uroot -ppwd`

2.查看user表:

mysql> use mysql
Database changed
mysql> select host,user,password from user;
+------+------+-------------------------------------------+
| host | user | password |
+------+------+-------------------------------------------+
| localhost    | root | *826960FA9CC8A87953B3156951F3634A80BF9853 |
+------+------+-------------------------------------------+
1 row in set (0.00 sec)

表中host、user字段标识了可以访问数据库的主机和用户。例如上面的数据就表示只能本地主机通过root用户访问。原来如此,难怪远程连接死活连不上。

为了让数据库支持远程主机访问,

可以直接修改host字段的值,将localhost修改成需要远程连接数据库的ip地址。或者直接修改成%。修改成%表示,所有主机都可以通过root用户访问数据库。为了方便,我直接修改成%。命令:mysql> update user set host = ‘%’ where user = ‘root’;

再次查看user表

+------+------+-------------------------------------------+
| host | user | password |
+------+------+-------------------------------------------+
| % | root | *826960FA9CC8A87953B3156951F3634A80BF9853 |
+------+------+-------------------------------------------+
1 row in set (0.00 sec)

修改成功,输入命令mysql> FLUSH PRIVILEGES; 回车使刚才的修改生效,再次远程连接数据库成功。

bug 1.错误命令 No rule to make target `install’. Stop.

出现标题所示的错误代码是因为在Linux安装软件总没有在Windows系统下安装软件那么容易,不同的软件包安装的方式也不同,这是缺少依赖包的原因,解决方法如下

yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5-devel libidn libidn-devel openssl openssl-devel nss_ldap openldap openldap-devel  openldap-clients openldap-servers libxslt-devel libevent-devel ntp  libtool-ltdl bison libtool vim-enhanced  

bug 2. 用 service mysqld restart 重启mysql服务的时候,报了Failed to restart mysqld.service: Unit not found

用估计也就是服务名错误了,于是使用 chkconfig --list 查询服务列表
在这里插入图片描述
可以看到服务名称为"mysql",使用 service mysql restart 重启mysql服务成功

3. bug3 开启远程连接详细笔记连接地址

原文地址

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值