千家信息网

Centos7.3,mysql5.7环境,数据存储空间加大调整方案。

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,Centos7.3Mysql 5.7分区信息如下df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/cl_g
千家信息网最后更新 2025年01月23日Centos7.3,mysql5.7环境,数据存储空间加大调整方案。

Centos7.3

Mysql 5.7

分区信息如下

df -h

Filesystem          Size   Used   Avail Use% Mounted on/dev/mapper/cl_gr61-root   50G    6.6G   44G  14%    /devtmpfs           3.9G   0     3.9G  0%   /devtmpfs             3.9G   0     3.9G  0%   /dev/shmtmpfs             3.9G   8.3M   3.9G  1%   /runtmpfs             3.9G   0     3.9G  0%   /sys/fs/cgroup/dev/sda2           1014M   157M   858M  16%   /boot/dev/sda1           200M   9.5M   191M  5%   /boot/efi/dev/mapper/cl_gr61-home   68G    1.7G   67G   3%   /hometmpfs             782M   0     782M  0%   /run/user/0

Centos7 默认XFS格式分区


查询mysql配置信息,默认存储地址在/var/lib/mysql

cat /etc/my.cnfdatadir=/var/lib/mysqlsocket=/var/lib/mysql/mysql.socklog-error=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.pid


方案一,减小(/home)分区空间,加大(/)根分区空间,不适合生产环境。

安装备份工具,备份home分区。

yum install xfsdumpxfsdump -f /home.xfsdump /homeplease enter label for this dump session (timeout in 300 sec) -> homeplease enter label for media in drive 0 (timeout in 300 sec) -> home

将home分区取消挂载,缩减到10G(会破坏数据,一定要备份)。

umount /homelvreduce -L 10G /dev/cl_gr61/home

扩展root分区

lvextend -l +100%FREE /dev/cl_gr61/rootxfs_growfs /dev/cl_gr61/root

重新格式化home分区为xfs格式,挂载home分区,还原数据。

mkfs.xfs -f /dev/cl_gr61/homexfsrestore /home.xfsdump /homemount /home

完成后,分区信息如下

df -h

Filesystem                  Size  Used   Avail Use%    Mounted on/dev/mapper/cl_gr61-root   108G  9.1G   99G   9%           /devtmpfs                    3.9G    0  3.9G   0%         /devtmpfs                       3.9G    0  3.9G   0%          /dev/shmtmpfs                       3.9G  8.3M  3.9G   1%         /runtmpfs                       3.9G    0  3.9G   0%          /sys/fs/cgroup/dev/sda2                   1014M  174M  841M  18%       /boot/dev/sda1                   200M  9.5M  191M   5%         /boot/efi/dev/mapper/cl_gr61-home   10G   1.7G  8.4G  17%          /hometmpfs                       782M   0   782M   0%           /run/user/0


方案二,虚拟机扩展硬盘或更换大硬盘DD克隆后,扩展lvm分区,危险,仅做实验。

使用parted工具对磁盘已扩大的sda磁盘进行分区处理

parted /dev/sda

更改显示单位为磁盘扇区,查询磁盘状态,因磁盘大小已变更,如有提示修复分区,请按F回车修复

(parted) unit s(parted) print free                                                   Error: The backup GPT table is not at the end of the disk, as it should be.  This might mean that another operating system believes the disk is smaller.  Fix, by moving the backup to the end (andremoving the old backup)?Fix/Ignore/Cancel?Warning: Not all of the space available to /dev/sda appears to be used, you can fix the GPT to use all of the space (an extra 41943040 blocks) or continue with the current setting? Fix/Ignore?Number    Start     End       Size     File system  Name             Flags        34s      2047s     2014s     Free Space 1      2048s     411647s   409600s    fat16      EFI System Partition   boot 2      411648s    2508799s   2097152s   xfs 3      2508800s   266336255s  263827456s                          lvm        266336256s  629145566s  362809311s  Free Space

删除lvm分区3,将剩余空间一起重新分区,此操作可能会损失所有数据,注意4K对齐。

(parted) rm 3(parted) mkpart Partition name? [] #分区名,无就直接回车。File system type? [ext2] #文件分区类型,请勿填写,不然有可能格式化丢数据,直接回车。Start? 508800s #原lvm分区开始扇区。End?  629143551s #磁盘结束扇区。Flags? lvm #磁盘标识,填写lvm回车。--如果没有,请使用set命令更改flags(set NUMBER FLAG STATE)Error: Partition(s) 3 on /dev/sda have been written, but we have been unable to inform the kernel of the change, probably because it/they are in use.  As a result, the old partition(s) will remain inuse.  You should reboot now before making further changes.Ignore/Cancel? I # /dev/sda 分区 3 变更已写入,但未能告知内核,分区可能在使用。因此,旧的分区将保留在使用。在做其它变更前请重新启动。--这里选择忽略,不要重启系统

查看分区信息并退出parted。

(parted)print freeNumber  Start     End         Size   File system  Name             Flags      34s       2047s       2014s   Free Space 1    2048s     411647s     409600s   fat16      EFI System Partition  boot 2    411648s   2508799s    2097152s   xfs 3    2508800s  629143551s  626634752s                           lvm           629143552s  629145566s    2015s            Free Space (parted)quit

允许lvm分区sda3进行PE物理块分配,并加10G到/home,剩余空间分配到/root,用xfs_growfs进行xfs文件分区扩展。可额外使用pvs,vgs,lvs查看lvm相关信息。

