mysql--Centos安装MariaDB(mysql)

简介: mysql--Centos安装MariaDB(mysql)

前戏


大家都知道mysql数据库被oracle公司收购了,后期可能会面临着收费的风险,因此还想免费使用开源的数据库mysql,就诞生了MariaDB。

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。

开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。

MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。


配置Mariadb的yum源


安装MariaDB有两种方式,第一种方式是,通过阿里云的yum源去下载(第三方的yum源,可能会版本较低,且软件不全,可能找不到),前提是配置好了阿里云的yum源。参考https://www.cnblogs.com/zouzou-busy/p/11602857.html

yum install mariadb-server

第二种方式是,通过mariadb官方的yum源去下载(一定是这个软件最正确的yum源,且包都是最新的)

yum install MariaDB-server MariaDB-client

使用第二种方式需要先配置MariaDB 的 YUM 配置文件 MariaDB.repo 文件

1.编辑创建mariadb.repo仓库文件

vim /etc/yum.repos.d/MariaDB.repo

2.添加repo仓库配置

[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/10.1/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1


安装


这里我们使用第一种方法安装,因为第一种镜像在国内,安装起来快,第二种镜像在国外,安装起来慢

当使用阿里云进行安装的时候,一定要保证/etc/yum.repos.d下没有MariaDB.repo文件,要不然下载速度会让你怀疑人生

当 MariaDB 仓库地址添加好后,你可以通过下面的一行命令轻松安装 MariaDB。

yum install MariaDB-server MariaDB-client -y

安装好了之后就要启动MariDB服务

mariadb数据库的相关命令是:
systemctl start mariadb  #启动MariaDB
systemctl stop mariadb  #停止MariaDB
systemctl restart mariadb  #重启MariaDB
systemctl enable mariadb  #设置开机启动

查看状态

systemctl status mariadb

启动完我们直接在命令行输入mysql就可以进入了


初始化mysql


在确认 MariaDB 数据库软件程序安装完毕并成功启动后请不要立即使用。为了确保数据 库的安全性和正常运转,需要先对数据库程序进行初始化操作。这个初始化操作涉及下面 5 个 步骤。

  1. 设置 root 管理员在数据库中的密码值(注意,该密码并非 root 管理员在系统中的密 码,这里的密码值默认应该为空,可直接按回车键)。
  2. 设置 root 管理员在数据库中的专有密码。
  3. 随后删除匿名账户,并使用 root 管理员从远程登录数据库,以确保数据库上运行的业务的安全性。
  4. 删除默认的测试数据库,取消测试数据库的一系列访问权限。
  5. 刷新授权列表,让初始化的设定立即生效。

确保mariadb服务器启动后,执行命令初始化

mysql_secure_installation
[root@HH ~]# mysql_secure_installation
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
  ......
Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.
Set root password? [Y/n] y    设置root密码   zou123456
New password:   zou123456
Re-enter new password:    zou123456
Password updated successfully!
Reloading privilege tables..
 ... Success!
Remove anonymous users? [Y/n] y  删除匿名账户
 ... Success!
Disallow root login remotely? [Y/n] n   禁止root管理员账户远程登入,我这里不禁止
 ... skipping.
Remove test database and access to it? [Y/n] y    删除test数据库并取消对它的权限
 - Dropping test database...
 ... Success!
Reload privilege tables now? [Y/n] y    刷新授权表,让初始化后的设定立即生效
 ... Success!
Thanks for using MariaDB!


数据库权限设置


当我们初始化数据库之后,远程连接的时候会报下面的错误

这是因为数据库权限的问题,这时候我们就要对数据库的权限进行一些设置了

mysql使用grant命令对账户进行授权,grant命令常见格式如下

grant 权限 on 数据库.表名 to 账户@主机名 identified by '账户密码';          # 对特定数据库中的特定表授权
grant 权限 on 数据库.* to 账户@主机名 identified by '账户密码';            # 对特定数据库中的所有表给与授权
grant 权限1,权限2,权限3 on *.* to 账户@主机名 identified by '账户密码';    # 对所有库中的所有表给与多个授权
grant all privileges on *.* to 账户@主机名  identified by '账户密码';    # 对所有库和所有表授权所有权限

退出数据库,使用root登录,开始权限设置

[root@HH ~]# mysql -uroot -p
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 14
Server version: 5.5.64-MariaDB MariaDB Server
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> grant all privileges on *.* to root@'%' identified by 'zou123456';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]>
# 对root所有权限,所有主机都授权
grant all privileges on *.* to root@'%' identified by 'zou123456';

授权之后一定要刷新权限flush privileges;

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

刷新完之后在去远程登录就可以登录成功了

注意:上面授权的密码是zou123456,哪怕你把密码改了,在远程端登录也是输入zou123456,而不是改掉之后的密码


乱码解决


默认创建的数据库是latin1文,这样我们如果往数据库里插入中文,查询出来的就是乱码,所以我们要把数据库的编码设置为utf8,进入数据库之后,可以通过 \s 查看编码格式

mysql的配置文件在/etc/my.cnf下,加入以下信息

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
log-error=/var/log/mysqld.log
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

修改了配置文件之后,重启服务

systemctl restart mariadb

查看数据库创建的编码,只有在更新了数据库编码之后,创建的数据库,才会使用这个编码

show create database 数据库名;

这样查询出来的才是中文,不会乱码

如果创建数据库报如下错误

MariaDB [(none)]> create database fa;
ERROR 1006 (HY000): Can't create database 'fa' (errno: 13)

执行下面这句

chown -R mysql:mysql /var/lib/mysql

/var/lib/mysql 为mysql的数据库存储的所在目录.


数据库的备份


为了防止数据的丢失,我们要对数据库定期做好备份

通过命令导出全部数据(退出数据库),输入数据库用户名密码就导出成功了

mysqldump -u root -p --all-databases > /tmp/db.dump

可以删除一些无关紧要的数据库,然后导入

drop database 数据库;

导入备份好的数据库有两种方式,第一种在mysql命令行中输入下面命令

source /tmp/db.dump   #这一步是输入的sql语句,在mysql中输入,导入数据

第二种方式导入数据,退出mysql,在linux命令行中执行如下命令

mysql -uroot -p <  /tmp/db.dump

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
关系型数据库 MySQL 数据库
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
|
8天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
66 24
|
2天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
58 7
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
62 4
|
2月前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
625 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
116 3
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
96 2
|
1月前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
166 2
|
1月前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
184 0

热门文章

最新文章