집 >데이터 베이스 >MySQL 튜토리얼 >Centos7에서 mysql 데이터베이스를 원격으로 연결할 수 없는 이유와 자세한 해결 방법
MySQL은 오라클에서 개발한 오픈소스 SQL 데이터베이스 관리 시스템으로, Centos7에서 mysql 데이터베이스에 원격접속이 안되는 이유와 해결방법을 주로 샘플코드를 통해 소개하고 있습니다. 필요합니다. 참고자료로 활용하시면 됩니다. 아래를 살펴보겠습니다.
머리말
최근 직장에서 문제가 발생했습니다. Centos7 시스템에서 원격으로 mysql에 연결할 수 없다는 것을 발견하고 관련 정보를 검색하여 해결했습니다. 원격접속 실패 문제. Mysql 데이터베이스에 접속해서 시도한 방법으로 드디어 문제가 해결되었습니다. 그래서 이 문제를 겪고 있는 친구들을 위해 요약하고 공유하겠습니다. 아래에서는 자세한 소개를 살펴보겠습니다.
두가지 이유가 있습니다
데이터베이스가 인증되지 않았습니다
서버 방화벽이 포트 3306을 열지 않습니다
1. 데이터베이스가 인증되지 않았습니다
인증이 없습니다 mysql 데이터베이스의 경우 하나만 사용하면 됩니다. 주문하세요.
mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION; //远程连接数据库的时候需要输入用户名和密码 用户名:root 密码:123456 指点ip:%代表所有Ip,此处也可以输入Ip来指定Ip 输入后使修改生效还需要下面的语句 mysql>FLUSH PRIVILEGES;
2. 서버 방화벽이 포트 3306을 열지 않습니다
centos에는 FirewallD와 iptables 방화벽이라는 두 가지 방화벽이 있습니다.
centos7은 FirewallD 방화벽을 사용합니다.
FirewallD는 지속적인 네트워크 트래픽 규칙을 구현하는 iptables용 프런트엔드 컨트롤러입니다. 명령줄과 그래픽 인터페이스를 제공하며 대부분의 Linux 배포판 리포지토리에서 사용할 수 있습니다. iptables를 직접 제어하는 것과 비교할 때 FirewallD를 사용하는 데에는 두 가지 주요 차이점이 있습니다.
1. FirewallD는 체인 규칙 대신 영역과 서비스를 사용합니다.
2. 규칙 세트를 동적으로 관리하여 기존 세션 및 연결을 파괴하지 않고 규칙을 업데이트할 수 있습니다.
FirewallD는 iptables 규칙을 더 쉽게 관리할 수 있게 해주는 iptables 주변 래퍼입니다. iptables를 대체하는 것은 아닙니다. iptables 명령을 FirewallD와 함께 사용할 수 있지만 FirewallD를 사용할 때는 FirewallD 명령만 사용하는 것이 좋습니다.
1. FirewallD 방화벽은 포트 3306
firewall-cmd --zone=public --add-port=3306/tcp --permanent
명령 의미:
--zone #作用域 --add-port=3306/tcp #添加端口,格式为:端口/通讯协议 --permanent #永久生效,没有此参数重启后失效
방화벽을 다시 시작하세요
systemctl restart firewalld.service
2.iptables는 포트 3306
을 개발합니다.
/sbin/iptables -I INPUT -p tcp -dport 3306 -j ACCEPT /etc/rc.d/init.d/iptables save
요약
위 내용은 Centos7에서 mysql 데이터베이스를 원격으로 연결할 수 없는 이유와 자세한 해결 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!