pvchange -x y /dev/sda3 #允许分配指定物理卷上的PElvextend -L +10G /dev/cl_gr61/home #增加10G空间到/home分区xfs_growfs /dev/cl_gr61/home #扩展/home分区表到新增空间lvextend -l +100%free /dev/cl_gr61/root #增加剩余的所有空间到/root分区xfs_growfs /dev/cl_gr61/root #扩展/root分区表到新增空间

完成后,分区信息如下

df -h

Filesystem                Size  Used Avail Use% Mounted on/dev/mapper/cl_gr61-root  271G  9.1G  262G   4% /devtmpfs                  3.9G     0  3.9G   0% /devtmpfs                     3.9G     0  3.9G   0% /dev/shmtmpfs                     3.9G  8.3M  3.9G   1% /runtmpfs                     3.9G     0  3.9G   0% /sys/fs/cgroup/dev/sda2                1014M  174M  841M  18% /boot/dev/sda1                 200M  9.5M  191M   5% /boot/efi/dev/mapper/cl_gr61-home   20G  1.7G   19G   9% /hometmpfs                     782M     0  782M   0% /run/user/0


方案三,增加硬盘作为mysql数据专用盘,将/var/lib/mysql迁移到新硬盘/mysqldata/


创建 LVM 的一般过程:


对磁盘分区(prated) --> 创建物理卷(pvcreate) --> 创建卷组(vgcreate) --> 创建逻辑卷(lvcreate) --> 创建文件系统(mkfs) --> 挂载文件系统(mount) --> 添加到文件系统列表(/etc/fstab)


使用prated工具对新增硬盘进行处理

prarted(parted) print  all #显示所有硬盘                                                          Model: Msft Virtual Disk (scsi)Disk /dev/sdb: 2199GB  #新增的硬盘Sector size (logical/physical): 512B/4096BPartition Table: Disk Flags: (parted) select /dev/sdb #选择要操作的硬盘,一定要再三确认(parted) mklabel gpt #创建分区表格式为gptWarning: The existing disk label on /dev/sdb will be destroyed and all data on this disk will be lost. Do you want to continue?Yes/No? yes(parted) mkpartPartition name?  []?                                                      File system type?  [ext2]?                                                Start? 0%                                                                 End? 100%

查看硬盘信息

(parted) print                                                            Model: Msft Virtual Disk (scsi)Disk /dev/sdb: 2199GBSector size (logical/physical): 512B/4096BPartition Table: gptDisk Flags: Number  Start   End     Size    File system  Name  Flags 1      1049kB  2199GB  2199GB

检查4k对齐

(parted) unit s #改变单位为扇区。(parted) print  #查看4K是否对齐。2048s(开始扇区)*512B(扇区逻辑大小)/4096B(4KB),能整除一般4K就对齐。                Model: Msft Virtual Disk (scsi)Disk /dev/sdb: 4294967296sSector size (logical/physical): 512B/4096BPartition Table: gptDisk Flags: Number  Start  End          Size         File system  Name  Flags 1      2048s  4294965247s  4294963200s

设置分区标识为lvm

(parted) unit compact  #改变现实单位为混合(默认的选项)(parted) set 1  #设置分区1名字为lvm                                                          Flag to Invert? lvm                                                       New state?  [on]/off?


创建LVM物理卷

pvcreate /dev/sdb1 #创建LVM物理卷  Physical volume "/dev/sdb1" successfully created.pvs  PV         VG      Fmt  Attr PSize   PFree   /dev/sdb1          lvm2 ---    2.00t  2.00t


创建LVM卷组

vgcreate cl_gr61_mysql /dev/sdb1 #创建LVM卷组  Volume group "mysql" successfully createdvgs  VG      #PV #LV #SN Attr   VSize   VFree   mysql     1   0   0 wz--n-   2.00t  2.00t


创建LVM分区

lvcreate cl_gr61_mysql -l 100%free -n mysql #在lvm卷组cl_gr61_mysql上创建mysql分区  Logical volume "mysql" created.lvs  LV    VG            Attr       LSize   Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert mysql cl_gr61_mysql -wi-a-----   2.00t


用xfs格式,格式化分区

mkfs.xfs /dev/cl_gr61_mysql/mysqlmeta-data=/dev/cl_gr61_mysql/mysql isize=512    agcount=4, agsize=134217472 blks         =                       sectsz=4096  attr=2, projid32bit=1         =                       crc=1        finobt=0, sparse=0data     =                       bsize=4096   blocks=536869888, imaxpct=5         =                       sunit=0      swidth=0 blksnaming   =version 2              bsize=4096   ascii-ci=0 ftype=1log      =internal log           bsize=4096   blocks=262143, version=2         =                       sectsz=4096  sunit=1 blks, lazy-count=1realtime =none                   extsz=4096   blocks=0, rtextents=0


创建mysql存储目录

mkdir /mysqlmount /dev/mapper/cl_gr61_mysql-mysql /mysqldf -hFilesystem                       Size  Used Avail Use% Mounted on/dev/mapper/cl_gr61_mysql-mysql  2.0T   33M  2.0T   1% /mysqlvi /etc/fstab /dev/mapper/cl_gr61_mysql-mysql  /mysql          xfs     defaults        0 0


停止mysql服务,复制数据库数据到新目录

systemctl stop mysqld.service cp -a -v /var/lib/mysql /mysql


变更mysql配置,修改存储目录地址

vi /etc/my.cnfdatadir = /mysql/mysql/socket = /mysql/mysql/mysql.sock


启动mysql服务,检查数据是否正常。

systemctl start mysqld.service


0