暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

【测试开发】Docker篇-安装

383


一、环境配置的难题

软件开发最大的麻烦事之一,就是环境配置。用户计算机的环境都不相同,你怎么知道自家的软件,能在哪些机器跑起来?


用户必须保证两件事:操作系统的设置,各种库和组件的安装。只有它们都正确,软件才能运行。举例来说,安装一个 Python 应用,计算机必须有 Python 引擎,还必须有各种依赖,可能还要配置环境变量。

如果某些老旧的模块与当前环境不兼容,那就麻烦了。


开发者常常会说:"它在我的机器可以跑了",言下之意就是,其他机器很可能跑不了。


环境配置如此麻烦,换一台机器,就要重来一次,旷日费时。很多人想到,能不能从根本上解决问题,软件可以带环境安装?也就是说,安装的时候,把原始环境一模一样地复制过来。


二、虚拟机

虚拟机就是带环境安装的一种解决方案。它可以在一种操作系统里面运行另一种操作系统,比如在 Windows 系统里面运行 Linux 系统。应用程序对此毫无感知,因为虚拟机看上去跟真实系统一模一样,而对于底层系统来说,虚拟机就是一个普通文件,不需要了就删掉,对其他部分毫无影响。

虽然用户可以通过虚拟机还原软件的原始环境。但是,这个方案有几个缺点。


(1)资源占用多

虚拟机会独占一部分内存和硬盘空间。它运行的时候,其他程序就不能使用这些资源了。哪怕虚拟机里面的应用程序,真正使用的内存只有 1MB,虚拟机依然需要几百 MB 的内存才能运行。

(2)冗余步骤多

虚拟机是完整的操作系统,一些系统级别的操作步骤,往往无法跳过,比如用户登录。

(3)启动慢

启动操作系统需要多久,启动虚拟机就需要多久。可能要等几分钟,应用程序才能真正运行。




0、环境准备

docker 的安装对操作系统的内核配置要求较高所以首先我们需要确定你的系统是64位的


你需要64位的ubuntu操作系统 Cosmic 18.10、Bionic 18.04 (LTS)、Xenial 16.04 (LTS)其中之一。

docker支持的架构为:x86_64(oramd64),armhf,arm64,s390x(IBM Z), andppc64le(IBM Power)。


以下x86_64就是64位的

root@1ba628dd9cd1:~#  uname -r
3.10.0-1062.18.1.el7.x86_64

复制


查看ubuntu系统是32位的还是64位的:getconf LONG_BIT 这个命令可以直接输出具体的系统内核版本

root@1ba628dd9cd1:~# getconf LONG_BIT
64

复制

查看系统信息:lsb_release -a

root@1ba628dd9cd1:~# lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 20.04.2 LTS
Release: 20.04
Codename: focal

复制

1、安装

1.1 卸载旧版本

旧版本的 Docker 称为 docker 或者 docker-engine,使用以下命令卸载旧版本:

root@1ba628dd9cd1:~# apt-get remove docker docker-engine docker.io containerd runc
Reading package lists... Done
Building dependency tree       
Reading state information... Done
E: Unable to locate package docker-engine

复制

/var/lib/docker的内容,包括镜像、容器、卷和网络,可以保留也可以删除。

执行之后,输入docker --version仍能看到docker版本

1.2  docker --version

root@1ba628dd9cd1:~# docker --version
-bash: docker: command not found

复制

如果出现以上的内容就证明卸载完成了、如果你还是出现了版本号那么证明以上方法不足以将其卸载干净、可以使用下面的方法进行卸载

用另一种方式:

sudo apt-get purge docker

sudo apt-get purge docker-ce

sudo apt-get remove -y docker-*

