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

这篇具有很好参考价值的文章主要介绍了【运维工程师学习五】数据库之MariaDB。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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为数据库,实则它只是客户端;

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

  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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

6、验证启动——端口

netstat -utnlp

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

7、验证启动——进程

ps aux | grep mariadb

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

8、MariaDB配置文件路径

主配置文件:/etc/my.cnf #MySQL也是这个,所以说MariaDB完全兼容性!
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

vi /etc/my.cnf 

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

[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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

主配置文件解读:

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

9、MariaDB的配置选项

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

注:
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;

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

FLUSH PRIVILEGES;

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

需要先关闭虚拟机的防火墙,才能够连接成功(先前文章14、15节说过了这里不再重复,自行通过下方链接查阅)
https://blog.csdn.net/weixin_43576565/article/details/131376844
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos
连接成功
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

(1)显示已有的数据库

show databases;

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos
命令以;结尾
注意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为数据库脚本文件

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

导入之前先使用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后面跟的是该用户的密码
    【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

显示数据库中的所有表:

show tables;

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

18、数据库备份

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

(1)备份指定数据库

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

注意这一步需要推出数据库,不能在数据库内执行。
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

(2)备份所有数据库

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

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

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos

19、还原/导入数据库

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

【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos
【运维工程师学习五】数据库之MariaDB,运维工程师学习,运维,学习,数据库,运维开发,shell,ssh,centos文章来源地址https://www.toymoban.com/news/detail-564484.html

到了这里,关于【运维工程师学习五】数据库之MariaDB的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 后端开发工程师需要了解的数据库知识

      作为一为 Java 开发工程师,写数据的查询 SQL 是必备的技能。在 日常生活中,是否统计过读数据和写数据的频率。以来开发经验来说,查询数据的操作语言是多于写数据的。   有的信息系统,数据只初始化一次,甚至是服务一辈子。   接触过很多的 web 开发系统,都是为

    2024年02月08日
    浏览(54)
  • 数据库系统工程师——第五章 网络基础知识

    计算机网络的定义:利用通信设备和线路将地理位置分散的、功能独立的自主计算机系统或由计算机控制的外部设备连接起来,在网络操作系统的控制下,按照约定的通信协议进行信息交换,实现资源共享的系统。 计算机网络发展的4个阶段:具有通信功能的单机系统→具通

    2023年04月26日
    浏览(54)
  • 【数据库系统工程师】第13章 云计算与大数据处理

    ○ 关键特征 ■ 广泛的网络接入 ■ 可测量的服务 ■ 多租户 ■ 按需自服务 ■ 快速的弹性和可扩展性 ■ 资源池化 ○ 其他关键特征 ■ 虚拟化技术 ■ 可靠性高 ■ 性价比高 ○ 根据云部署模式和云应用范围 ■ 公用云 ■ 社区云 ■ 私有云 ■ 混合云 ○ 根据云计算的服务层次

    2023年04月17日
    浏览(50)
  • 云计算2主从数据库,Linux运维系统工程师面试

    配置yum源,安装数据库服务, 注意如何配置yum源 ,不再重复细节,可以参考云计算1中ftp安装篇,现在设置里检查DVD光盘文件是否连接,再进行以下操作 [root@localhost~]#mount /dev/cdrom /opt/centos 将cd设备挂载到/opt/centos,不存在的话可以先创建 [root@localhost~]#mkdir -p /opt/centos [root@loc

    2024年04月25日
    浏览(37)
  • 【运维工程师学习】Debian安装

    选择镜像文件 进入安装选择界面 graphical install 图形安装 Install 安装系统 advanced options 高级选项 Help 帮助 accessible dark contrast installer menu 无障碍暗色对比度安装程序菜单 (旨在为视力有障碍的用户提供更好的可访问性,提供了: 高对比度主题、大字体选项、屏幕阅读器支持) In

    2024年02月12日
    浏览(59)
  • 【运维工程师学习二】OS系统管理

    操作系统管理着所有的硬件资源,负责响应各个应用的资源请求。应用还没有运行的时候就只是一堆各种各样的文件( 二进制文件、文本文件 等等),运行的时候,相对系统而言就是进程。比如你启动 apache (linux下知名的web服务端),在系统中就启动了一个(或多个,假如

    2024年02月11日
    浏览(46)
  • 运维工程师第一阶段windows的学习

    计算机历史 1946-1956 电子管时代 美国兵夕法尼亚大学 5000次/s 1956-1964 晶体管时代 几十万次 1964-1972 集成电路时代 几百万到几千万 1972-至今 大规模和超大规模集成电路 几亿次到几百万亿次 计算机硬件组成 分为内设设备和外设设备。 cpu,主板,cpu散热器,内存,硬盘和光驱,显

    2024年02月15日
    浏览(50)
  • 【运维工程师学习】Centos中MySQL替换MariaDB

    把搜索出来的全删除 查看路径里那里还有mysql 全删除 再找 再删 MySQL官网tar包下载链接:https://dev.mysql.com/downloads/mysql/ 如果报错 提示: 可以执行以下命令 打开 /etc/profile 在底部添加如下命令 执行 如果不行进到 /etc/my.cnf 里 在 [mysqld] 下添加 改完密码记得回来去掉 第一次登录

    2024年02月16日
    浏览(45)
  • 值得一看!年薪50万运维安全工程师学习路线

    前言 在运维工作中,经常被贴上这样的标签:背锅侠?电脑修理工?救火队员?35岁被退休?996/007等等,安全运维工程师真的这么不堪吗? 一、运维安全是什么? 首先我们从运维工程师的工作职能入手,岗位工作内容: 1、平台架构组建 运维工程师的基本工作之一,主要负

    2024年02月03日
    浏览(63)
  • 【运维工程师学习三】Linux中Shell脚本编写

    Shell程序有很多, 如 Korn shell(ksh)、Bourne Again shell(bash)、C shell(包括csh与tcsh) 等等, 各主要操作系统下缺省的shell: AIX下是 Korn Shell Solaris缺省的是 Bourne shell FreeBSD缺省的是 C shell HP-UX缺省的是 POSIX shell Linux缺省的是 Bourne Again shell 但这种在命令行中的命令是即时输出结果的,不

    2024年02月11日
    浏览(70)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包