项目的开发环境是 虚拟机的ubuntu系统下用mysql5.1和python2.6进行开发的,客户端是在win7下用的flash。
一直以来,操作数据库都是使用的phpmyadmin,周末在家想来以前在windows下使用sqlyog或者heidisql操作是比较好用的,就想配置一下,谁知道把mysql的配置改了一通,竟然mysql用不了了,无耐只好在ubuntu上面把mysql重新安装了。
安装完mysql后,用下面命令登陆mysql
root@ubuntu:#mysql -uroot -p
然后为mysql设置远程访问权限
mysql> grant all PRIVILEGES on *.* to 'root'@'%' identified by 'root';
mysql> flush privileges;
mysql> use information_schema
mysql> select * from user_privileges;
查询到有下面的结果:'admin'@'%',说明mysql已经授权远程连接。
接下来给iptables中添加虽则,是的mysql的3306端口可以被访问到
root@ubuntu:# sudo iptables -A INPUT -p tcp --dport 3306 -j ACCEPT
检查完网络连接和防火墙后,发现还是连接不上
root@ubuntu:# netstat -an |grep 3306
root@ubuntu:# sudo ufw status
最关键的地方是要把 /etc/mysql/my.cnf 文件里面的bind-address 修改了,默认是127.0.0.1;
打开: /etc/mysql/my.cnf
找到: bind-address = 127.0.0.1
改为: bind-address = 0.0.0.0
或者注释掉 # bind-address=127.0.0.1 这句。
重启mysql:sudo service mysql restart
这样再用sqlyog,连接成功!