집 >데이터 베이스 >MySQL 튜토리얼 >설치된 mysql에 my.ini 파일이 없는 문제 해결 방법
오랜 시간 동안 mysql을 사용하다가 어느 날 갑자기 mysql 구성 파일인 my.ini를 사용해야 하는데 그런 파일도 없고 파일이 숨겨져 있지도 않다는 것을 알게 되었습니다.
일반적으로 mysql은 C:Program FilesMySQLMySQL Server 5.7에 설치되어 있습니다. 이전에는 mysql을 생성하기 위해 설치 패키지를 사용했기 때문에 my.ini 파일이 없습니다. 이 파일은 mysql에 관한 중요한 설정 파일이다. 그렇지 않다면 이렇게 할 수 있습니다.
저도 다른 분들의 글을 보고 그렇게 했습니다.
주의하세요. my.ini 파일 생성을 준비하기 전에 이전 데이터베이스의 모든 데이터를 sql에 덤프하세요. 이 과정에서 데이터 파일이 삭제되고 sql 서비스가 종료되기 때문입니다. 따라서 이전 데이터는 모두 삭제됩니다.
my.ini를 복원하는 첫 번째 단계:
로컬 데이터를 백업하고 백업하세요. Navicat을 사용하여 SQL을 덤프하십시오.
my.ini를 복원하는 두 번째 단계:
mysql의 bin 디렉터리에 cmd를 입력하고 Enter 키를 누릅니다.
Restore my.ini 3단계:
명령 창 입력:
Restore my.ini 4단계:
MySQL 서비스 삭제 명령: sc delete service name .
서비스 이름 확인 방법.
첫번째는 직접 느낌으로 찾아보는 방법이 많습니다.
두 번째 방법은 mysql의 포트번호 검색을 이용하는 방법입니다.
3306은 mysql의 기본 포트 번호입니다. Win+R을 누르면 cmd를 입력하여 명령줄로 들어갑니다. 명령을 입력하세요.
netstat -ano | findstr 3306
서비스 이름을 찾은 후 다음 명령을 입력하세요.
#MySql57은 내 서비스 이름입니다
sc delete MySql57
이 명령을 실행하면 MySql57 서비스가 서비스에서 삭제됩니다.
꼭 스크린샷 명령어를 사용해야 한다면 서비스를 재구성하면 되지만, 메인 서비스에 데이터가 너무 많아서 제대로 하지 않으면 메인 서비스에 영향을 미치게 되므로 백업도 해야 합니다. 데이터를 올려요. 슬레이브 데이터베이스의 동작은 마스터 데이터베이스의 동작과 동일하다. 이름만 다를 뿐입니다. 다음에는 봉사하겠습니다. 모두를 위해 스크린샷을 찍어드리겠습니다. 슬레이브 서비스의 서비스 이름은 mysqls1
삭제하기 전에 서비스를 중지해야 합니다!
두 번째 상황이 발생하는 경우 이유 중 하나는 서비스 이름이 잘못되었기 때문입니다. 다른 하나는 삭제했다는 것입니다. 두 번째 경우, 서비스에서 서비스 이름을 찾을 수 없다면 해당 서비스를 삭제했다는 의미입니다.
my.ini 복원 5단계: mysql 루트 디렉터리에 새 파일을 만들고 파일 이름을 my.ini로 지정합니다.
my.ini 복원 6단계: my.ini의 콘텐츠를 편집합니다.
basedir 및 datadir 이 두 구성은 실제 mysql 경로에 따라 편집해야 합니다.
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html [client] default-character-set = utf8 [mysql] default-character-set = utf8 [mysqld] character-set-client-handshake = FALSE character-set-server = utf8 init_connect='SET NAMES utf8' # Remove leading # and set to the amount of RAM for the most important data # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%. innodb_buffer_pool_size = 128M # Remove leading # to turn on a very important data integrity option: logging # changes to the binary log between backups. # log_bin # These are commonly set, remove the # and set as required. #注意这个地方要和你安装mysql的路径保持一致。 basedir = C:\Program Files\MySQL\MySQL Server 5.7 datadir = C:\Program Files\MySQL\MySQL Server 5.7\data port = 3306 # server_id = ..... # Remove leading # to set options mainly useful for reporting servers. # The server defaults are faster for transactions and fast SELECTs. # Adjust sizes as needed, experiment to find the optimal values. join_buffer_size = 128M sort_buffer_size = 16M read_rnd_buffer_size = 16M sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES skip-grant-tables
Restore my.ini 7단계: mysql에서 새 데이터 파일을 생성합니다
mysql의 bin 디렉터리에 cmd를 입력하고 Enter 키를 누릅니다. 명령을 입력합니다. 선.
mysqld --initialize-insecure --user=mysql
이 오류는 이전 데이터 파일을 삭제하지 않았기 때문에 발생합니다.
이러한 경우에는 주로 틴더를 사용하여 직접 분쇄합니다.
이 오류가 발생하는 경우 my.ini의 두 구성이 올바르지 않기 때문일 수 있습니다.
basedir = C:\Program Files\MySQL\MySQL Server 5.7-s1 datadir = C:\Program Files\MySQL\MySQL Server 5.7-s1\data
삭제 후 실행
恢复my.ini第八步:重新生成mysql服务,同时绑定my.ini配置文件
输入一下命令。
mysqld --install "MySql57" --defaults-file="C:/Program Files/MySQL/MySQL Server 5.7/my.ini"
如果无法启动成功重复上面的步骤。不要怕大胆干反也损失不了啥!
重复了好几遍还是不行那大概是端口冲突了吧,把my.ini文件的3306随便改一个。
恢复my.ini第九步:进入mysql修改密码
登录mysql,输入此命令。因为服务刚刚删了所以不用输入密码。
mysql -u root -p
直接回车
进入mysql后,输入
use mysql;
然后再输入
update mysql.user set authentication_string=password("123456") where user="root";
然后刷新权限并退出
flush privileges; Quit
위 내용은 설치된 mysql에 my.ini 파일이 없는 문제 해결 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!