centos7下docker安装设置国内镜像及常见命令

centos7下docker安装设置国内镜像及常见命令

要求

[root@localhost ~]# uname -r

在这里插入图片描述
docker要求centOs的内核版本在3.10 以上

移除旧版本

# 移除掉旧的版本
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-selinux \
                  docker-engine-selinux \
                  docker-engine

安装

[root@localhost ~]# yum -y install yum-utils device-mapper-persistent-data lvm2
[root@localhost ~]# yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
#设置yum源为阿里云
[root@localhost ~]# yum -y install docker-ce
[root@localhost ~]# docker -v

docker安装完成
在这里插入图片描述

设置国内镜像

[root@localhost ~]# mkdir -p /etc/docker
[root@localhost ~]# sudo tee /etc/docker/daemon.json <<-'EOF'
> {
> "registry-mirrors": ["http://hub-mirror.c.163.com"]
> }
> EOF
[root@localhost ~]# systemctl restart docker

国内加速地址有:

Docker中国区官方镜像

https://registry.docker-cn.com

网易

http://hub-mirror.c.163.com

ustc

https://docker.mirrors.ustc.edu.cn

中国科技大学

https://docker.mirrors.ustc.edu.cn

阿里云容器

https://almtd3fa.mirror.aliyuncs.com

常见命令

查看docker概要信息

[root@localhost ~]# docker info

镜像相关命令

查看镜像

[root@localhost ~]# docker images

REPOSITORY:镜像名称
TAG:镜像标签
IMAGE ID:镜像ID
CREATED:镜像的创建日期(不是获取该镜像的日期)
SIZE:镜像大小
这些镜像都是存储在Docker宿主机的/var/lib/docker目录下

搜索镜像

如果你需要从网络中查找需要的镜像
(格式:docker search 镜像名称)

[root@localhost ~]# docker search centos

NAME:仓库名称
DESCRIPTION:镜像描述
STARS:用户评价,反应一个镜像的受欢迎程度
OFFICIAL:是否官方
AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的

拉取镜像

拉取镜像就是从中央仓库中下载镜像到本地
(格式:docker pull 镜像名称:版本)

[root@localhost ~]# docker pull centos:7

删除镜像

按镜像ID删除镜像

[root@localhost ~]# docker rmi 99a633ad346f

删除所有镜像

docker rmi `docker images -q`

注:这个是反引号,键盘ESC键下方那个

容器相关命令

查看容器

查看正在运行的容器

[root@localhost ~]# docker ps

查看所有容器

[root@localhost ~]# docker ps -a

查看最后一次运行的容器

[root@localhost ~]# docker ps -l

查看停止的容器

[root@localhost ~]# docker ps -f status=exited

创建与启动容器

创建容器常用的参数说明:
创建容器命令:docker run
-i:表示运行容器
-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
–name :为创建的容器命名。
-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文
件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t
两个参数,创建后就会自动进去容器)。
-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

(1)交互式方式创建容器:
(格式:docker run -it --name=容器名称 镜像名称:标签 /bin/bash)

[root@localhost ~]# docker run -it --name=gohb01 centos:7 /bin/bash

退出

[root@b5ddcf1efaef /]# exit

(2)守护式方式创建容器:
(格式:docker run -di --name=容器名称 镜像名称:标签 /bin/bash)

[root@localhost ~]# docker run -id --name=gohb02 centos:7 /bin/bash

登录守护式容器方式:
(格式:docker exec -it 容器名称 (或者容器ID) /bin/bash)

[root@localhost ~]# docker exec -it gohb02 /bin/bash

停止与启动容器

停止容器:
(格式:docker stop 容器名称(或者容器ID))

[root@localhost ~]# docker stop gohb01

启动容器:
(格式:docker start 容器名称(或者容器ID))

[root@localhost ~]# docker start gohb01

文件拷贝

如果我们需要将文件拷贝到容器内可以使用cp命令
(格式:docker cp 需要拷贝的文件或目录 容器名称:容器目录)

[root@localhost ~]# docker cp anaconda-ks.cfg gohb02:/usr/local

文件从容器内拷贝出来
(格式:docker cp 容器名称:容器目录 需要拷贝的文件或目录)

[root@localhost ~]# docker cp gohb02:/usr/local/anaconda-ks.cfg af2.cfg

目录挂载

我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录
的文件从而去影响容器。
(格式:docker run -di --name=容器名 -v 宿主机目录:容器目录 镜像名称:标签)

[root@localhost ~]# docker run -di --name=gohb03 -v /usr/local/myhtml:/usr/local/myhtml centos:7

如果你共享的是多级的目录,可能会出现权限不足的提示。
这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题

[root@localhost ~]# docker inspect gohb03

查看容器运行的各种数据

(格式:docker inspect 容器名称(容器ID))

[root@localhost ~]# docker inspect gohb03

查看IP地址

[root@localhost ~]# docker inspect --format='{{.NetworkSettings.IPAddress}}' gohb03

删除容器

删除指定的容器:
(格式:docker rm 容器名称(容器ID))

[root@localhost ~]# docker rm gohb03
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章