【运维工程师学习五】数据库之MariaDB

news/2024/4/28 8:55:20/文章来源:https://blog.csdn.net/weixin_43576565/article/details/131633362

【运维工程师学习五】数据库

    • 1、常用的关系型数据库
    • 2、C/S结构
    • 3、MariaDB图形客户端
    • 4、安装MariaDB
    • 5、启动MariaDB及验证启动是否成功
    • 6、验证启动——端口
    • 7、验证启动——进程
    • 8、MariaDB配置文件路径
      • 主配置文件解读:
    • 9、MariaDB的配置选项
    • 10、MariaDB客户端连接
      • 1、在本机,即使root密码为空,客户端一样可以连接的,使用命令`mysql –u root –p` 提示输入密码时直接回车即可进入数据库;
      • 2、修改数据库超管root的密码,除了上述方法,还有另外一种方法,就是进入数据库后通过数据库的更新操作(update)可以实现,具体方法,请看下节“mariadb修改root密码”;
      • 3、允许root用户远程连接(在业务环境中不会这样做,但现在是实验,为客户端连接linux的Mariadb做铺垫),使用命令行客户端进入数据库后执行命令
      • 4、刷新MySQL的系统权限相关表­
    • 11、图形客户端的使用(Navicat为例)
    • 12、默认安装后,系统自带3个数据库
    • 13、mariadb修改root密码
    • 14、客户端常用命令——数据库相关
      • (1)显示已有的数据库
      • (2)创建数据库
      • (3)删除数据库
    • 15、导入数据
    • 16、为业务数据库创建指定的用户
    • 17、客户端常用命令——表相关
    • 18、数据库备份
      • (1)备份指定数据库
      • (2)备份所有数据库
      • (3)备份指定数据库指定表(多个表以空格间隔)
      • (4)备份指定数据库排除某些表
    • 19、还原/导入数据库

1、常用的关系型数据库

db根据存储模型划分,数据库类型主要可分为:网状数据库(Network Database)、关系数据库(Relational Database)、树状数据库(Hierarchical Database)、面向对象数据库(Object-oriented Database)等。商业应用中主要是关系数据库,而关系数据库中常见的软件有比如Oracle、DB2、Sybase、MS SQL Server、Informax、MySQL等等。
实数据库系统几乎支持所有的操作系统,也就是上述数据库几乎与平台无关(当然除SQL Server和Access以外,因为这是微软的东西,平台依赖性很强的,只在windwos系统平台上运行)。

关系型数据库系统除了全面列出来的还有很多,但最常用的也不外乎:

  • Oracle #闭源、收费,金融行业或其它行业大型公司的选择
  • MySQL #开源、免费,互联网公司的最爱
  • MS SQL Server #闭源、收费,一些互联网公司及传统中小企的选择

注:MySQL已被Oracle公司收购。MySQL原创始人重新开发了一个分支,叫MariaDB,完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。CentOS7系统中已经将默认的数据库系统MySQL替换为MariaDB,因此接下来的关于数据库的安装及使用演示均是基于MariaDB。

2、C/S结构

数据库的软件体系结构是C/S(Client/Server,客户端/服务端),要访问或管理数据库必须通过对应的客户端。认清这个问题,有两个好处(以MariaDB为例):

下图中,初学者往往会mariadb.x86_64为数据库,实则它只是客户端;

在这里插入图片描述

  1. mariadb.x86_64数据库客户端
  2. mariadb-server.x86_64才是数据库服务端
  3. 选择最适合自己使用习惯的客户端,有利于提高认知及学习效率。mariadb.x86_64是命令行客户端,初期建议尝试几种图形客户端。

3、MariaDB图形客户端

  1. phpMyAdmin
  2. MySQL Workbench
  3. Adminer
  4. Navicat for MySQL
  5. OmniDB
  6. DataGrip(JetBrains旗)
  7. Dbeaver
  8. SQLyog

4、安装MariaDB

本次安装使用“软件仓库安装法”。同时安装服务端及客户端:

yum install -y mariadb-server mariadb

在这里插入图片描述

5、启动MariaDB及验证启动是否成功

  • 启动、设置开机自动启动、查看状态
systemctl start mariadb

在这里插入图片描述

