github无法访问时,应依次排查网络连通性、dns解析、hosts文件、dns污染及https证书问题。具体包括ping测试、更换公共dns、清理hosts、比对全球dns解析结果、校准系统时间并禁用安全软件干扰。

如果您尝试访问 GitHub 网址但页面无法加载,则可能是由于本地网络连接异常、DNS 解析失败或域名解析路径受干扰所致。以下是针对性的网络与 DNS 排查方法:
一、验证网络连通性与基础连接状态
该步骤用于确认设备是否具备基本互联网访问能力,并排除物理层或路由层中断问题。若其他网站可正常打开而仅 GitHub 不可用,则问题更可能集中于 DNS 或 HTTPS 层面。
1、在命令行中执行 ping github.com,观察是否返回有效 IP 地址及响应延迟;
2、若出现“请求超时”或“无法解析主机名”,说明网络未通或 DNS 未响应;
3、尝试访问 https://www.baidu.com 或 https://www.qq.com,验证其他 HTTPS 网站是否可正常加载;
4、重启路由器与光猫,等待约 60 秒后重新测试 GitHub 访问状态。
二、检测并更换 DNS 服务器
DNS 污染或运营商 DNS 返回过期 IP 是导致 GitHub 打不开的高频原因。更换为抗污染、低延迟的公共 DNS 可绕过本地解析故障。
1、Windows 用户:进入“控制面板→网络和 Internet→网络连接→当前连接→属性→Internet 协议版本 4(TCP/IPv4)→属性”,取消勾选“自动获取 DNS 服务器地址”,手动填入 8.8.8.8 和 8.8.4.4;
2、macOS 用户:前往“系统设置→网络→当前连接→详细信息→DNS”,点击“+”号添加 223.5.5.5 与 114.114.114.114;
3、Linux 用户:编辑 /etc/resolv.conf,将 nameserver 行替换为 nameserver 1.1.1.1;
4、修改完成后,在终端或命令提示符中执行刷新命令:ipconfig /flushdns(Windows)、sudo dscacheutil -flushcache; sudo killall -HUP mDNSResponder(macOS)、sudo systemd-resolve --flush-caches(Linux)。
三、排查 hosts 文件干扰项
旧版加速脚本或手动配置可能在 hosts 中写入已失效的 GitHub 域名映射,造成强制解析至不可达 IP,反而阻断访问。
1、Windows 路径:用记事本“以管理员身份运行”,打开 C:\Windows\System32\drivers\etc\hosts;
2、macOS/Linux 路径:终端执行 sudo nano /etc/hosts;
3、在文件中搜索关键词 github.com、assets-cdn.github.com、raw.githubusercontent.com;
4、删除所有包含上述域名的行,保存文件;
5、立即执行 DNS 缓存刷新命令,避免残留解析生效。
四、测试 DNS 解析结果准确性
直接比对不同 DNS 服务对 github.com 的解析结果,可快速定位是否为 DNS 污染所致。
1、访问在线 DNS 查询工具,如 https://dnschecker.org/#A/github.com;
2、输入 github.com,查看全球多个节点返回的 IP 是否一致;
3、若国内节点返回 IP 明显不同于海外主流节点(如 140.82.x.x 系列以外的地址),则确认存在 DNS 污染;
4、此时应优先采用第二步中的 DNS 更换方案,而非依赖本地 hosts 静态映射。
五、检查 HTTPS 连接与证书有效性
GitHub 强制使用 HTTPS,若 TLS 握手失败(如证书错误、时间偏差、中间人劫持),浏览器将阻止页面加载,即使网络与 DNS 正常。
1、核对系统时间是否准确,误差不得超过 ±5 分钟;
2、在 Chrome 地址栏输入 chrome://settings/certificates,检查是否有非系统预置的根证书被安装;
3、临时关闭杀毒软件、防火墙或具有 HTTPS 扫描功能的安全工具;
4、尝试在隐身模式下访问 GitHub,排除浏览器扩展干扰。










