centos7.0环境下安装MySql_8.0.12

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: centos7.0环境下安装MySql_8.0.12

一 官网下载MySql

  1. 进入官网,点击"DOWNLOAD"

mysql官网
image.png

  1. 点击“Community”
    image.png

  2. 点击左侧"MySql Community Server "
    image.png

  3. 下拉页面,选择"Linux -Generic",然后选择下边的适合自己系统(32位/64位)的版本即可
    image.png

  4. 将下载下来的压缩包上传到/usr/local目录并进行解压

xz -d mysql-8.0.12-linux-glibc2.12-x86_64.tar.xz

这样解压后得到的是.tar文件,再次进行解压:

tar -xvf mysql-8.0.12-linux-glibc2.12-x86_64.tar

二 centos7下安装MySql_8.0.12

查看机器是否安装过mysql

  • CentOS6
    rpm -qa|grep mysql
    请先执行卸载命令:rpm -e --nodeps mysql-libs

    • CentOS7
      rpm -qa|grep mariadb
      请先执行卸载命令:rpm -e --nodeps mariadb-libs

1. 将上边解压后得到的mysql文件修改名字,方便后边操作

mv mysql-8.0.12-linux-glibc2.12-x86_64 mysql

2. 进入mysql文件夹,创建data目录

cd mysql;
mkdir data;

3.添加用户组(可以不添加)

groupadd mysql
useradd -g mysql mysql

4.设置mysql目录权限,把权限交给mysql用户/用户组

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

5.将mysql的脚本服务放进系统服务里

cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

6.修改/etc/my.cnf文件

basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306                                             
socket  = /tmp/mysql.sock
character-set-server = utf8                                                                  
log-error=/var/log/mysqld.log                                                              
pid-file=/home/mysql/mysqld.pid

7.新增log与pid文件

vi /var/log/mysqld.log;#什么也不写,直接保存退出
#赋权限
chown -R mysql /var/log/;
chgrp -R mysql /var/log/;

vi /home/mysql/mysqld.pid;#什么也不写,直接保存退出
chown -R /home/mysql/mysqld.pid;
chgrp -R /home/mysql/mysqld.pid;

8.进入mysql安装目录的bin目录进行初始化

cd /usr/local/mysql/bin/;
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql/--datadir=/usr/local/mysql/data/;

9.先进入cd support-files目录里,把support-files/mysql.server 拷贝为/etc/init.d/mysql

cd /usr/local/mysql/support-files/;
cp mysql.server /etc/init.d/mysql;
chmod +x /etc/init.d/mysql;#设置权限

10.将mysql服务设置为开机自启

chkconfig --add mysql

11.做一个软连接,方便在任意目录都能开启/登录mysql

ln -s /usr/local/mysql/bin/mysql /usr/bin;

12.开启mysql

service mysql start

13.登录mysql

  1. 先查看生成的初始密码
    cat /var/log/mysqld.log
    image.png

2.登录

mysql -u root -p

然后会提示输入密码,把上边图片里的密码输入即可;

14.登录进去后第一件事就是修改root用户密码

ALTER user 'root'@'localhost' IDENTIFIED BY 'newpassword';

配置远程登录

mysql>use mysql;#使用mysql库
mysql>select user,host from user;#host是远程主机地址,可以写成%,即所有远程地址;

将mysql数据库user表里的root用户的host改成% ,即所有远程地址都可以访问

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

允许root用户进行远程登录

GRANT ALL ON *.* TO 'root'@'%';
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你的数据库密码';#root是用户名 mysql默认的是root password是密码自己设置 %表示任意主机,也可以指定ip地址

如果登录时出现如下错误:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES);

解决方法:

  1. 配置免密登录
    vi /etc/my.conf  #在任意位置添加下边的一行
    skip-grant-tables  #配置免密码登录
    #保存退出后重启mysql
    service mysql restart;
    
  2. 直接在窗口出入mysql后回车即可登录了
mysql  #直接回车即可登录
  1. 以此执行如下命令
flush privileges;#刷新权限
alter user 'root'@'%'identified by 'root@123';#修改密码为‘root@123’
quit;#退出
  1. 再将my.conf里的免密登录删除,重启mysql即可
    vi /etc/my.conf  #在任意位置添加下边的一行
    #skip-grant-tables  #将这行删除或注释掉
    #保存退出后重启mysql
    service mysql restart;
    

    忘记root用户登录密码

  2. 在/etc/my.cnf里添加免密登录
skip-grant-table
  1. 重启mysql并登录
    service mysql restart;
    mysql -u root -u;  #直接回车登录,密码不用输
    
  2. 刷新权限
flush privileges;
  1. 修改密码
    use mysql;
    alter user 'root'@'%' IDENTIFIED BY 'root';
    
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
Web App开发 搜索推荐 Unix
Linux系统之MobaXterm远程连接centos的GNOME桌面环境
【10月更文挑战第21天】Linux系统之MobaXterm远程连接centos的GNOME桌面环境
111 4
Linux系统之MobaXterm远程连接centos的GNOME桌面环境
|
6天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
19 3
|
6天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
14 1
|
6天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
15 2
|
8天前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
9天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
45 2
|
23天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
56 3
Mysql(4)—数据库索引
|
12天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
52 4
|
17天前
|
存储 关系型数据库 MySQL
如何在MySQL中创建数据库?
【10月更文挑战第16天】如何在MySQL中创建数据库?