6、验证启动——端口

netstat -utnlp

在这里插入图片描述

  • 3306是MySQL及MariaDB的默认端口。
  • 端口信息及进程信息均表示数据库MariaDB启动正常。

7、验证启动——进程

ps aux | grep mariadb

在这里插入图片描述

8、MariaDB配置文件路径

主配置文件:/etc/my.cnf #MySQL也是这个,所以说MariaDB完全兼容性!
在这里插入图片描述

vi /etc/my.cnf 

在这里插入图片描述

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
symbolic-links=0
#
# This group is read both both by the client and the server
# use it for options that affect everything
#
[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid
[client-server]#
# include all files from the config directory
#
!includedir /etc/my.cnf.d

在这里插入图片描述

主配置文件解读:

  1. [***]表示配置分组,如[mysqld]表示从下一行开始至出现 [***]的行,均为服务端的配置行。本文件为默认配置,服务端只设置了两个选项,一个是datadir数据保存路径),一个是socket套接字文件路径);
  2. !includedir表示其它附加的配置文件路径。本例中包含的/etc/my.cnf.d文件夹中凡是以.cnf结尾的文件都会被当数据库的配置文件的一部分。如果这个文件夹中的配置文件定义的选项与主配置文件中有重复,则以该文件夹的配置为准。
  3. 配置文件引入“包含”的概念,一般是为了实现配置文件的分类,提高配置文件的可读性。例如可以把关于服务端的配置选项全部放在server.cnf中,将客户端的配置选项放在client.cnf中。

9、MariaDB的配置选项

在这里插入图片描述

注:
1、关于搜索到的配置举例,请不要盲目复制,因为很多选项都是基于特定的硬件(内存大小及CPU性能);
2、配置的优化是根据自身的业务环境而定,并且是在有性能监控数据及遇到的问题总结做支撑,例如:遇到错误提示“超出连接数”那就要修改最大连接数、遇到有大量请求在等待那就可能要修改最大并发数、发现内存及CPU占用过高那就可能要修改缓存大小,等等;
3、早期不用太热衷于玩弄各个高级配置项,基本配置都够你玩半年(配合web练习),天才除外;

10、MariaDB客户端连接

mysql -u root -p

使用yum安装的mariadb,默认管理员root的密码为空,并且只允许本机连接,不允许远程连接。因此,我们需要为root用户配置密码,方法如下:

1、在本机,即使root密码为空,客户端一样可以连接的,使用命令mysql –u root –p 提示输入密码时直接回车即可进入数据库;

2、修改数据库超管root的密码,除了上述方法,还有另外一种方法,就是进入数据库后通过数据库的更新操作(update)可以实现,具体方法,请看下节“mariadb修改root密码”;

3、允许root用户远程连接(在业务环境中不会这样做,但现在是实验,为客户端连接linux的Mariadb做铺垫),使用命令行客户端进入数据库后执行命令

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY '123456' WITH GRANT OPTION;

在这里插入图片描述

123456为密码,上述命令的意思是:允许密码为123456的root用户具有数据库中所有数据库的所有权限。

4、刷新MySQL的系统权限相关表­

FLUSH PRIVILEGES;

在这里插入图片描述

11、图形客户端的使用(Navicat为例)

需要先关闭虚拟机的防火墙,才能够连接成功(先前文章14、15节说过了这里不再重复,自行通过下方链接查阅)
https://blog.csdn.net/weixin_43576565/article/details/131376844
在这里插入图片描述
在这里插入图片描述
连接成功
在这里插入图片描述

12、默认安装后,系统自带3个数据库

  • information_schema #此数据库提供了访问数据库元数据的方式
  • mysql #核心数据库,存储用户的权限信息等,不可以随意修改其内容
  • performance_schema #此数据库为数据库性能优化提供重要的参考信息,默认关闭
  • test #(有些版本会带)顾名思义,测试数据库,没有内容,可删除

在这里插入图片描述

13、mariadb修改root密码

具体方法:
1、进入etc目录下

cd /etc

2、编辑my.cnf文件

vi my.cnf

3、在my.ini,[mysqld]下添加一行,使其登录时跳过权限检查

[mysqld]
skip-grant-tables     

4、重启数据库

service mysqld restart

