Doom Emacs 中 TLS 支持问题的分析与解决
问题背景
在使用 Doom Emacs 时,用户可能会遇到一个与 TLS 连接相关的问题:当尝试通过 Emacs 下载内容(如使用 emojify-download-emoji 或 nerd-icons-install-fonts 命令)时,Emacs 会无限期挂起,无法完成下载操作。这个问题通常出现在从源代码编译安装 Emacs 的环境中。
问题表现
当执行需要网络连接的操作时,Emacs 会显示以下信息:
Contacting host: raw.githubusercontent.com:443
Opening TLS connection to 'raw.githubusercontent.com'...
Opening TLS connection with 'openssl s_client -connect raw.githubusercontent.com:443 -CAfile /etc/ssl/certs/ca-certificates.crt -nbio -no_ssl3 -no_tls1 -no_tls1_1 -ign_eof'...done
然后程序就会卡在这个状态,无法继续执行后续操作。
根本原因
这个问题的主要原因是 Emacs 在编译时没有正确启用 GNUTLS 支持。虽然用户在编译时使用了 --with-gnutls=ifavailable 参数,但系统可能缺少必要的开发库,导致 GNUTLS 支持实际上没有被编译进 Emacs。
解决方案
要解决这个问题,需要确保系统安装了所有必要的依赖项,并正确编译 Emacs:
-
安装必要的开发库:
libgnutls28-dev:提供 GNUTLS 开发文件libssl-dev:提供 SSL 开发支持
-
重新编译 Emacs: 在确保所有依赖项都已安装后,使用以下参数重新编译 Emacs:
./configure --without-compress-install --with-native-compilation --with-mailutils --with-gnutls=ifavailable --with-cairo --with-harfbuzz -
验证安装: 编译安装完成后,在 Emacs 中执行
M-x doom/info命令,检查 GNUTLS 是否出现在 features 列表中。
技术细节
GNUTLS 是 GNU 项目下的一个安全通信库,实现了 SSL、TLS 和 DTLS 协议。Emacs 使用 GNUTLS 来处理安全网络连接。当 Emacs 缺少 GNUTLS 支持时,它会尝试使用外部工具(如 openssl)来处理 TLS 连接,这可能导致性能问题和连接不稳定。
在 Doom Emacs 中,许多功能(如字体安装、表情符号下载等)都依赖于安全的 HTTPS 连接。因此,确保 Emacs 内置了 GNUTLS 支持对于这些功能的正常工作至关重要。
最佳实践
为了避免类似问题,建议:
- 在编译 Emacs 前,确保系统已安装所有必要的开发依赖
- 定期更新系统和开发工具链
- 在安装新功能后,检查
doom/info输出,确认所有需要的特性都已启用 - 考虑使用包管理器提供的预编译版本,除非有特殊需求需要从源代码编译
总结
TLS 连接问题是 Doom Emacs 用户可能遇到的一个常见问题,通常是由于编译时缺少必要的依赖项导致的。通过正确安装开发库并重新编译 Emacs,可以轻松解决这个问题。理解 Emacs 的网络连接机制和编译选项,有助于预防和解决类似的技术问题。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00