本地Mysql开启远程访问(图文)

目录

  • [1. 问题所示](#1. 问题所示)
  • [2. 原理分析](#2. 原理分析)
  • [3. 解决方法](#3. 解决方法)

1. 问题所示

事因是访问同事的数据库时,出现无法访问

java 复制代码
出现1130 - Host 'IT07' is not allowed to connect to this MySQL server

截图如下:

2. 原理分析

如果账号密码地址都正常的情况下,这是没开开启远程访问

  1. 编辑MySQL配置文件 :通常是my.cnf或my.ini,具体取决于你的操作系统和安装方式
    在配置文件中,需要找到bind-address参数,并将其设置为MySQL服务器的IP地址或0.0.0.0,以允许来自任何IP地址的连接

对所有网络接口开放,因此请确保在安全网络环境中执行此操作

sql 复制代码
bind-address = 0.0.0.0
  1. 创建远程访问 :默认情况下,MySQL服务器只允许本地连接(也可使用自带的账户,下述逻辑可忽略)

需要在MySQL中为远程用户创建帐户并授予适当的权限

使用以下命令登录MySQL服务器:

bash 复制代码
mysql -u 用户名 -p

创建一个允许远程访问的用户(例如,用户名为remote_user,密码为password,并允许从任何主机连接):

sql 复制代码
CREATE USER 'remote_user'@'%' IDENTIFIED BY 'password';
  1. 设置远程访问
    授予用户所需的权限,例如,如果用户需要对某个用户进行读写访问:
sql 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'remote_user'@'%' WITH GRANT OPTION;
  1. 刷新权限以确保更改生效:
sql 复制代码
FLUSH PRIVILEGES;

命令行结束之后还需要开启端口映射

具体步骤如下:在window中搜索高级安全Windows Defender防火墙的入站规则

开启本地端口的映射:

如果执行到这一步还不行

请完善后续两步操作

  • 防火墙设置:服务器上启用了防火墙,请确保允许MySQL服务器的TCP端口(通常是3306端口)的流量通过防火墙
  • 重启MySQL服务:保存并关闭配置文件后,重新启动MySQL服务器以使更改生效

3. 解决方法

最终操作完成后,可以进行访问:

相关推荐
l1t7 小时前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
MarkHard12311 小时前
如何利用redis使用一个滑动窗口限流
数据库·redis·缓存
island131413 小时前
【Redis#10】渐进式遍历 | 数据库管理 | redis_cli | RES
数据库·redis·bootstrap
心想事成的幸运大王13 小时前
Redis的过期策略
数据库·redis·缓存
倔强的石头_13 小时前
CentOS 上安装KingbaseES(ISO包)详细教程
数据库
2401_8979300613 小时前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
诗句藏于尽头14 小时前
Django模型与数据库表映射的两种方式
数据库·python·django
寻星探路14 小时前
数据库造神计划第六天---增删改查(CRUD)(2)
java·大数据·数据库
盖世英雄酱5813615 小时前
Read timed out问题 排查
java·数据库·后端
云动雨颤16 小时前
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
数据库·spring boot·tomcat