5、直接无密码登录数据库

mysql -uroot -p

6、查看数据库并使用mysql数据库表

mysql> show databases;
mysql> use mysql;

7、更新密码

mysql> update user set password=passworD("123456") where user='root';

#注意如果Mysql的版本是5.7及以上的话update语句如下:

update user set authentication_string=passworD("123456") where user='root';

#刷新数据库的系统权限相关表­

FLUSH PRIVILEGES;

8、去my.cnf配置文件中删除使其登录时跳过权限检查的配置
9、重启mysql实现密码登录

service mysqld restart

在这里插入图片描述

在这里插入图片描述

14、客户端常用命令——数据库相关

(1)显示已有的数据库

show databases;

在这里插入图片描述
命令以;结尾
注意database后面有个s,英文中表示复数的意思
整个命令顾名思议就是显示所有数据库,默认共4个数据库,各个数据库的意义前面已作基本介绍。

注:客户端中的命令不支持tab补全;表名及列名可以使用tab补全,但这个功能默认不开启,欲尝试自行搜索我的博客,篇幅问题这里不展开说。

(2)创建数据库

create database mytest;		#mytest为数据库名

(3)删除数据库

drop database mytest;		#mytest为数据库名

注意这里的database没有加s
已经成功创建mytest数据库
上面只是最简单的创建数据库命令,如果需要指定数据库的字符集则需要加相关参数。

15、导入数据

source / sql-dftables.txt		# /root/ sql-dftables.txt为数据库脚本文件

在这里插入图片描述

需要输入完整路径。如果脚本中只有表结构,则只会在数据库中创建表,如果脚本中既有表结构又有数据内容,则都会导入。数据库脚本文件其实就是数据库的各种命令的集合。

导入之前先使用use命令连接指定的数据库,即后面的导入操作就会导入至该数据库。

注:包括后面介绍关于数据库表的操作命令都需要先使用use命令,指定数据库。使用source命令,最后不用;结尾

16、为业务数据库创建指定的用户

为某数据库创建指定用户,基于安全考虑,不使用root用户进行业务操作,建议为业务数据库创建指定的用户,命令如下:

GRANT ALL PRIVILEGES ON mytest.* TO 'test2'@‘localhost'IDENTIFIED BY '12345qwert';

GRANT SELECT,INSERT,UPDATE,DELETE ON mytest.* TO 'test2'@'%'IDENTIFIED BY '12345qwert';

命令解读如下:

  • GRANT后面跟的是权限范围 ALL PRIVILEGES
    表示允许所有权限,而SELECT,INSERT,UPDATE,DELETE表明只允许查、增、改、删四个权限,其它不允许。
  • ON 后面跟的数据库名 mytest.* 表示mystest的所有表都被允许,TO后面@之前表示的是用户名(不带引号)
    @后面跟的是客户端位置(localhost表示仅本机可连,%表示任意远程主机,还可以指定某IP或IP段) BY后面跟的是该用户的密码
    在这里插入图片描述

注:客户端中的命令不区分大小写,只是大家习惯将命令大写,内容小写提高整条命令的可读性。

17、客户端常用命令——表相关

显示数据库中的所有表:

show tables;

关于表的操作命令还有很多,如增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)不再演示,请自行搜索,如搜索“mysql常用命令”

18、数据库备份

数据库备份方法有很多,这里仅演示自带的备份工具备份完整的数据库(表结构及内容),命令如下:

(1)备份指定数据库

mysqldump -u root -p mytest > /root/mytest_bak_20230711.sql

在这里插入图片描述

mysqldump是一个独立的程序,因此这里看到的是系统命令行环境中。

  • -u root是使用root命令登陆数据库来操作备份动作
  • -p是后面要输入密码,与mysql客户端类似
  • mytest是要备份数据库名
  • root/mytest_bak_20230711.sql是备份的目标文件,这是一个文本文件,只是习惯使用.sql作为文件后缀标识,方便识别。
  • mysqldump还有很多用法,欲了解更多请自行搜索。
  • 备份的文本文件的部分内容。
  • 还原则使用前面介绍的source即可。

注意这一步需要推出数据库,不能在数据库内执行。
在这里插入图片描述

(2)备份所有数据库

