logo

English

이곳의 프로그래밍관련 정보와 소스는 마음대로 활용하셔도 좋습니다. 다만 쓰시기 전에 통보 정도는 해주시는 것이 예의 일것 같습니다. 질문이나 오류 수정은 siseong@gmail.com 으로 주세요. 감사합니다.

MacOS mysql 비밀번호 분실 시 재설정하기

by digipine posted Nov 14, 2017
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print

MySQL을 설치할 때 임시 Password를 부여하는 이것을 무시하고 설치했거나 정말로 비밀번호를 잊어버렸을때에 재설정하는 방법을 설명합니다.

아래와 같이 입력하면 인증을 생략하고 안전모드로 데몬을 실행한다. 즉, 비밀번호 없이도 MySQL에 접속할 수 있게 된다. (여기서도 많이 헤맸다. 해당 경로로 이동해서 그대로 mysqld_safe –skip-grant-tables 명령어를 치면 실행할 수 없는 명령이라고 나오는데, 반드시 관리자 권한(sudo)로 실행하고 경로에도 ./를 붙여서 실행해야 한다) 그리고 이 단계에서 비밀번호를 물어보는 건 MySQL 비밀번호가 아닌 맥의 관리자 비밀번호다.

sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables

위 명령어는 실행된 상태로 유지되므로 새로운 터미널 창을 열어서 MySQL에 접속한다. 이제 비밀번호를 묻지 않고 바로 접속이 된다. (예이!) 만약 접속이 잘 안 된다면 방금 전 실행한 명령어가 완전히 실행되었는지(=바람개비가 다 사라졌는지) 확인한다.

/usr/local/mysql/bin/mysql -uroot

접속한 뒤에는 아래와 같이 비밀번호를 root로 변경한다. password=(‘root’)에 root 대신 원하는 비밀번호를 입력해도 된다. (참고로 5.7 버전 이전에는 set password=password(‘원하는 비밀번호’)였는데 컬럼명이 바꼈다.1 굳이 바뀐 컬럼명을 직접 보고자 한다면 use mysql;을 하고 show full columnes from user;를 치면 된다.)

mysql> use mysql; 
mysql> update user set authentication_string=password('root') where user='root';

마지막으로 변경사항을 적용하기 위해 flush privileges 명령어를 실행한다.

mysql> flush privileges;

MySQL 접속하기

다시 MySQL에 접속하면 잘 되는 것을 확인할 수 있다. 만약 접속이 거부되면 -uroot -proot와 같이 비밀번호까지 붙여서 한번에 실행하는 것을 시도한다.

/usr/local/mysql/bin/mysql -uroot
/usr/local/mysql/bin/mysql -uroot -proot

그런데 접속 후 명령을 실행하게 되면 다음과 같은 에러가 발생한다. ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement. 이 경우 아래 명령어를 실행하면 정상적으로 MySQL 명령을 실행할 수 있다.

mysql> use mysql; 
mysql> set password = password('원하는 비밀번호');
이제 MySQL 데몬을 종료하고 재시작하면 된다.
# ps -e | grep mysql 
# kill -9 [P_ID]
위와 같이 mysql 프로세스들을 모두 kill 해 준후 재시작하면된다. 아니면 맥을 재부팅 하거나..
TAG •

List of Articles
No. Subject Author Date Views
36 [MacOS] Terminal 에서 zsh compinit: insecure directories 경고 제거하기 lizard2019 2021.04.30 565
35 iOS - OpenURL으로 HTML에서 어플 실행 digipine 2017.11.01 568
34 [iOS, MacOS] ATS 보안 정책 가이드 digipine 2017.11.02 570
33 iOS - Sleep Mode Blocking 방법, 앱실행시 슬립모드 진입 방지 digipine 2017.11.01 572
32 [macOS] Xcode 디버깅 시 Could not attach pid 오류 해결 file lizard2019 2023.06.05 586
31 iOS - sizeWithFont 메소드 deprecated와 sizeWithAttributes digipine 2017.11.02 610
30 iOS - UILabel 에서 AttributeString 사용하기 digipine 2017.11.02 640
29 iOS - BSD Socket 네트워크 프로그래밍 digipine 2017.11.01 662
28 [iOS, MacOS] NSArray 정렬 Sorting에 대해서 digipine 2017.11.02 667
27 macOS ARP Spoofing Attack file digipine 2020.09.17 694
26 The distance estimate iBeacon signal strength lizard2019 2019.10.25 695
25 XCode 8 업데이트 후 Code Sign Error 발생 시 해결법 1 digipine 2017.11.02 711
24 iOS - NSString의 언어 인코딩 메소드 정리 digipine 2017.11.01 715
23 WatermelonDB 'jsi/jsi.h' file not found 문제 해결 file digipine 2021.04.06 732
22 OpenAL PDF, Sample Source file digipine 2017.11.02 796
21 iOS - 코드 수행시간 측정하기 - getTickCount digipine 2017.11.01 848
20 iOS - Openssl 빌드하기 digipine 2017.11.01 946
19 iOS - BLE 장치용 ANCS Library for ANCS digipine 2017.11.02 950
18 iOS - Objective C 정규식 사용법 2 digipine 2017.11.01 968
17 [swift 4] 변경 사항 정리 file 엉뚱도마뱀 2018.07.23 1020
Board Pagination Prev 1 2 3 Next
/ 3