Java开发如何更改MySQL数据库datadir目录之MySQL数据库索引实现 - Go语言中文社区

Java开发如何更改MySQL数据库datadir目录之MySQL数据库索引实现


引言

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL

关于如何更改datadir目录的问题:

ubuntu默认安装mysql的时候,会将datadir设置为

/var/lib/mysql

下面,但是我们大多数时候都需要指定一个我们准备好的方便查找的目录为数据存储目录,我们可以在

my.cnf

下面更改

datadir

这一行,将'

=

'后边的目录更改成我们自己的目录即可。

例如:我将datadir改成

/data

下,则在my.cnf中做如下更改,在

[mysqld]

port = 3306

basedir = /usr

datadir = /data/mysql

更改完成保存退出,可以重启mysql服务了,不知道您的服务器会不会报错,我的反正mysql是起不来了。只要将datadir换回来就能启动。出现这个问题的原因是在ubuntu中存在一个apparmor的服务。

这个服务主要作用是主要的作用是设置某个可执行程序的访问控制权限,可以限制程序 读/写某个目录/文件,打开/读/写网络端口等等。(原来,我们虽然讲新的目录所有者改为了mysql,但我们没有告诉mysql要给新的目录什么权限,于是就悲剧了)

他的配置文件在

/etc/apparmor.d/

中,在这里我们可以看到一个

usr.sbin.mysqld

的配置文件,打开看一下就明白了。我们的日志路径、pid路径等等都存放在这里,所以我们要改datadir路径,这里也需要做更改,要更改log路径同样也要在这里更改。更改后配置如下:

/logs/mysql/mysql.log rw,

/logs/mysql/mysql.err.log rw,

/data/mysql/ r,

/data/mysql/** rwk,

/logs/mysql/ r,

/logs/mysql/* rw,

这是我更改过的路径。更改完成以后,因为这是一个服务,所以我们需要重启一下这个服务。

/etc/init.d/apparmor restart

这里基本上不会存在问题了,(我就是在这里重启了一下服务器,就OK了),如果还是无法启动你的mysql,那么请使用如下命令

mysql_install_db --datadir=/data/mysql

查看一下是不是有报错信息,根据错误排查一下。

最终按照这个方法解决了问题。真是多谢前辈。

最后本人做个总结,只作为一种尝试解决方案:

将mysql默认的datadir目录"/var/lib/mysql"改为 "/home/mysql_data"

1、关掉数据库

sudo /etc/init.d/mysql stop

2、因为我们指定的数据库文件目录为/home/mysql_data

cd /home //打开home

mkdir mysql_data //创建目录

chown mysql:mysql mysql_data //并修改其拥有者及所属群组为mysql:mysql.命令

//修改mysql配置文件my.cnf:

将 datadir=/var/lib/mysql 改为 datadir=/home/mysql_data

3、修改ubuntu中的安全设置

sudo gedit /etc/apparmor.d/usr.sbin.mysqld

在这个文件里面加入权限设定,将原来的

/var/lib/mysql/ r,

/var/lib/mysql/** rwk,

更换成(或直接添加)

/home/mysql_data/mysql/ r,

/home/mysql_data/mysql/** rwk,

4、重新初始化数据文件:执行

sudo mysql_install_data

5、启动mysql数据库服务(或重启服务器):

sudo /etc/init.d/mysql start

这个方法中最值得一提是修改

/etc/apparmor.d/usr.sbin.mysqld

这个文件,改变应用程序的权限。

MySQL索引实现

在MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的,本文主要讨论MyISAM和InnoDB两个存储引擎的索引实现方式。

MyISAM索引实现

MyISAM引擎使用B+Tree作为索引结构,叶节点的data域存放的是数据记录的地址。下图是MyISAM索引的原理图:

图1

这里设表一共有三列,假设我们以Col1为主键,则图8是一个MyISAM表的主索引(Primary key)示意。可以看出MyISAM的索引文件仅仅保存数据记录的地址。在MyISAM中,主索引和辅助索引(Secondary key)在结构上没有任何区别,只是主索引要求key是唯一的,而辅助索引的key可以重复。如果我们在Col2上建立一个辅助索引,则此索引的结构如下图所示:

图2

同样也是一颗B+Tree,data域保存数据记录的地址。因此,MyISAM中索引检索的算法为首先按照B+Tree搜索算法搜索索引,如果指定的Key存在,则取出其data域的值,然后以data域的值为地址,读取相应数据记录。

MyISAM的索引方式也叫做“非聚集”的,之所以这么称呼是为了与InnoDB的聚集索引区分。

总结

以 上就是我对Java开发如何更改MySQL数据库datadir目录之MySQL数据库索引实现 问题及其优化总结,分享给大家,觉得收获的话可以点个关注收藏转发一波喔,谢谢大佬们支持!

最后,每一位读到这里的网友,感谢你们能耐心地看完。希望在成为一名更优秀的Java程序员的道路上,我们可以一起学习、一起进步!都能赢取白富美,走向架构师的人生巅峰!

想了解学习Java方面的技术内容以及Java技术视频的内容可加群:722040762 验证码:简书(666 必过)欢迎大家的加入哟!

版权声明:本文来源简书,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://www.jianshu.com/p/d3ecc900c474
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-01-12 13:24:19
  • 阅读 ( 1658 )
  • 分类:数据库

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