이 기사에서는 MySQL 데이터 디렉토리를 변경하거나 MySQL 데이터베이스 데이터를 새 위치로 재배치하는 방법을 배울 것입니다. 이 상황은 데이터베이스가 매우 빠르게 성장하거나 일부 보안상의 이유로 데이터 디렉토리를 이동하려는 경우에 사용될 수 있습니다. 새 위치로 이동합니다.
전제조건
- Sudo 권한이 있는 루트가 아닌 사용자가 있는 Ubuntu 시스템.
- MySQL이 설치되어 작동 중입니다.
- 데이터베이스 데이터 위치를 이동하려는 새 볼륨 또는 위치는 data_vol이 머신 또는 서버에 연결된 새 볼륨이므로 새 위치는 /mnt/data_vol/MySQL이 됩니다.
MySQL 데이터 폴더 위치 변경
계속 진행하기 전에 먼저 데이터 디렉토리의 현재 위치를 찾습니다.
$ mysql –u root –pOutput:암호 입력:MySQL 모니터에 오신 것을 환영합니다. 명령은 로 끝납니다. 또는 \g.MySQL 연결 ID는 472Server 버전:5.6.30-0ubuntu0.14.04.1(Ubuntu)Copyright (c) 2000, 2016, Oracle 및/또는 그 계열사입니다. 판권 소유. Oracle은 Oracle Corporation 및/또는 그 계열사의 등록 상표입니다. 다른 이름은 해당 소유자의 상표일 수 있습니다.'help;'를 입력하십시오. 또는 '\h'를 입력하세요. 현재 입력 문을 지우려면 '\c'를 입력하십시오.mysql>
MySQL의 루트 암호를 묻는 메시지가 나타나면 암호를 입력하십시오. 아래 명령어를 실행하여 MySQL의 현재 작업 데이터 디렉토리를 확인하십시오.
Mysql> @@datadir 선택;출력:+-----------------+| @@datadir |+-----------------+| /var/lib/mysql/ |+-----------------+1 행 세트(0.00초)
출력은 MySQL 데이터베이스가 /var/lib/MySQL을 기본 폴더로 데이터 디렉토리로 사용함을 보여줍니다. 먼저 수정하기 전에 데이터 무결성을 확인하고 MySQL을 중지하고 상태를 확인합니다.
$ sudo systemctl mysql 중지
systemctl은 services 명령에 대해 아무 것도 표시하지 않기 때문에
$ sudo systemctl status mysqlOutput:mysql.service - MySQL 커뮤니티 서버 로드:로드됨(/lib/systemd/system/mysql.service; 활성화됨, 공급업체 사전 설정:활성화됨) 활성:2016년 9월 월부터 비활성(죽음)- 12 13:57:43 IST; 1s 전 프로세스:17669 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCCESS) 프로세스:17668 ExecStart=/usr/sbin/mysqld (code=exited, status=0 /SUCCESS) 프로세스:17664 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS) 메인 PID:17668 (code=exited, status=0/SUCCESS)Sep 12 13 :55:14 ubuntu-16 systemd[1]:MySQL Community Server 시작 중...Sep 12 13:55:15 ubuntu-16 systemd[1]:MySQL Community Server 시작 중.Sep 12 13:57:40 ubuntu-16 systemd [1]:MySQL Community Server 중지 중...Sep 12 13:57:43 ubuntu-16 systemd[1]:MySQL Community Server를 중지했습니다.
일단 MySQL이 중지되었음을 확인하고 데이터를 새 위치로 이동합니다. 데이터를 이동하려면 데이터 파일의 권한을 유지하는 -a 옵션과 자세한 출력을 표시하는 -v 옵션과 함께 Rsync를 사용합니다.
다음은 데이터를 새 위치로 이동하는 전체 명령입니다. –
$ rsync –av /var/lib/mysql /mnt/data_vol/OutPut:증분 파일 목록 보내기mysql/mysql/auto.cnfmysql/debian-5.7.flagmysql/ib_buffer_poolmysql/ib_logfile0mysql/ib_logfile1mysql/ibdata1mysql/mysql/mysql/ /columns_priv.MYDmysql/mysql/columns_priv.MYImysql/mysql/columns_priv.frmmysql/mysql/db.MYDmysql/mysql/db.MYImysql/mysql/db.frmmysql/mysql/db.opt….mysql/sys/x@0024user_summary frmmysql / SYS / X @ 0024user_summary_by_file_io.frmmysql / SYS / X @ 0024user_summary_by_file_io_type.frmmysql / SYS / X @ 0024user_summary_by_stages.frmmysql / SYS / X @ 0024user_summary_by_statement_latency.frmmysql / SYS / X @ 0024user_summary_by_statement_type.frmmysql / SYS / X @ 0024wait_classes_global_by_avg_latency.frmmysql / SYS / X @ 0024wait_classes_global_by_latency.frmmysql / SYS / X @ 0024waits_by_host_by_latency.frmmysqlsys // X @ 0024waits_by_user_by_latency.frmmysql / SYS / X @ 0024waits_global_by_latency.frmsent 199,384,083 바이트는 6,858 / 132,927,294.00 바이트를 바이트 sectotal 크기 199,307,568 고속화 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.cnfOutput:[mysqld_safe]socket =/var/run/mysqld/mysqld.socknice =0[mysqld]## * 기본 설정#user =mysqlpid -파일 =/var/run/mysqld/mysqld.pidsocket =/var/run/mysqld/mysqld.sockport =3306basedir =/usrdatadir =/mnt/data_vol/mysql/tmpdir =/tmplc-messages-dir =/usr/share /mysqlskip-external-lockingApparmor Alias 설정 변경
또한 /etc/apparmor.d/tunables/alias
를 편집해야 했습니다.파일 맨 아래에 별칭 규칙에 다음 줄을 추가해야 했습니다.
$ sudo vi /etc/apparmor.d/tunables/aliasOutput:# -------------------------------- ----------------------------------## Copyright (C) 2010 Canonical Ltd.## 이 프로그램은 무료입니다 소프트웨어; Free Software Foundation에서 발행한 GNU General Public# License 버전 2의 조건에 따라 재배포 및/또는 수정할 수 있습니다.## ------------------ ------------------------------------------------# 별칭 규칙을 사용하여 경로를 다시 작성할 수 있으며 변수# 확인 후에 수행됩니다. 예를 들어, '/usr'이 이동식 미디어에 있는 경우:# alias /usr/ -> /mnt/usr/,## 또는 mysql 데이터베이스가 /home에 저장된 경우:# alias /var/lib/mysql/ -> / 홈/mysql/,별칭 /var/lib/mysql/ -> /mnt/data_vol/mysql파일이 수정되면 의상을 다시 시작해야 합니다.
다음은 의상을 다시 시작하는 명령입니다.
기본 데이터 디렉토리를 변경했기 때문에 스크립트 환경을 전달하기 위해 최소한의 디렉토리 폴더 구조를 생성하는 아래 명령을 실행해야 했습니다.
$ sudo mkdir /var/lib/mysql/mysql –p
이제 mysql 서비스를 다시 시작합니다.
$ sudo systemctl mysql 시작이제 아래 명령을 사용하여 MySQL 서비스의 상태를 확인합니다.
$ sudo systemctl status mysqlOutput:mysql.service - MySQL 커뮤니티 서버 로드됨:로드됨(/lib/systemd/system/mysql.service; 활성화됨, 공급업체 사전 설정:활성화됨) 활성:2016-09월 월부터 활성(실행 중)- 12 14:17:27 IST; 23s 전 프로세스:18481 ExecStartPost=/usr/share/mysql/mysql-systemd-start post(code=exited, status=0/SUCC 프로세스:18477 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre(코드 =exited, status=0/SUCCES Main PID:18480 (mysqld) Tasks:28 (limit:512) 메모리:137.3M CPU:329msCGroup:/system.slice/mysql.service └─18480 /usr/sbin/mysqldSep 12 14 :17:26 ubuntu-16 systemd[1]:MySQL 커뮤니티 서버 시작 중...9월 12일 14:17:27 ubuntu-16 systemd[1]:MySQL 커뮤니티 서버 시작새 데이터 디렉토리가 변경되었는지 확인하기 위해 아래 명령을 실행합니다.
$ mysql -uroot -pOutput:비밀번호 입력:MySQL 모니터에 오신 것을 환영합니다. 명령은 로 끝납니다. 또는 \g.MySQL 연결 ID는 3Server 버전:5.7.13-0ubuntu0.16.04.2 (Ubuntu)Copyright (c) 2000, 2016, Oracle 및/또는 그 계열사입니다. 판권 소유. Oracle은 Oracle Corporation 및/또는 그 계열사의 등록 상표입니다. 다른 이름은 해당 소유자의 상표일 수 있습니다.'help;'를 입력하십시오. 또는 '\h'를 입력하세요. 현재 입력된 문을 지우려면 '\c'를 입력하십시오.mysql> @@datadir+를 선택하십시오.------------------+| @@datadir |+----------------------+| /mnt/data_vol/mysql/ |+-----------------+1 행 세트(0.00초)mysql>데이터 디렉토리가 변경되었음을 확인하면 /var/lib/mysql_backup에 있는 기본 데이터 디렉토리를 제거합니다. 아래는 이전 데이터베이스 디렉토리를 제거하는 명령입니다.
$ sudo rm –rf /var/lib/mysql_backup<블록 인용>위의 구성 및 단계에서 MySQL 데이터 디렉터리를 새 위치로 재배치하는 방법을 배웠습니다. 이는 다른 위치에 더 많은 데이터를 보호하거나 저장하는 데 도움이 됩니다.