解决apt-get安装过程中出现的Size mismatchHash Sum mismatch问题。

事情起因

我从单位复制了一个Virtualbox虚拟机(ubuntu 15.04 Desktop)回来,准备装个git,在家里的MAC上搭建一个工作环境。结果,在第一步

$ sudo apt-get update

的时候,就出现了Hash Sum mismatch错误。没有管,接着

$ sudo apt-get install git

结果下载git-man_2.1.4-2.1_all.deb时,出现了Size mismatch错误,下载文件的大小是1266150。一开始我以为是源出现了问题,连续换了几个源都不起作用,接着在网上看到清空apt的缓存的建议,仍也不起作用。

上述问题包括:

  1. 更新时的Hash Sum mismatch问题
  2. 安装git时的Size mismatch问题

首先研究问题2

没办法,开始研究apt的Debug方法,终于找到了一个选项Debug::Acquire::http,开启之后,发现无论是我将源设置为archive.ubuntu.com还是us.archive.ubuntu.com,在下载的时候都会返回一个302的重定向,重定向到一个类似以下格式的地址http://124.205.69.167/files/1056000001BCA2E4/mirrors.163.com/ubuntu/pool/main/g/git/git-man_2.1.4-2.1_all.deb,猜测实际文件是从mirrors.163.com下载的,于是打开http://mirrors.163.com/ubuntu/pool/main/g/git/,显示git-man_2.1.4-2.1_all.deb的大小是684k,明显与前面下载的不符,于是手工下载一个,发现mirrors.163.com上的该文件实际大小就是1266150。

到此,可以推断:应该下载的是一个684K大小的文件,而实际下载了一个1266150大小的文件,所以导致安装不成功。

接下来找解决办法。首先,打开http://archive.ubuntu.com/ubuntu/pool/main/g/git/,同样显示git-man_2.1.4-2.1_all.deb的大小是684k,手工下载,查看大小是700438,明显这个应该是正确的文件。于是,下载这个文件,利用dpkg安装,然后再执行sudo apt-get install git,成功。猜测如果放到/var/cache/apt/archives,再进行安装,应该也能成功,不过没有试。

首先,为什么我制定的国外源会重定向到mirrors.163.com? 搜索发现可能的原因是我的网络运营商为ubuntu源做了优化,将国外源重定向到了mirrors.163.com,而该源的部分文件时与主源不一致。

如何才能不重定向? 感觉把源文件下载下来,用dpkg安装这个方法,不可取,如果文件多了就很麻烦,所以研究怎么才能不重定向。

  1. 首先想到的是,利用https,搜索结果发现所有的源都不支持https,失败。
  2. 在man apt.conf中,看到Acquire::http::AllowRedirect选项,开启之后,发现其他的文件也无法下载成功了,实际还是返回了重定向,而这个选项禁止重定向,导致所有文件都无法下载了,失败。
  3. 研究使用代理。在折腾半天SS之后,依然失败,原因应该是SS是Socks代理,而apt-get需要的是http代理,失败。猜测如果有http代理,这个办法应该也能起作用。

更新:

将SS转为HTTP代理:

$ sudo apt-get install polipo
$ sudo service polipo stop
$ sudo polipo socksParentProxy=localhost:1080

之后,即可以通过以下命令,通过代理更新了:

$ sudo http_proxy=http://localhost:8123 apt-get update

不过,问题1依然存在。 4. 最后,在绝望的时刻,想起了在man apt.conf中出了http和https的选项,还有ftp,搜索发现archive.ubuntu.com就支持ftp,于是,将源文件中的http都换成ftp,安装,成功。

接着研究问题1

首先,试了前文的ftp协议,依然失败。分析可能是与这个情况一致:http://askubuntu.com/questions/673647/how-can-i-troubleshoot-apt-get-update-giving-hash-sum-mismatch,后续继续跟踪该问题。

更新:

又仔细研究了一下,从第一个出现问题的链接开始:http://security.ubuntu.com/ubuntu/dists/vivid-security/main/binary-amd64/Packages

首先,在apt.conf中,打开多个可能相关的配置项:

Debug::Acquire::http true;
Debug::pkgAcquire::Auth true;
Debug::Hashs true;

$ sudo apt-get update的输出中,搜索:http://security.ubuntu.com/ubuntu/dists/vivid-security/main/binary-amd64/Packages,找到了以下内容:

Get:1 http://security.ubuntu.com vivid-security/main amd64 Packages [115 kB]
100% [1 Packages 115 kB/115 kB 100%] [Waiting for headers] [Connecting to security.ubuntu.com (91.189.91.15)]201 URI Done: http://security.ubuntu.com/ubuntu/dists/vivid-security/main/binary-amd64/Packages.bz2
RecivedHash: SHA256:0460b45fe9ace5ddb1e2080df5f75a6ee5d950fa451733991ec1b2b303bd16f6
ExpectedHash: SHA256:9daf23b84605ff833d1d280f837bd87fcbc3c7e0ca9403590985f970ee561f61 100% [1 Packages bzip2 0 B] [Waiting for headers] [Connecting to security.ubuntu.com (91.189.91.15)]201 URI Done: bzip2:/var/lib/apt/lists/partial/security.ubuntu.com_ubuntu_dists_vivid-security_main_binary-amd64_Packages.bz2
RecivedHash: SHA256:f10f6ef0486182bc9369e7912ddb9cf536c3049813ffd169b84f34dcda540ace
ExpectedHash: SHA256:9daf23b84605ff833d1d280f837bd87fcbc3c7e0ca9403590985f970ee561f61 http://security.ubuntu.com/ubuntu/dists/vivid-security/main/binary-amd64/Packages: Computed Hash: SHA256:f10f6ef0486182bc9369e7912ddb9cf536c3049813ffd169b84f34dcda540ace Expected Hash: SHA256:9daf23b84605ff833d1d280f837bd87fcbc3c7e0ca9403590985f970ee561f61
100% [Waiting for headers] [Connecting to security.ubuntu.com (91.189.91.15)]GET /ubuntu/dists/vivid-security/multiverse/binary-amd64/Packages.bz2 HTTP/1.1
Host: security.ubuntu.com
Cache-Control: max-age=0
Range: bytes=5195-
If-Range: Mon, 28 Sep 2015 14:33:00 GMT
User-Agent: Debian APT-HTTP/1.3 (1.0.9.7ubuntu4)

从上可以分析出,正确文件为

SHA256:9daf23b84605ff833d1d280f837bd87fcbc3c7e0ca9403590985f970ee561f61

而收到的,一个是

SHA256:0460b45fe9ace5ddb1e2080df5f75a6ee5d950fa451733991ec1b2b303bd16f6

一个是

SHA256:f10f6ef0486182bc9369e7912ddb9cf536c3049813ffd169b84f34dcda540ace

用浏览器打开http://security.ubuntu.com/ubuntu/dists/vivid-security/main/binary-amd64/,分别下载Packages.bz2Packages.gz,并分别解压。

$ sha256sum Packages*
0460b45fe9ace5ddb1e2080df5f75a6ee5d950fa451733991ec1b2b303bd16f6 Packages.bz2
f10f6ef0486182bc9369e7912ddb9cf536c3049813ffd169b84f34dcda540ace Packages.from.bz2
9daf23b84605ff833d1d280f837bd87fcbc3c7e0ca9403590985f970ee561f61 Packages.from.gz
b6b70b8f7838d742104904d461677652cf5120f9b8302841cb017c0c5c9dea40 Packages.gz

显然,Packages.gz包含了正确的文件,而Packages.bz2中是错误的文件,而默认下载了Packages.bz2。于是,在apt.conf设置Acquire::CompressionTypes::Order::,优先下载Packages.gz

Acquire::CompressionTypes::Order:: "gz";
Debug::Acquire::http true;
Debug::pkgAcquire::Auth true;
Debug::Hashs true;

再执行$ sudo apt-get update,成功!

参考

  1. http://askubuntu.com/questions/673647/how-can-i-troubleshoot-apt-get-update-giving-hash-sum-mismatch
  2. http://www.woonchao.com/2015/08/29/hash/

