phpEnv如何开启MySQL远程访问 phpEnv数据库外网连接配置
发布:smiling 来源: PHP粉丝网 添加日期:2026-05-03 19:28:20 浏览: 评论:0
phpEnv的MySQL默认仅监听127.0.0.1,需修改phpEnv\MySQL\my.ini中[mysqld]段的bind-address=0.0.0.0,通过控制面板重启服务,并创建'@%'用户、放行Windows防火墙3306端口,PHP连接须用局域网IP而非localhost。
phpEnv 的 MySQL 默认不监听外网,必须手动改配置
phpEnv 是 Windows 下集成环境,自带的 MySQL 默认 bind-address = 127.0.0.1,连本地其他程序(比如 Navicat)都连不上,更别说远程了。它用的不是标准 MySQL 安装包,配置文件位置和重启方式都和常规部署不同,直接套用 Linux 教程会失败。
配置文件在 phpEnv\MySQL\my.ini(不是 C:\Windows\my.ini 或其他路径)
找到 [mysqld] 段落下的 bind-address 行,把它改成:bind-address = 0.0.0.0
如果该行被注释(前面有 # 或 ;),需取消注释;如果没有这行,就手动添加在 [mysqld] 下方
保存后,**必须通过 phpEnv 控制面板重启 MySQL 服务**(不能只用命令行 net stop mysql,phpEnv 管理的是独立实例)
用户权限必须显式指定 '%' 或具体 IP,localhost 不等于通配
phpEnv 自带的 root 用户默认是 root@localhost,这个账号对任何远程 IP 都无效。即使你 ping 通了、端口也开了,连接时仍会报 Access denied for user 'root'@'xxx.xxx.xxx.xxx' —— 因为 MySQL 认为这是另一个完全不同的用户。
登录 phpEnv 自带的 MySQL:用控制面板打开「MySQL 命令行」或执行 phpEnv\MySQL\bin\mysql.exe -u root -p
运行:CREATE USER 'remote_user'@'%' IDENTIFIED BY 'StrongPass123!';
授权(不要直接给 root 远程权限):GRANT SELECT, INSERT, UPDATE, DELETE ON your_db.* TO 'remote_user'@'%';
刷新:FLUSH PRIVILEGES;
验证:SELECT Host, User FROM mysql.user WHERE User = 'remote_user';,确保看到 % 而不是 localhost
Windows 防火墙比云服务器更易忽略,3306 必须放行入站规则
phpEnv 运行在本机,没有云安全组概念,但 Windows 自带防火墙默认拦截所有入站 TCP 连接。很多用户测试时用手机或另一台 Windows 电脑连不上,查了半天网络,最后发现只是防火墙没关。
打开「Windows Defender 防火墙」→「高级设置」→「入站规则」→「新建规则」
选择「端口」→「TCP」→「特定本地端口:3306」→「允许连接」→ 勾选「域」「专用」「公用」(开发阶段可全选)
规则名称写清楚,比如 MySQL-phpEnv-3306,方便后续管理
确认生效后,可在另一台机器执行:telnet your_pc_ip 3306,能连上说明端口通了;连不上则优先排查防火墙
PHP 连接代码里 host 不能写 localhost,得用真实局域网 IP
很多人在 PHP 里写 $host = 'localhost' 或 127.0.0.1,以为只要数据库开着就能连 —— 这只对 phpEnv 自身的 PHP 有效。一旦从其他设备(比如公司内网另一台电脑、手机热点下的终端)访问,localhost 指的是那台设备自己,而不是你的 phpEnv 所在电脑。
先查你运行 phpEnv 的电脑在局域网中的 IP:ipconfig(Windows)看「IPv4 地址」,通常是 192.168.x.x 或 10.x.x.x
PHP 连接时必须用这个 IP:$host = '192.168.1.105';(别写成 localhost 或 127.0.0.1)
PDO 示例:$dsn = 'mysql:host=192.168.1.105;port=3306;dbname=test;charset=utf8mb4';
注意:如果你用的是 WiFi 热点或经常换网络,IP 可能变,建议把路由器 DHCP 设置为固定分配
最常被跳过的一步是验证 MySQL 实际监听地址 —— 改完 my.ini 后,务必进命令行运行 netstat -ano | findstr :3306,看到 0.0.0.0:3306 或 [::]:3306 才算真正生效;如果还显示 127.0.0.1:3306,说明配置没加载或服务没重启对。
Tags: phpEnv如何开启MySQL远程访问 phpEnv数据库外网连接配置
- 上一篇:phpEnv怎么更新版本 phpEnv升级最新版方法
- 下一篇:最后一页
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)
