Ubuntu 16.04에서 MySQL 데이터 디렉터리를 다른 위치로 변경하는 방법
이 기사에서는 MySQL 데이터 디렉터리를 변경하거나 MySQL 데이터베이스 데이터를 새 위치로 재배치하는 방법을 배웁니다. 이 상황은 데이터베이스가 매우 빠르게 성장하거나 보안상의 이유로 데이터 디렉터리를 복사하려는 경우에 사용될 수 있습니다. 새로운 위치로.
전제 조건
- 루트가 아닌 사용자로서 sudo 권한이 있는 Ubuntu 컴퓨터.
- MySQL이 설치되어 실행 중입니다.
- 데이터베이스 데이터 위치를 이동하려는 새 볼륨 또는 위치는 data_vol이 컴퓨터에 연결된 새 볼륨이므로 새 위치는 /mnt/data_vol/MySQL이 됩니다.
MySQL 데이터 폴더 위치 변경
계속하기 전에 , 먼저 데이터 디렉터리의 현재 위치를 찾습니다
$ mysql –u root –p Output: Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 472 Server version: 5.6.30-0ubuntu0.14.04.1 (Ubuntu) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
MySQL의 루트 비밀번호를 묻는 메시지가 나타나면 비밀번호를 입력합니다. MySQL의 현재 작업 데이터 디렉터리를 확인하려면 다음 명령을 실행하세요.
Mysql> select @@datadir; Output: +-----------------+ | @@datadir | +-----------------+ | /var/lib/mysql/ | +-----------------+ 1 row in set (0.00 sec)
출력에 표시된 것처럼 MySQL 데이터베이스는 /var/lib/MySQL을 데이터 디렉터리의 기본 폴더로 사용합니다. 무엇이든 수정하기 전에 데이터의 무결성을 확인하고 MySQL을 중지하고 상태를 확인합니다
$ sudo systemctl stop mysql
왜냐하면 systemctl은 서비스 명령
$ sudo systemctl status mysql Output: mysql.service - MySQL Community Server Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled) Active: inactive (dead) since Mon 2016-09-12 13:57:43 IST; 1s ago Process: 17669 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCCESS) Process: 17668 ExecStart=/usr/sbin/mysqld (code=exited, status=0/SUCCESS) Process: 17664 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS) Main PID: 17668 (code=exited, status=0/SUCCESS) Sep 12 13:55:14 ubuntu-16 systemd[1]: Starting MySQL Community Server... Sep 12 13:55:15 ubuntu-16 systemd[1]: Started MySQL Community Server. Sep 12 13:57:40 ubuntu-16 systemd[1]: Stopping MySQL Community Server... Sep 12 13:57:43 ubuntu-16 systemd[1]: Stopped MySQL Community Server.
에서 아무 것도 표시하지 않기 때문입니다. MySQL이 중지되었음을 확인한 후에는 데이터를 새 위치로 이동합니다. 데이터를 이동하기 위해 데이터 파일에 대한 권한을 유지하는 –a 옵션과 자세한 출력을 표시하는 –v와 함께 Rsync를 사용합니다.
다음은 데이터를 새 위치로 이동하는 전체 명령입니다.
$ rsync –av /var/lib/mysql /mnt/data_vol/ OutPut: sending incremental file list mysql/ mysql/auto.cnf mysql/debian-5.7.flag mysql/ib_buffer_pool mysql/ib_logfile0 mysql/ib_logfile1 mysql/ibdata1 mysql/mysql/ mysql/mysql/columns_priv.MYD mysql/mysql/columns_priv.MYI mysql/mysql/columns_priv.frm mysql/mysql/db.MYD mysql/mysql/db.MYI mysql/mysql/db.frm mysql/mysql/db.opt …. mysql/sys/x@0024user_summary.frmmysql/sys/x@0024user_summary_by_file_io.frm mysql/sys/x@0024user_summary_by_file_io_type.frm mysql/sys/x@0024user_summary_by_stages.frm mysql/sys/x@0024user_summary_by_statement_latency.frm mysql/sys/x@0024user_summary_by_statement_type.frm mysql/sys/x@0024wait_classes_global_by_avg_latency.frm mysql/sys/x@0024wait_classes_global_by_latency.frm mysql/sys/x@0024waits_by_host_by_latency.frm mysqlsys//x@0024waits_by_user_by_latency.frm mysql/sys/x@0024waits_global_by_latency.frm sent 199,384,083 bytes received 6,858 bytes 132,927,294.00 bytes/sec total size is 199,307,568 speedup is 1.00
rsync 후 데이터 폴더를 새 위치로 성공적으로 이동했습니다. 보안상의 이유로 데이터가 새 위치에 있음을 확인할 때까지 데이터 폴더를 유지하고 현재 데이터 디렉터리의 이름을 /var/lib/mysql에서 /var/lib/mysql_backup으로 바꿉니다. 다음은 현재 데이터 디렉토리를 변경하는 명령입니다.
다음은 현재 데이터 디렉터리를 변경하는 명령입니다.
$ sudo mv /var/lib/mysql /var/lib/mysql_backup
이제 기본 데이터 디렉터리를 변경하겠습니다. 변경하려면 여러 가지 방법이 있지만 /etc/mysql/mysql.conf.d/에 있는 파일을 편집하겠습니다. mysqld.cnf의 mysqld.cnf 파일 .
다음 명령으로 mysqld.cnf를 편집하세요
$ sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf Output: [mysqld_safe] socket = /var/run/mysqld/mysqld.sock nice = 0 [mysqld] # # * Basic Settings # user = mysql pid-file = /var/run/mysqld/mysqld.pid socket = /var/run/mysqld/mysqld.sock port = 3306 basedir = /usr datadir = /mnt/data_vol/mysql/ tmpdir = /tmp lc-messages-dir = /usr/share/mysql skip-external-locking
Apparmor 별칭 설정 변경
또한 맨 아래에 /etc/apparmor.d/tunables/alias
도 편집해야 합니다 파일의 별칭을 추가해야 합니다. 규칙에 다음 줄이 있습니다.
$ sudo vi /etc/apparmor.d/tunables/alias Output: # ------------------------------------------------------------------ # # Copyright (C) 2010 Canonical Ltd. # # This program is free software; you can redistribute it and/or # modify it under the terms of version 2 of the GNU General Public # License published by the Free Software Foundation. # # ------------------------------------------------------------------ # Alias rules can be used to rewrite paths and are done after variable # resolution. For example, if '/usr' is on removable media: # alias /usr/ -> /mnt/usr/, # # Or if mysql databases are stored in /home: # alias /var/lib/mysql/ -> /home/mysql/, alias /var/lib/mysql/ -> /mnt/data_vol/mysql
파일을 편집한 후에는 apparmor를 다시 시작해야 합니다.
다음은 의류를 다시 시작하는 명령입니다.
기본 데이터 디렉터리를 변경했으므로 스크립팅 환경을 통과하려면 최소한의 디렉터리 폴더 구조를 생성하는 다음 명령을 실행해야 합니다.
$ sudo mkdir /var/lib/mysql/mysql –p
이제 mysql 서비스를 다시 시작하겠습니다.
$ sudo systemctl start mysql
이제 다음 명령을 사용하여 MySQL 서비스의 상태를 확인합니다.
$ sudo systemctl status mysql Output: mysql.service - MySQL Community Server Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled) Active: active (running) since Mon 2016-09-12 14:17:27 IST; 23s ago Process: 18481 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCC Process: 18477 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCES Main PID: 18480 (mysqld) Tasks: 28 (limit: 512) Memory: 137.3M CPU: 329ms CGroup: /system.slice/mysql.service └─18480 /usr/sbin/mysqld Sep 12 14:17:26 ubuntu-16 systemd[1]: Starting MySQL Community Server... Sep 12 14:17:27 ubuntu-16 systemd[1]: Started MySQL Community Server.
새 데이터 디렉터리가 변경되었는지 확인하기 위해 다음 명령을 실행합니다.
$ mysql -uroot -p Output: Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.13-0ubuntu0.16.04.2 (Ubuntu) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> select @@datadir +----------------------+ | @@datadir | +----------------------+ | /mnt/data_vol/mysql/ | +-----------------+ 1 row in set (0.00 sec) mysql>
데이터 디렉터리가 변경되었음을 확인한 후, 기본 데이터 디렉토리를 삭제하겠습니다. 이 디렉토리는 /var/lib/mysql_backup에 있습니다. 다음은 이전 데이터베이스 디렉토리를 삭제하는 명령입니다.
$ sudo rm –rf /var/lib/mysql_backup
위 구성 및 단계에서 우리는 MySQL 데이터 디렉터리를 새로운 위치로 재배치하는 방법을 배웠습니다. 이는 더 많은 데이터를 다른 위치에 보호하거나 저장하는 데 도움이 됩니다.
위 내용은 Ubuntu 16.04에서 MySQL 데이터 디렉터리를 다른 위치로 변경하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL에서 파티셔닝, 샤딩, 인덱싱 및 쿼리 최적화를 포함하여 대규모 데이터 세트를 처리하기위한 전략에 대해 설명합니다.

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].

