【Ubuntu踩坑及解决方案(一)】

1. 问题概述(发生了什么)

在 Ubuntu 22.04(jammy)虚拟机中进行环境配置与编译 RMMock 时,先后遇到两类问题:

  1. apt update / apt install 失败:提示 Temporary failure resolving ...(域名解析失败)

  2. apt install 报错:Could not get lock /var/lib/dpkg/lock-frontend ... held by process ... (unattended-upgr)(dpkg 锁被占用)

  3. go build . 下载依赖失败:访问 https://proxy.golang.orgconnect: connection refused(Go 默认模块代理不可达)


2. 问题 1:apt update 报 "Temporary failure resolving ..."

2.1 现象(报错特征)

sudo apt update 输出大量:

  • Temporary failure resolving 'archive.ubuntu.com'

  • Temporary failure resolving 'security.ubuntu.com'

  • Temporary failure resolving 'packages.ros.org'

  • Temporary failure resolving 'packages.microsoft.com'

2.2 根因(为什么会这样)

这是 DNS 解析失败:系统无法把域名解析成 IP,所以无法访问软件源。

2.3 如何定位(如何确认是 DNS 问题)(详见:另一篇博文Unbuntu网络问题解决方案-CSDN博客)(https://blog.csdn.net/2402_87862217/article/details/156805772?spm=1001.2014.3001.5501

2.4 解决方案(修复 DNS)


3. 问题 2:apt install 报 dpkg lock 被 unattended-upgrades 占用

3.1 现象(报错特征)

执行 sudo apt install ... 出现:

  • Could not get lock /var/lib/dpkg/lock-frontend

  • It is held by process XXXX (unattended-upgr)

3.2 根因(为什么会这样)

Ubuntu 在后台运行 unattended-upgrades(无人值守自动升级)

它会占用 dpkg 锁,导致你手动运行 apt 时无法同时操作。

触发原因通常是:你刚执行了 sudo apt update,系统发现有大量安全更新,于是自动升级开始。

3.3 如何定位(确认锁是谁占的)

复制代码
ps aux | grep unattended

如果看到类似:

  • /usr/bin/unattended-upgrade

    说明后台正在升级。

3.4 正确处理方式(重点:不要乱删锁)

✅ 推荐:等待 unattended-upgrades 自动完成

判断完成标志:ps aux | grep unattended 不再出现 unattended-upgrade(只剩 grep 本身,或仅剩 shutdown guard)。

✅ 升级结束后建议执行收尾:

sudo dpkg --configure -a

3.5 结果

等待后再次安装/升级 snapd 成功,输出中出现的
disabled or static unit not running, not starting it

属于正常提示,不是错误。


4. 问题 3:go build 下载依赖失败(proxy.golang.org 连接被拒)

4.1 现象(报错特征)

go build . 时出现多行:

  • Get "https://proxy.golang.org/...": dial tcp ...:443: connect: connection refused

4.2 根因(为什么会这样)

Go 默认使用官方模块代理:

  • GOPROXY=https://proxy.golang.org

    在某些网络环境(国内、校园网、特定出口策略)下该域名可能被阻断或拒绝连接,导致依赖无法下载,从而编译失败。

4.3 如何定位(验证哪个代理可用)

用 curl 测试:

复制代码
curl -I https://proxy.golang.org curl -I https://goproxy.cn

本次结果:

  • proxy.golang.org 连接拒绝

  • goproxy.cn 返回 HTTP 200(可用)

4.4 解决方案(切换 Go 模块代理)

设置国内代理并清缓存后重试:

复制代码
go env -w GOPROXY=https://goproxy.cn,direct
go env -w GOSUMDB=sum.golang.google.cn
go clean -modcache
go build .

5. 验证清单(确保问题真的解决)

5.1 apt 正常

sudo apt update

不应再出现 Temporary failure resolving ...

5.2 dpkg 锁已释放

ps aux | grep unattended

不应再出现 unattended-upgrade 主进程

5.3 Go 代理设置正确

go env | grep -E 'GOPROXY|GOSUMDB'

5.4 构建成功

go build . ls -lh

应生成可执行文件(或至少不再报下载依赖错误)


6. 经验与预防(下次怎么避免踩坑)

  1. 新装系统 / 刚联网:先处理 DNS,再 apt update

  2. apt update 后如果系统自动升级,不要立刻 install 一堆包,先等后台升级结束

  3. 国内/受限网络编译 Go 项目:提前设置 GOPROXY 为 goproxy.cn

  4. 遇到 apt 锁:不要删锁文件 ,先确认进程并等待;必要时只用安全的 dpkg --configure -a 做收尾


相关推荐
SudosuBash8 小时前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
Coding君11 小时前
每日一Go-28、Go语言进阶-深入Go运行时:内存管理与GC
go
echo本尊4721811 小时前
如何设计一个简单易用的定时任务模块
go
哈基咪怎么可能是AI18 小时前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行1 天前
Linux和window共享文件夹
linux
Bigger2 天前
告别版本焦虑:如何为 Hugo 项目定制专属构建环境
前端·架构·go
木心月转码ing2 天前
WSL+Cpp开发环境配置
linux
刀法如飞2 天前
一款Go语言Gin框架MVC脚手架,满足大部分场景
go·mvc·gin
Coding君3 天前
每日一Go-26、Go语言进阶:深入并发模式2
go