mysqldump -u root -p --all-databases > /root/alldatabases_bak_20230711.sql

在这里插入图片描述

(3)备份指定数据库指定表(多个表以空格间隔)

mysqldump -u root -p mysql db user event > /root/mysql_bak_20230711.sql

在这里插入图片描述

(4)备份指定数据库排除某些表

mysqldump -uroot -p mysql --ignore-table=mysql.db --ignore-table=mysql.user > /root/123.sql

在这里插入图片描述

19、还原/导入数据库

mysql > use db_name #输入需要还原/导入的数据库名
mysql > source /backup/mysqldump/db_name.db #输入还原/导入的数据库路径

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_331286.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为云子网路由表作用及价值

子网路由表 子网路由表作用云专线、VPN的配置与子网路由表强关联,本质是在相应的子网路由表中添加了一条路由Nat路由表问题地址变更问题snat和dnat 子网路由表作用 子网内部作为一个二层网络,通过mac地址互通,不通过路由互通。跨子网&#x…

微信小程序安装和使用 Vant Weapp 组件库

微信小程序安装和使用 Vant Weapp 组件库 1. Vant Weapp 介绍2. Vant Weapp 的 安装2.1. 通过npm安装2.2. 构建npm2.3. 修改 app.json2.4. 修改 project.congfig.json2.5. 测试一下,使用Vant Weapp提供的组件 1. Vant Weapp 介绍 Vant 是一个轻量、可靠的移动端组件…

Three.js环境光,平行光,点光源,聚光灯的创建和灯光辅助线的使用

