::1是IPv6环回地址,等同于IPv4的127.0.0.1,启动turnserver,出现多次以下的错误:
bind: Cannot assign requested address
0: Trying to bind fd 38 to <[::1]:3478>: errno=99
Cannot bind local socket to addr: Cannot assign requested address
0: Cannot bind DTLS/UDP listener socket to addr [::1]:3478
跟到源码src/apps/common/apputils.c中的addr_bind函数去看也没找到原因。进一步探索后,发现这是在个别linux机器上遇到这种问题,似乎与操作系统类型也没有关系(因为测试过在另一台装有同样类型的操作系统机器上却正常),怀疑与IPv6的配置有关系,或者与系统环境有关,或者这也有可能是coturn的一个bug,原因不详,我最后是这么解决的:打开配置文件turnserver.conf,把listening-device选项关掉就正常了,这一项其实不需要开启,有的系统里面,ifconfig返回的设备里不存在eth0,而叫做其他的名字,如果开启的话就要配置正确了。
# Listener interface device (optional, Linux only).
# NOT RECOMMENDED.
#
#listening-device=eth0
另外listening-ip和relay-ip也可以不用开启,turnserver会自动找到本机的ip并使用它们。