当前位置:   article > 正文

ubuntu18.04安装docker容器

ubuntu18.04安装docker容器

Ubuntu镜像下载

https://mirrors.huaweicloud.com/ubuntu-releases/

docker安装

  1. # 第一步、卸载旧版本docker
  2. sudo apt-get remove docker docker-engine docker.io containerd runc
  3. # 第二步、更新及安装软件
  4. lu@host:~$ curl -fsSL https://get.docker.com -o get-docker.sh
  5. lu@host:~$ sudo sh get-docker.sh
  6. # Executing docker install script, commit: e5543d473431b782227f8908005543bb4389b8de
  7. + sh -c apt-get update -qq >/dev/null
  8. + sh -c DEBIAN_FRONTEND=noninteractive apt-get install -y -qq apt-transport-https ca-certificates curl >/dev/null
  9. + sh -c install -m 0755 -d /etc/apt/keyrings
  10. + sh -c curl -fsSL "https://download.docker.com/linux/ubuntu/gpg" | gpg --dearmor --yes -o /etc/apt/keyrings/docker.gpg
  11. gpg: WARNING: unsafe ownership on homedir '/home/lu/.gnupg'
  12. + sh -c chmod a+r /etc/apt/keyrings/docker.gpg
  13. + sh -c echo "deb [arch=amd64 signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu bionic stable" > /etc/apt/sources.list.d/docker.list
  14. + sh -c apt-get update -qq >/dev/null
  15. + sh -c DEBIAN_FRONTEND=noninteractive apt-get install -y -qq docker-ce docker-ce-cli containerd.io docker-compose-plugin docker-ce-rootless-extras docker-buildx-plugin >/dev/null
  16. + sh -c docker version
  17. Client: Docker Engine - Community
  18. Version: 24.0.2
  19. API version: 1.43
  20. Go version: go1.20.4
  21. Git commit: cb74dfc
  22. Built: Thu May 25 21:52:13 2023
  23. OS/Arch: linux/amd64
  24. Context: default
  25. Server: Docker Engine - Community
  26. Engine:
  27. Version: 24.0.2
  28. API version: 1.43 (minimum version 1.12)
  29. Go version: go1.20.4
  30. Git commit: 659604f
  31. Built: Thu May 25 21:52:13 2023
  32. OS/Arch: linux/amd64
  33. Experimental: false
  34. containerd:
  35. Version: 1.6.21
  36. GitCommit: 3dce8eb055cbb6872793272b4f20ed16117344f8
  37. runc:
  38. Version: 1.1.7
  39. GitCommit: v1.1.7-0-g860f061
  40. docker-init:
  41. Version: 0.19.0
  42. GitCommit: de40ad0
  43. ================================================================================
  44. To run Docker as a non-privileged user, consider setting up the
  45. Docker daemon in rootless mode for your user:
  46. dockerd-rootless-setuptool.sh install
  47. Visit https://docs.docker.com/go/rootless/ to learn about rootless mode.
  48. To run the Docker daemon as a fully privileged service, but granting non-root
  49. users access, refer to https://docs.docker.com/go/daemon-access/
  50. WARNING: Access to the remote API on a privileged Docker daemon is equivalent
  51. to root access on the host. Refer to the 'Docker daemon attack surface'
  52. documentation for details: https://docs.docker.com/go/attack-surface/
  53. ================================================================================
  54. lu@host:~$
  55. # 第三步、查看docker是否安装完成
  56. lu@host:~$ docker -v
  57. Docker version 24.0.2, build cb74dfc
  58. # 第四步、查看是否成功启动docker
  59. lu@host:~$ systemctl status docker
  60. ● docker.service - Docker Application Container Engine
  61. Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
  62. Active: active (running) since Sat 2024-05-11 15:17:44 CST; 1min 39s ago
  63. Docs: https://docs.docker.com
  64. Main PID: 15493 (dockerd)
  65. Tasks: 10
  66. CGroup: /system.slice/docker.service
  67. └─15493 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
  68. 5月 11 15:17:43 host systemd[1]: Starting Docker Application Container Engine...
  69. 5月 11 15:17:43 host dockerd[15493]: time="2024-05-11T15:17:43.435309035+08:00" level=info msg="Starting up"
  70. 5月 11 15:17:43 host dockerd[15493]: time="2024-05-11T15:17:43.441754095+08:00" level=info msg="detected 127.0.0.53 nameserver, assuming systemd-resolved, so using resolv.conf: /run
  71. 5月 11 15:17:43 host dockerd[15493]: time="2024-05-11T15:17:43.640102836+08:00" level=info msg="Loading containers: start."
  72. 5月 11 15:17:44 host dockerd[15493]: time="2024-05-11T15:17:44.219270950+08:00" level=info msg="Loading containers: done."
  73. 5月 11 15:17:44 host dockerd[15493]: time="2024-05-11T15:17:44.461539976+08:00" level=warning msg="WARNING: No swap limit support"
  74. 5月 11 15:17:44 host dockerd[15493]: time="2024-05-11T15:17:44.461699515+08:00" level=info msg="Docker daemon" commit=659604f graphdriver=overlay2 version=24.0.2
  75. 5月 11 15:17:44 host dockerd[15493]: time="2024-05-11T15:17:44.462969664+08:00" level=info msg="Daemon has completed initialization"
  76. 5月 11 15:17:44 host systemd[1]: Started Docker Application Container Engine.
  77. 5月 11 15:17:44 host dockerd[15493]: time="2024-05-11T15:17:44.575567013+08:00" level=info msg="API listen on /run/docker.sock"
  78. lu@host:~$