이 기사에서는 Drop Table 문을 사용하여 MySQL에서 테이블을 떨어 뜨리는 것에 대해 설명하여 예방 조치와 위험을 강조합니다. 백업 없이는 행동이 돌이킬 수 없으며 복구 방법 및 잠재적 생산 환경 위험을 상세하게합니다.

InnoDB의 전체 텍스트 검색 기능은 매우 강력하여 데이터베이스 쿼리 효율성과 대량의 텍스트 데이터를 처리 할 수있는 능력을 크게 향상시킬 수 있습니다. 1) InnoDB는 기본 및 고급 검색 쿼리를 지원하는 역 색인화를 통해 전체 텍스트 검색을 구현합니다. 2) 매치 및 키워드를 사용하여 검색, 부울 모드 및 문구 검색을 지원합니다. 3) 최적화 방법에는 워드 세분화 기술 사용, 인덱스의 주기적 재건 및 캐시 크기 조정, 성능과 정확도를 향상시키는 것이 포함됩니다.

기사는 외국 열쇠를 사용하여 데이터베이스의 관계를 나타내고 모범 사례, 데이터 무결성 및 피할 수있는 일반적인 함정에 중점을 둡니다.

이 기사에서는 PostgreSQL, MySQL 및 MongoDB와 같은 다양한 데이터베이스에서 JSON 열에서 인덱스를 작성하여 쿼리 성능을 향상시킵니다. 특정 JSON 경로를 인덱싱하는 구문 및 이점을 설명하고 지원되는 데이터베이스 시스템을 나열합니다.
