阿里云centos重新安装mysql密码_阿里云Centos 7上面安装mysql教程

1 软件的基本安装过程

1 卸载已有的mysql

1.查看系统是否安装了mysql软件

rpm -qa|grep -i mysql

2.将已经安装过的软件卸载掉。注意:这样的卸载是不彻底,不过这里够用了。

yum remove '软件名'

2 准备mysql的repo源

总结代码:

wget http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpmrpm -ivh mysql57-community-release-el7-7.noarch.rpm

==============补充start================

解释:wget默认会以最后一个符合 /的后面的字符来命令

例如:wget http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm下载完成的名字就是mysql57-community-release-el7-7.noarch.rpm

可以自己改变下载后的文件名:命名为

wget -O mysql.rpm http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm

==============补充end=================

CentOS 7的yum源中默认是没有mysql的。所以,为了解决这个问题我们首先下载安装mysql的repo源。

wget http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm

cd06e52e106934edb9ce78e037fe8a5d.png

rpm -ivh mysql57-community-release-el7-7.noarch.rpm

bf1999b407c538d7e76cb0deb34106ec.png

安装之后会获得/etc/yum.repos.d/mysql-community.repo和/etc/yum.repos.d/mysql-community-source.repo两个源,可以去相应的路径下查看一下。

16ccaf3640b40a399dbd75d00a8c44e4.png

3 安装mysql

使用代码总结:

yum install mysql-serveryum install mysql-develyum install mysql

rpm -qa | grep -i mysql

1.安装mysql-server

yum install mysql-server

7bd621b7a93f5b208a5645bf9944cc85.png

089d891c8fd67b48d5bee63e6d7114a9.png

a5df7e5785e5a5165d478aefd7d94e56.png

2 安装mysql-devel

yum install mysql-devel

0616f9ade3a221ef8c71b05f17b84e16.png

1b085495aafc316cf340b3e8e61e648d.png

3.安装mysql

yum install mysql

babfd42521e3316c16da2415009ab582.png

安装完成之后重新检查一下安装了的mysql软件。

rpm -qa|grep -i mysql

3e71e90087797a36d2c378a36b5ba071.png

一般来说,只要安装mysql-server跟mysql-client 。

2 服务开关操作

service mysqld status 查看mysql当前的状态service mysqld stop 停止mysqlservice mysqld restart 重启mysqlservice mysqld start 启动mysql

3 将MySQL加入开机启动

systemctl enable mysqld

c0373c4d66c9a9e89716f305cbfda128.png

4 启动mysql服务进程

systemctl start mysqld

或者使用下面的代码:都是启动mysql服务,效果一样。

#service mysqld start 启动mysql

e17953e28e4bf0e2cd0fe2ea8dff0eee.png

5 无法登录问题解决

登录root帐号需要密码,不过我们没有。

f55ac2c27e4b00678c92bab14c11ab8e.png

下面是这个问题的详细解决过程

1 修改配置文件,跳过用户验证

1.在/etc/my.cnf文件中添加skip-grant-tables。这里注意一下:我的skip-grant-tables放到了文件最后。

skip-grant-tables:的作用就是跳过了mysql的用户验证

然后直接输入mysql,不需要带任何登录参数直接回车就可以登陆上数据库;

4c394253ec2bf09de4be17a3a988cc82.png

2.重启mysql,service mysqld restart

重启之后我们直接输入mysql即可进入mysql数据库,因为我们已经跳过了mysql数据库的用户验证。

7d0008f75595b7b267b0d0e3939fdd05.png

eca60dfebc4633dd06320b1c2aa9add5.png

3.使用mysql数据库

使用命令:use mysql;

ce0c5e22259b14aae635de0d98e40cef.png

4.show tables查看所有表

会发现有个user表,这里存放的就是用户名,密码,权限等等账户信息

mysql>show tables;+---------------------------+

| Tables_in_mysql |

+---------------------------+

| columns_priv |

| db |

| engine_cost |

| event |

| func |

| general_log |

| gtid_executed |

| help_category |

| help_keyword |

| help_relation |

| help_topic |

| innodb_index_stats |

| innodb_table_stats |

| ndb_binlog_index |

| plugin |

| proc |

| procs_priv |

| proxies_priv |

| server_cost |

| servers |

| slave_master_info |

| slave_relay_log_info |

| slave_worker_info |

| slow_log |

| tables_priv |

| time_zone |

| time_zone_leap_second |

| time_zone_name |

| time_zone_transition |

| time_zone_transition_type |

| user |

+---------------------------+

31 rows in set (0.00 sec)

5.查看账户信息

执行下面的命令,可以查看用户的账户信息。

select user,authentication_string from user;

0a17c46e78794a78ed3a76ddbfdc0a92.png

从这里我们可以看到mysql数据库中的密码是加密的,不可逆的。一旦忘记了就找不回来了的。

6.修改root用户的密码

我们可以执行下面的命令修改root用户的密码:

update mysql.user set authentication_string=password('your password') where user='root';

7.修改密码之后,删除所有权限

flush privileges;

8.退出数据库

exit

9.恢复/etc/my.cnf文件

恢复/etc/my.cnf,将skip-grant-tables删除或者注释掉。

bf7a2cb2cbd89ff453795f98cdfc0844.png

10.重启mysql,service mysqld restart

service mysqld restart

到此为止我们就解决了mysql安装之后登录不知道密码的问题。现在一切都正常了。

11.验证一下是否成功解决了登录问题

rpm -qa|grep -i mysql