docker常用指令

查看本地镜像

  1. docker images
  2. docker images -q # 查看所有镜像id

搜索镜像

docker search 镜像名称

查看容器

  1. docker ps # 查看正在运行的容器
  2. docker ps -a # 查看所有容器

拉取指定镜像

  1. docker pull [images]:[version]
  2. # 例如:docker pull ubuntu:14.04

创建并启动容器

docker run 参数

创建容器并进入交互模式

  1. sudo docker run -it ubuntu:14.04 bash
  2. # 这个命令会启动一个Ubuntu容器,并为您提供一个shell 来交互,shell 终端退出则容器会关闭。

创建容器后台运行

  1. sudo docker run -d --name my_ubuntu ubuntu:14:04
  2. # 这个命令会以守护进程模式(-d)启动一个Ubuntu容器,并将其命名为 my_ubuntu。
  3. # 关闭终端容器不会退出,要想进入交互模式需要docker exec指令

例子:

  1. lu@host:~$ cat run_docker.sh
  2. #/bin/bash
  3. export MY_CONTAINER="ubuntu14.04-`whoami`"
  4. num=`sudo docker ps -a|grep -w "$MY_CONTAINER$"|wc -l`
  5. echo $num $MY_CONTAINER
  6. if [ 0 -eq $num ];then
  7. # --net=host:使容器共享宿主机的网络接口。--ipc=host:使容器可以访问宿主机的 IPC 资源。--pid=host : 使容器可以访问宿主机的进程。
  8. # --privileged:给予容器扩展的权限,允许容器访问宿主机上的所有设备,并运行一些通常被禁止的操作.
  9. sudo docker run \
  10. --net=host --ipc=host --pid=host \
  11. -it --privileged --name $MY_CONTAINER \
  12. -v $PWD:/home/share ubuntu:14.04 bash
  13. else
  14. sudo docker start $MY_CONTAINER
  15. sudo docker exec -ti $MY_CONTAINER /bin/bash
  16. fi
  17. lu@host:~$

参数:

  • --net=host:使容器使用宿主机的网络命名空间,这意味着容器将共享宿主机的网络接口

  • --ipc=host:使容器使用宿主机的 IPC 命名空间,这意味着容器可以访问宿主机的 IPC 资源。

  • --pid=host:使容器使用宿主机的 PID 命名空间,这意味着容器可以访问宿主机的进程。

  • -it:以交互模式(-i)运行容器,并为容器分配一个伪终端(-t)。

  • --privileged:给予容器扩展的权限,允许容器访问宿主机上的所有设备,并运行一些通常被禁止的操作。

  • --name $MY_CONTAINER:指定容器的名称为环境变量 MY_CONTAINER 的值。

  • -v $PWD:/home/lu:将当前工作目录($PWD)挂载到容器中的 /home/lu 目录。这允许您从宿主机访问和修改容器中的文件。

  • ubuntu:14.04:使用 ubuntu:14.04 Docker 镜像来创建容器。这个镜像是一个基于 Ubuntu 14.04 的环境。

  • bash:容器启动后执行的命令,这里是一个 Bash shell,允许您在容器中执行命令。

启动容器

  1. # 通过docker start命令来启动已部署的容器服务。
  2. docker start 容器名称

进入容器

  1. # 容器启动后,进入终端交互模式
  2. docker exec 参数

停止容器

  1. # 非交互模式下,通过docker stop命令来停止已部署的容器服务。
  2. docker stop 容器名称
  3. # 如果创建容器的同时进入到交互模式下,通过exit退出终端来停止容器
  4. # 如果是使用 docker exec进入的交互模式:
  5. # 那么退出容器只需要关闭终端或输入exit 命令不会关闭容器,必须通过docker stop命令来停止。

删除容器

docker rm 容器名称

删除镜像

docker rmi [imageID] 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/570402
推荐阅读
相关标签
  

闽ICP备14008679号