How to change the MySQL database file directory in Ubuntu

How to change the MySQL database file directory in Ubuntu

Preface

The company's Ubuntu server places the directories of various systems on different logical partitions. For example, the default directory /var/lib/mysql for storing MySQL database files is located in a separate partition, and the system directory /var/ is located in a separate partition. However, the size of this partition is fixed and is not enough to store the entire database file. However, the size of another system directory /data reaches T level, which greatly meets the needs, so there is a need to change the database file directory.

The following is the process I tried by referring to some articles on the Internet:

1. Stop the database service:

Use /etc/init.d/mysql stop or stop mysql

2. Create a directory for the database file (such as /mysqldb) at the target location (/data) and copy (if you no longer use the default location, you can directly mv the original database file to the new directory) the original database file directory to this directory:

cd /data

mkdir mysqldb

cp -r /var/lib/mysql /data/mysqldb/

After a period of waiting, there is a copy of the original default mysql database file directory "/mysql" under /data/mysqldb/

3. Modify the my.cnf file

# vim /etc/mysql/my.cnf

Change datadir = /var/lib/mysql datadir = /data/mysqldb/mysql

In addition, since the current my.cnf has socket = /var/run/mysqld/mysqld.sock (not sock = /var/lib/mysql/mysql.sock as mentioned on the Internet), that is, the location of the socket is not where the database file is located, you do not need to do what other web pages say, and use the following command to make a mysql.sock link:

ln -s /data/mysqldb/mysql/mysql.sock /var/lib/mysql/mysql.sock (need to copy a copy from /home/data/mysql)

4. Modify the database permissions:

# chown -R mysql:mysql /data/mysqldb/mysql/ ← Change the ownership of the database file directory to mysql

# chmod 700 /data/mysqldb/mysql/whois/ ← Change the whois attribute of the database directory to 700

# chmod 660 /data/mysqldb/mysql/whois/* ← Change the attribute of the data table in the database to 660

5. Modify the file usr.sbin.mysqld

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

Bundle

/var/lib/mysql r,

/var/lib/mysql/** rwk,

Change to

/data/mysqldb/mysql/ r,

/data/mysqldb/mysql/** rwk,

Note: Without this step, the database service will not be able to restart. It seems to be restarting, but it is stuck and unresponsive.

6. Start mysql server

/etc/init.d/apparmor restart

/etc/init.d/mysql restart (or use restart mysql)

Done!

Summarize

The above is the full content of this article. I hope that the content of this article will have certain reference learning value for your study or work. If you have any questions, you can leave a message to communicate. Thank you for your support for 123WORDPRESS.COM.

You may also be interested in:
  • How to change the database data storage directory in MySQL
  • How to implement Mysql switching data storage directory
  • Steps to change the mysql database directory in Linux
  • Detailed explanation of mysql5.5 database data directory migration method
  • centos mysql modify database directory
  • How to modify the storage directory of Mysql database?
  • How to modify the mysql data directory under Win2008 r2
  • How to relocate the MySQL data directory
  • Tutorial on creating a temporary directory for MySQL in memory

<<:  How to install MySQL and MariaDB in Docker

>>:  Vue+spring boot realizes the verification code function

Recommend

nuxt.js multiple environment variable configuration

Table of contents 1. Introduction 2. Scenario 3. ...

vue-cropper component realizes image cutting and uploading

This article shares the specific code of the vue-...

Native js to achieve seamless carousel effect

Native js realizes the carousel effect (seamless ...

Pitfall notes of vuex and pinia in vue3

Table of contents introduce Installation and Usag...

Summary of common sql statements in Mysql

1. mysql export file: SELECT `pe2e_user_to_compan...

Seven different color schemes for website design experience

The color matching in website construction is ver...

JS implements a detailed plan for the smooth version of the progress bar

The progress bar is not smooth I believe that mos...

Share 8 MySQL pitfalls that you have to mention

MySQL is easy to install, fast and has rich funct...

MySQL8 Installer version graphic tutorial

Installation The required documents are provided ...

Exploring the Linux Kernel: The Secrets of Kconfig

Get a deep understanding of how the Linux configu...

Docker binding fixed IP/cross-host container mutual access operation

Preface Previously, static IPs assigned using pip...

How to set a dotted border in html

Use CSS styles and HTML tag elements In order to ...

How to use custom images in Html to display checkboxes

If you need to use an image to implement the use ...