1. 首页
  2. IT资讯

MySQL支持IPv6-TODO

MySQL支持IPv6
此处使用的MySQL版本为mysql-5.5.35-linux2.6-x86_64。

验证操作系统支持IPv6,此处是Linux操作系统

ping6 ::1

配置MySQL支持IPv6连接

在MySQL启动时绑定地址,在服务启动时使用如下参数–bind-address=addr配置,
其中addr可以是IPv4或者IPv6地址,或者主机名hostname。
修改my.cnf配置文件,在[mysqld]选项下增加bind-address = ::配置,
把bind-address配置成::可以保证同时支持IPV4和IPV6的TCP/IP的连接。

  [mysqld]bind-address = ::  

重启mysql使配置生效:
/etc/init.d/mysqld restart

创建测试用户

使用IPv4先登陆mysql,
执行命令CREATE USER 'ipv6test'@'::1' IDENTIFIED BY '123456';

给ipv6test用户增加执行权限

执行命令GRANT ALL PRIVILEGES ON . TO 'ipv6test'@'::1' IDENTIFIED BY '123456' WITH GRANT OPTION;

验证通过::1本地连接mysql数据库

输入命令mysql -h ::1 -uipv6test -p123456

新增"root@%"就可任意ip访问

和IPv4时没有区别,如果已经配置了"root@%"用户,直接使用IPv6地址即可访问。
grant all on . to root@'%' identified by 'zdh1234' with grant option;
mysql -h 2001:db8:1:0:20c:29ff:fe96:8b55 -uroot -pzdh1234

使用netstat查看3306端口:

netstat -an | grep 3306

0.0.0.0:3306
表示监听端口绑定IPv4,只支持IPv4地址连接

:::3306
表示监听端口绑定IPv4和IPv6,支持IPv4和IPv6地址连接

使用jdbc连接mysql的URL

// IPv4连接URL
// String jdbcIpv4Url = "jdbc: mysql://127.0.0.1:3306/databaseName ";
// IPv6连接URL
// String jdbcIpv6Url = "jdbc: mysql://address=(protocol=tcp)(host=2001:db8:1:0:20c:29ff:fe96:8b55)(port=3306)/database ";
注意使用IPv6地址时,必须使用address=(protocol=tcp)(host=2001:db8:1:0:20c:29ff:fe96:8b55)(port=3306)格式,
同时上面的格式中的host也兼容IPv4的格式,如下:
address=(protocol=tcp)(host=127.0.0.1)(port=3306)
所以为了同时兼容IPv4和IPv6,建议使用上面的格式连接MySQL。

注意下面的连接字符串可能过长:
address=(protocol=tcp)(host=2001:db8:1:0:20c:29ff:fe96:8b55)(port=3306)
会有如下报错:
SQLException : SQL state: HY000 java.sql.SQLException: String 'address=(protocol=tcp)(host=2001:db8:1:0:20c:29ff:fe96:8b55)(port=3306' is too long for host name (should be no longer than 60) ErrorCode: 1470
可以使用简写版本:
address=(protocol=tcp)(host=2001:db8:1:0:20c:29ff:fe96:8b55),
或者把2001:db8:1:0:20c:29ff:fe96:8b55变为主机名hostname再填写,
或者尝试升级mysql版本提供更长的字符支持。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31551496/viewspace-2212512/,如需转载,请注明出处,否则将追究法律责任。

主题测试文章,只做测试使用。发布者:℅傍ㄖ免沦陷dε鬼,转转请注明出处:http://www.cxybcw.com/190830.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code