Three.js中的灯光API使用 1.环境光(AmbientLight)2.平行光(directionalLight)3.PointLight(点光源) 4.聚光灯(SpotLight)5.材质平面(PlaneGeometry)用于接收(平行光和聚…

JavaWeb项目【SpringBoot】——图书项目4.0【源码】:SpringBoot版本 springboot相关技术 项目应用

目录 项目简介思考 & 改进1.Jsp都是同步请求---->改成异步Ajax【完成】2.前端用Jsp技术落后----->用Vue框架【完成】3.架构问题:配置数据和Java代码耦合【完成】3.SQL语句和Java代码耦合【完成】4.架构问题:servlet只能处理一个请求5.响应方式…

[论文分享]MR-MAE:重构前的模拟:用特征模拟增强屏蔽自动编码器

论文题目:Mimic before Reconstruct: Enhancing Masked Autoencoders with Feature Mimicking 论文地址:https://arxiv.org/abs/2303.05475 代码地址:https://github.com/Alpha-VL/ConvMAE(好像并未更新为MR-MAE模型) …

从Vue2到Vue3【零】——Vue3简介及创建

系列文章目录 内容链接从Vue2到Vue3【零】Vue3简介及创建 文章目录 系列文章目录前言一、Vue3的发布带来了什么1.1 性能提升1.2 源码升级1.3 支持TypeScript1.4 新特性 二、创建Vue3.0工程2.1 什么是Vite2.2 利用Vite创建Vue3.0工程2.3 利用vue-cli脚手架创建Vue3.0工程 三、 …

美团JVM面试题

1. 请解释一下对象创建的过程? Java对象创建的过程主要分为以下五个步骤: 类加载检查 Java虚拟机在读取一条new指令时候,首先检查能否在常量池中定位到这个类的符号引用,并且检查这个符号引用代表的类是否被加载、解析和初始化。如果没有&a…

C#开发的OpenRA游戏之维修按钮

C#开发的OpenRA游戏之维修按钮 前面分析物品的变卖按钮,如果理解这个流程,再看其它按钮的流程,其实是一样的,所以前面的文章是关键,只有理解通透的基础之上,才能继续往下。 维修按钮的存在价值,就是当建筑物受到敌方破坏,还没有完全倒掉之前,可以使用金币来进行修理。…

快速排序的非递归实现、归并排序的递归和非递归实现、基数排序、排序算法的时间复杂度

文章目录 快速排序的非递归三数取中法选取key快速排序三路划分 归并排序的递归归并排序的非递归计数排序稳定性排序算法的时间复杂度 快速排序的非递归 我们使用一个栈来模拟函数的递归过程,这里就是在利用栈分区间。把一个区间分为 [left,keyi-1][key][keyi1,right…

Android 进程与进程之间的通信--AIDL详细教程,以传递对象为例,两个app实现

我这里案例是 通过 IPC 传递对象 (以DemoBean类为例) 如下: AIDL 使用一种简单语法,允许您通过一个或多个方法(可接收参数和返回值)来声明接口。参数和返回值可为任意类型,甚至是 AIDL 生成的其…

如何将jar 包下载到自定义maven仓库

下载命令 mvn install:install-file -Dfileartifactid-version.jar -DgroupIdgroupid -DartifactIdartifactid -Dversionversion -Dpackagingjar -DlocalRepositoryPath. -DcreateChecksumtrue参数解释 在上述命令中,需要替换以下参数: artifactid-vers…

计算机组成原理课程设计 报告

在我的博客查看:https://chenhaotian.top/study/computer-composition-principles-course-design/ 计算机组成原理课程设计 报告 一、目的和要求 深入了解计算机各种指令的执行过程,以及控制器的组成,指令系统微程序设计的具体知识&#xf…

【前端知识】React 基础巩固(二十六)——Portals 的使用

React 基础巩固(二十六)——Portals 的使用 Portals 通常&#xff0c;组件会渲染到 root 节点下。可使用 Portals 将组件渲染至其他节点。 添加 id 为 more、modal 的 div 元素 <div id"root"></div> <div id"more"></div> &l…

工作:三菱PLC之CC-Link IE Field Network通讯知识及应用

工作&#xff1a;三菱PLC之CC-Link IE Field Network通讯知识及应用 一、理论 1. 简介连接 CC-LINK-IE通讯分别有 CC-Link IE TSN&#xff0c;CC-Link IE Control Network&#xff0c;CC-Link IE Field Network&#xff0c;CC-Link IE Field Network Basic几种形式&#xff…

成功解决wget下载报错 : wget HTTP request sent, awaiting response... 403 Forbidden

成功解决wget下载报错 : wget HTTP request sent, awaiting response... 403 Forbidden 问题描述解决方案原理什么是User Agent解决 问题描述 –2023-07-15 02:32:57-- https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/Anaconda3-2023.03-Linux-x86_64.sh Resolving mi…

PyTorch: 池化-线性-激活函数层

文章和代码已经归档至【Github仓库&#xff1a;https://github.com/timerring/dive-into-AI 】或者公众号【AIShareLab】回复 pytorch教程 也可获取。 文章目录 nn网络层-池化-线性-激活函数层池化层最大池化&#xff1a;nn.MaxPool2d()nn.AvgPool2d()nn.MaxUnpool2d()线性层激…

linux 下如何安装 tar.gz包

linux 下如何安装 tar.gz包 解压缩进入解压后的文件目录下 解压缩 tar -zxvf pycharm-community-2023.1.3.tar.gz进入解压后的文件目录下 ./pycharm.sh可执行Pycharm 建议将目录转移到其他位置 我习惯使用2020版本的 下载地址

源码阅读: echo 回显程序

文章目录 1. 目的2. 原始代码3. 化简和跨平台支持4. 修改后代码的代码分析5. References 1. 目的 阅读 netbsd 9.3 的 echo.c, 练习 C 语言源码阅读的技能。 2. 原始代码 https://github.com/NetBSD/src/blob/trunk/bin/echo/echo.c /* $NetBSD: echo.c,v 1.23 2021/11/16 …

2023年Java最新面试题

由【后端面试题宝典】提供 和 equals 的区别是什么&#xff1f; 对于基本类型&#xff0c;比较的是值&#xff1b;对于引用类型&#xff0c;比较的是地址&#xff1b;equals不能用于基本类型的比较&#xff1b;如果没有重写equals&#xff0c;equals就相当于&#xff1b;如果重…

基于JavaSwing+Mysql的仓库销售管理系统

点击以下链接获取源码&#xff1a; https://download.csdn.net/download/qq_64505944/88049275 JDK1.8 MySQL5.7 功能&#xff1a;管理员与员工两个角色登录&#xff0c;基础数据查找&#xff0c;仓库查找&#xff0c;增删改查仓库信息、商品等 源码数据库文件配置文件课程设…