可以看到已经完美的解决了。一路下来还真不容易啊。

68ec1745126a00b6fafd7fcfd431d54a.png

解决登录问题中的代码整理:

vim /etc/my.cnf //修改配置

skip-grant-tables 加入到my.cnf 文件的最后

service mysqld restart//修改配置后重启mysql服务

mysql//跳过用户验证后,直接就能登录

mysql> use mysql; //切换数据库

mysql> show tables; //查看所有表

mysql> select user,authentication_string from user; //查看权限信息

mysql> update mysql.user set authentication_string=password('your password') where user='root'; //修改密码

mysql> flush privileges; //刷新让修改生效

mysql> exit //退出mysql[root@iz2ze6adlpez0gy7j13vrmz ~]# vim /etc/my.cnf //还原my.cnf文件配置,去掉最后的skip-grant-tables[root@iz2ze6adlpez0gy7j13vrmz ~]# cat /etc/my.cnf //查看是否还原成功[root@iz2ze6adlpez0gy7j13vrmz ~]# service mysqld restart //重启mysql服务[root@iz2ze6adlpez0gy7j13vrmz ~]# mysql -uroot -proot //使用修改的密码登录

6.重置密码问题

下面顺便讲解一下这个问题:

安装完mysql 之后,登陆以后,不管运行任何命令,总是提示这个错误:

You must reset your password usingALTER USER statement before executing this statement

处理步骤为:依次执行下面三条代码。

SET PASSWORD = PASSWORD('your new password');

ALTER USER 'root'@'localhost'PASSWORD EXPIRE NEVER;

flush privileges;

这里要注意的是your new password 必须包含数字,字母包含大小写,标点符号。不然好像是不能通过的。

完成以上三步退出再登,使用新设置的密码就行了,以上除了 your new password 需要修改成新密码外,其他原样输入即可。

7.解决远程客户端无法连接MySQL数据库

现在我们想要在本地,远程访问我们阿里云服务器上的mysql数据库。我使用的是navicat 软件,但是发现一直连接不上。

531f1c9ead041030a0062bd6a27d4281.png

出现这个问题的原因是因为:我的实例是专有网络类型。要想能够远程访问,需要对外开放MySQL的端口3306.

8a9ef12a7141b0a19ae09a7e4669822e.png

下面演示如何对外开放3306端口。

7bee3e2bcc51200ac946fdfc8dc8145a.png

fde98215d62e70aad6abad5d09c598b2.png

e8d3740652aa8c205935c40099b4d63e.png

5fc4023aa2c52f1116f6d63deaf5489c.png

配置完成之后,我再次去尝试远程连接MySQL数据库。

不幸的是,这次还是失败了:这次报的错误如下:

bf6d1676b723a8584267b492bcb255fd.png

错误代码是1130: -Host xxx.xxx.xxx.xxx is not allowed to connect to this MySQL server

首先我想的应该是数据的权限不足的问题;

通过查阅资料发现了这篇文章:解决远程连接mysql错误1130的方法https://www.aliyun.com/jiaocheng/136440.html

解决方法如下:

具体说就是:在本机登入mysql后,更改 “mysql” 数据库里的 “user” 表里的 “host” 项,从”localhost”改称'%'。。

mysql -u root -p

mysql>usemysql;

mysql>select host,user from user;

mysql>update user set host = '%' where user ='root';

mysql>flush privileges;

mysql>select host,user from user;

第一句是以权限用户root登录

第二句:选择mysql库

第三句:查看mysql库中的user表的host值(即可进行连接访问的主机/IP名称)

317ab5ae2b60ec908e829bfe7fc64fa8.png

第四句:修改host值(以通配符%的内容增加主机/IP地址),当然也可以直接增加IP地址

第五句:刷新MySQL的系统权限相关表

第六句:再重新查看user表时,有修改。。

1b9eeecceb0e31f1bf907bb91e0ab928.png

重起mysql服务即可完成。service mysqld restart。

实际开发中:我们更多的还是推荐创建用户,然后使用创建的用户连接数据库。 root用户的权限太大了。

通过上面的处理我们再一次来尝试远程连接mysql数据库

7d49fe256f8179660ef611ef6e16d8d0.png

到此MySQL数据库在阿里云esc centos 7 上的安装就算是大功告成了。

8.补充知识点

1 一些常用的命令

1 检查MySQL是否已经安装

yum list installed | grep mysql

2 已经安装使用yum方式卸载

yum -y remove mysql-libs.x86_64

3 下载 MySQL Yum Repository

wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm

4 添加 MySQL Yum Repository 到你的系统 repository 列表中

yum localinstall mysql-community-release-el7-5.noarch.rpm

5 验证下是否成功添加到了你的系统repository 列表中

yum repolist enabled | grep "mysql.*-community.*"

6 查看MySQL版本

yum repolist all | grep mysql

7.查看当前的启动的 MySQL 版本

yum repolist enabled | grep mysql

8 通过yum来安装MySQL

yum install mysql-community-server

9.查看MySQL 的安装目录

whereis mysql

10.启动MySQL服务

systemctl start mysqld 或者 service mysqld start

11.关闭MySQL服务

systemctl stop mysqld 或者 service mysqld stop

12.查看MySQL服务状态

systemctl status mysqld 或者 service mysqld status

13.重启MySQL服务

service mysqld restart

14.使用命令 pidof mysqld 命令来查看mysql 的启动状态如图所示:如果显示PID说明程序启动,不显示PID即为程序没有启动。

pidof mysqld

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值