记一次apt-get无法安装git的问题的更多相关文章

  1. centos7安装git踩坑记

    之前自己是按照Git 服务器搭建这篇博客来安装git服务器的,一步步顺序下来,但git clone的时候,每次都要求输入密码.说好的SSH免密登录呢.前后搞了一天多才搞定,现在记录下踩过的坑. 坑1: ...

  2. linux(centos)下安装git并上传代码

    cat /etc/redhat-release   查看系统版本信息 >>CentOS Linux release 7.4.1708 (Core) 背景:我已经注册了github账号,之前 ...

  3. 在腾讯云的ubuntu服务器上面安装git服务器

    GitHub是一个免费托管开源代码的远程仓库.但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用.搭建Git服 ...

  4. Ubuntu 16.04安装Git及GUI客户端

    1.通过APT源安装Git命令行工具 这里不建议通过源码进行安装,增加复杂程度,且最新版本的Git在各个方面都会修复,不至于出现不能用的状态. sudo add-apt-repository ppa: ...

  5. 源码编译安装git

    debian上的git版本才2.1有点低了,为了安装最新版的2.11,我决定从源码编译安装一下. 预备工作: 1.安装编译工具.apt install -y  build-essential 2.安装 ...

  6. 在Ubuntu 18.04上安装Git

    步骤1.首先,通过运行以下命令确保您的系统和apt包列表完全更新: apt-get update -yapt-get upgrade -y 第2步.在Ubuntu 18.04上安装Git. 现在让我们 ...

  7. 【Git】2、Linux快速安装Git环境 & oh-my-zsh

    Linux快速安装Git环境 文章目录 Linux快速安装Git环境 1.Linux安装Git 2.安装zsh 3.安装oh-my-zsh 3.1.安装oh-my-zsh 3.2. 测试验证 4.小结 ...

  8. 如何在Ubuntu 18.04安装Git

    在Ubuntu 18.04安装Git 更新apt包列表 apt-get update -y apt-get upgrade -y 安装Git: apt install git 检查Git版本 git ...

  9. 在Ubuntu 16.10 安装 git 并上传代码至 git.oschina.net

    1. 注册一个账号和创建项目 先在git.oschina.net上注册一个账号和新建一个project ,如project name 是"myTest". 2.安装git sudo ...

随机推荐

  1. Sublime Text 插件之常用20个插件

    作为一个开发者你不可能没听说过 Sublime Text.不过你没听说过也没关系,下面让你明白. Sublime Text是一款非常精巧的文本编辑器,适合编写代码.做笔记.写文章.它用户界面十分整洁, ...

  2. es6模板字符串 问题记录

    自古无图无真相,望各位博主在条件允许的情况下,配张图片吧! 界面是用join拼接的,当循环td的时候会产生一个空串,界面就会出现一个逗号, 虽然功能块算实现了,不过始终美中不足,然后想到的办法是替换所 ...

  3. fadein()

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. Intent的属性介绍

    在Android系统的设计中有四大组件:Activity,Service,BroadcastReceiver,ContentProvider.Intent可以被应用于ContentProvider之外 ...

  5. C#winform MDI子窗体打开时内容显示不全

    出现这种情况一般是 打开了多个MDI的子窗体,打开新窗体的时候关闭其他的子窗体就OK了, 具体代码: foreach (Form form in main.MdiChildren)           ...

  6. Remote Desktop Connection Manager介绍

    Remote Desktop Connection Manager (RDCMan) 是微软Windows Live体验团队的主要开发者 Julian Burger开发的一个远程桌面管理工具.简称为R ...

  7. CSS常用中文字体、字号

    字体(font-family): 新细明体:PMingLiU 细明体:MingLiU 标楷体:DFKai-SB 黑体:SimHei 宋体:SimSun 新宋体:NSimSun 仿宋:FangSong  ...

  8. C++ Iterator迭代器介绍及Iterator迭代器用法代码举例

    C++ Iterator迭代器介绍 迭代器可被用来访问一个容器类的所包函的全部元素,其行为像一个指针.举一个例子,你可用一个迭代器来实现对vector容器中所含元素的遍历.有这么几种迭代器如下: 迭代 ...

  9. streams 日差管理及监控

    第一部分 stream环境的日常管理 1.capture进程管理 --capture进程信息 SET LINESIZE 200 COLUMN CAPTURE_NAME HEADING 'Capture ...

  10. vJine 第三波 之 Lua 来袭 vJine.Lua

    vJine.Lua vJine.Lua是Lua语言的C#封装库,可实现通过C#直接运行Lua脚本并与Lua脚本交互的功能. 1. 授权: MPL2.0 相关资源: nuget:(https://www ...