从MacOS goland无法debug到dns无法解析localhost

背景

MacOS 13.0.1

GoLand2022.2

GoLand开发golang项目,可以run,但是无法debug...

复制代码
​
/Applications/GoLand.app/Contents/plugins/go/lib/dlv/mac/dlv --listen=10.xx.xxx.129:63466 --headless=true --api-version=2 --check-go-version=false --only-same-user=false exec /private/var/folders/7p/dsbvg0k54139kxmr4fyd864w0000gn/T/GoLand/___go_build_codeup_aliyun_com_607fcd17c06031c0ebd327fc_canopia_be_business_cmd_rpc 

couldn't start listener: listen tcp 10.xx.xxx.129:63466: bind: can't assign requested address
Debugger finished with the exit code 1

​

解决思路

  1. debug无法找到正确的本地IP地址,尝试修改 /etc/hosts 强行指定

  2. goland dlv 强行指定debug进程启动时候的listen地址为127.0.0.1 (无法配置)

分析

1.日志中出现的IP,可以发现是远程dns的服务器VIP(多个ip轮巡)

2.测试 `ping localhost` ,发现解析出来的地址不是 127.0.0.1 ,还是远程dns的ip

3.尝试通过修改 /etc/hosts 和 /etc/resolv.conf 文件

  • /etc/hosts 理论上是优先级最高的配置,但是可能被一些信息安全工具修改

  • /etc/resolv.conf 一般自动修改,不需要手动,但是也可能被工具修改

尝试手动修改2个文件,发现还是不生效

4.尝试清理dns缓存,保证 /etc/hosts 生效

复制代码
sudo dscacheutil -flushcache; sudo killall -HUP mDNSResponder

清理后并没有效果...

5.尝试在 /etc/hosts 文件中配置其他,比如

复制代码
10.xx.xx.104 github.com

ping github.com 的时候无法解析到 10.xx.xx.104

6.问题逐渐变成 /etc/hosts 为什么不生效?

7.Google & chatgpt 查询,得到了一些可能的问题

  • 需要保证 /etc/hosts 是属于 root 用户 wheel 组,并且权限是644

    sudo ls -l /etc/hosts

    -rw-r--r--@ 1 root wheel 2110 8 7 22:02 /etc/hosts

  • 保证mac的网络配置是关闭自动ipv6的,使用仅本地连接

  • 某些操作系统版本,严格限制 /etc/hosts 内容的格式(或者说是bug),才会生效

要求key value之间只能有一个空格...或者tab(一个或者多个),无法混用

复制代码
# 每行的key value只能有一个空格,或者一个/多个 tab
127.0.0.1	localhost
255.255.255.255	broadcasthost
::1	localhost

解决

上面分析中需要保证的部分全部修改,之后 /etc/hosts 立刻生效;

结论:

  1. goland dlv启动本地debug进程默认是localhost,并且无法修改

2./etc/hosts 文件修改是立刻生效的,如果不生效,说明文件本身存在问题

相关推荐
且去填词6 小时前
深入理解 GMP 模型:Go 高并发的基石
开发语言·后端·学习·算法·面试·golang·go
a程序小傲6 小时前
京东Java面试被问:多活数据中心的流量调度和数据同步
java·开发语言·面试·职场和发展·golang·边缘计算
韦东东8 小时前
万元级边缘算力方案:Mac Mini在几个知识库项目的部署实践
人工智能·macos·大模型·mac mini·边缘算力·知识库应用
卜锦元9 小时前
EchoChat搭建自己的音视频会议系统01-准备工作
c++·golang·uni-app·node.js·音视频
钟离墨笺10 小时前
Go语言-->interfance{}赋值的陷阱
开发语言·后端·golang
小镇学者10 小时前
【python】python有必要像go或者nodejs那样做多版本切换吗?
开发语言·python·golang
梦想画家11 小时前
深度解析RuleGo框架:核心原理与插件机制实战
golang·规则引擎·rulego
小镇学者12 小时前
【python】macos环境升级自己安装的python3
开发语言·python·macos
且去填词12 小时前
Go 内存分配器(TCMalloc):栈与堆的分配策略
开发语言·后端·面试·golang
TESmart碲视12 小时前
解锁多屏办公效率:2026年深度解析EDID技术与KVM切换器解决方案
macos·计算机外设·kvm切换器·tesmart·双屏kvm切换器·tesmart碲视