sudo rm-rf var/lib/docker(慎重:这是镜像和容器的默认存储位置,不要误删

(apt-get remove 会删除软件包而保留软件的配置文件apt-get purge 会同时清除软件包和软件的配置文件)


1.3 使用存储库进行安装

apt-get update 更新下载源列表

root@1ba628dd9cd1:~# apt-get update 
Hit:1 http://archive.ubuntu.com/ubuntu focal InRelease                     
Get:2 http://security.ubuntu.com/ubuntu focal-security InRelease [114 kB]  
Get:3 http://archive.ubuntu.com/ubuntu focal-updates InRelease [114 kB]
Get:4 http://security.ubuntu.com/ubuntu focal-security/universe amd64 Packages [716 kB]
Get:5 http://archive.ubuntu.com/ubuntu focal-backports InRelease [101 kB]
Get:6 http://archive.ubuntu.com/ubuntu focal-updates/multiverse amd64 Packages [29.8 kB]
Get:7 http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages [1245 kB]
Get:8 http://security.ubuntu.com/ubuntu focal-security/restricted amd64 Packages [274 kB]
Get:9 http://security.ubuntu.com/ubuntu focal-security/main amd64 Packages [829 kB]
Get:10 http://archive.ubuntu.com/ubuntu focal-updates/universe amd64 Packages [973 kB]   
Get:11 http://security.ubuntu.com/ubuntu focal-security/multiverse amd64 Packages [27.6 kB]
Get:12 http://archive.ubuntu.com/ubuntu focal-updates/restricted amd64 Packages [299 kB]    
Fetched 4722 kB in 4s (1331 kB/s)                           
Reading package lists... Done

复制

允许apt通过https使用repository安装软件包

root@1ba628dd9cd1:~# apt-get install \
>     apt-transport-https \
>     ca-certificates \
>     curl \
>     gnupg-agent \
>     software-properties-common

复制

添加Docker官方GPG key、我们使用阿里云的源地址

root@1ba628dd9cd1:~# curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg|apt-key add -
    
Ok

复制


验证key的指纹

root@1ba628dd9cd1:~# apt-key fingerprint 0EBFCD88
    
pub   rsa4096 2017-02-22 [SCEA]
      9DC8 5822 9FC7 DD38 854A  E2D8 8D81 803C 0EBF CD88
uid           [ unknown] Docker Release (CE deb) <docker@docker.com>
sub   rsa4096 2017-02-22 [S]

复制

出现下面内容为正常情况


5)添加稳定版repository

国内阿里云版:

root@1ba628dd9cd1:~# add-apt-repository \
>    "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu \
>    $(lsb_release -cs) \
>    stable"


Get:1 https://mirrors.aliyun.com/docker-ce/linux/ubuntu focal InRelease [36.2 kB]
Get:2 https://mirrors.aliyun.com/docker-ce/linux/ubuntu focal/stable amd64 Packages [9631 B]
Hit:3 http://security.ubuntu.com/ubuntu focal-security InRelease                                        
Hit:4 http://archive.ubuntu.com/ubuntu focal InRelease                   
Hit:5 http://archive.ubuntu.com/ubuntu focal-updates InRelease
Hit:6 http://archive.ubuntu.com/ubuntu focal-backports InRelease
Fetched 45.8 kB in 2s (28.7 kB/s)
Reading package lists... Done

复制

5)我们再次更新下下载源 sudo apt-get update

6)安装最新版本的docker ce和containerd

(如果您启用了多个Docker存储库,则在apt-get install或apt-get update命令中未指定版本的情况下安装或更新将始终安装尽可能高的版本)

root@1ba628dd9cd1:~# apt-get install docker-ce docker-ce-cli containerd.i

复制

安装最新版本的 ce

apt-get install docker-ce

复制

验证docker 的版本

root@1ba628dd9cd1:~# docker --version
Docker version 20.10.6, build 370c28

复制

出现版本号证明已经成功安装了docker

启动docker

service docker restart

复制


设置开机自启动并启动 Docker-ce(安装成功后默认已设置并启动,可忽略)

sudo systemctl enable docker
sudo systemctl start docker

复制


ps:由于最近在忙着搬砖一直没给大家更新属实对不住大家,再不更新关注我的伙伴们都要跑完了,即日起开始正常更新

文章转载自测试前沿布道者,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论