>데이터 베이스 >MySQL 튜토리얼 >Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

PHPz
PHPz앞으로
2023-05-30 18:46:151384검색

1.Pycharm 구성

1. 배포 구성

Tool==》배포==》구성

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

2.Python Interpreter

파일==》설정==》프로젝트: xx== 》 Python 인터프리터

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

3. 실행/디버그 구성

Run==》구성 편집==》새 Python 구성

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

참고: pycharm에서 디버깅하려면 여기에 특별한 주의를 기울이세요. Django가 필요합니다. 형식 매개변수를 다음으로 설정하세요. runserver 0:8000

이 문장은 다음과 같이 다시 작성할 수 있습니다. 원격 코드를 로컬에서 디버깅하려면 Django 프로젝트를 0.0.0.0:8000에서 시작해야 합니다.

2. MySQL 데이터베이스 인증 문제

1. settings.py

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'computers',
        'USER': 'root',
        'PASSWORD': '123',
        'HOST': '192.168.28.128',
        'PORT': '3306'
    }
}

참고: 여기서 HOST가 원격 측에서 직접 실행될 때 "localhost"를 사용할 수 있지만 디버깅할 때는 원격으로 변경해야 합니다. pycharm 서버 IP로 원격 종료, 그렇지 않으면 다음 오류가 발생합니다:

django.db.utils.OperationalError: (1698, "사용자 'root'@'localhost'에 대한 액세스가 거부되었습니다.")

2. 원격 데이터베이스 인증

(1) my.cnf 파일을 수정합니다(우분투의 주소는:/etc/mysql/mysql.conf.d/mysqld.cnf)

필요한 경우 수정하고 그렇지 않은 경우 추가:

bind-address=0.0.0.0

(2) mysqld 서비스를 다시 시작합니다.

systemctl restart mysqld

(3) 링크 mysql

mysql -u root -p

(4) 데이터베이스 mysql

use mysql;

사용 (5) 권한 구성

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;1

매개변수 설명 :

  • " ." ---- 모든 리소스 및 모든 권한

  • "‘root’@%" — 루트는 사용자 이름을 나타냅니다. %는 모든 액세스 주소를 나타냅니다. 교체하려면 하나의 주소만 액세스할 수 있습니다.)

  • IDENTIFIED BY ‘root’, 이 루트는 액세스 비밀번호를 나타냅니다.

  • WITH GRANT OPTION을 사용하면 계단식 인증이 가능합니다.

(6) 시스템 권한 관련 테이블 데이터를 새로 고치는 것이 중요합니다.

flush privileges;

(7) 추가가 성공했는지 확인하세요

select Host, User from user;

Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법

(8) 원격 액세스 확인

원격 호스트 주소:

mysql -u root -p -h

위 내용은 Pycharm 및 MySQL 데이터베이스 인증 문제를 원격으로 디버깅하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제