Docker对我目前而言,我只发掘了他部分的效用,主要是帮助我减少学习成本,比如在学习redis,或者是消息队列的时候,能够减少装环境的成本。那么废话不多说,下面直接上干活。

一、docker的思想:

1、集装箱: 会将所有需要的内容放到不同的集装箱中,谁需要这个环境,就直接拿到这个集装箱就可以了,

2、标准化:

1、运输的标准化:docker有一个码头,所有上传的集装箱都放在这个码头上,当谁需要某一个环境时,只需要让大海豚去搬运这个集装箱就可以了,

2、命令的标准化: docker提供了一系列命令,帮助我们获取集装箱

3、提供了REST的API,并繁衍了很多图形化界面的操作

3、隔离性:docker在运行集装箱的内容时,会在Linux的内核中单独开辟一块空间,这块空间不会影响到其他程序。

二、docker的安装:

1、安装docker的依赖: yum -y install yum-utils device-mapper-persistent-data lvm2

2、设置docker的下载镜像源:

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3、安装docker:yum makecache fast yum -y install docker-ce (需要分别运行)

4、 启动,并设置为开机自动启动,测试

启动Docker服务

systemctl start docker

设置开机自动启动

systemctl enable docker # 开机自动启动docker

systemctl restart docker # 重启dokcer

测试 hello wold

docker run hello-world

启动一个redis服务

sudo docker run -p 6379:6379 --name redis -v /data/redis/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes

docker的中央仓库

1、docker官方的中央仓库下载很慢,但是资源最全,因为是在国外

2、我们一般使用蜂巢和阿里云的镜像,

3、在公司内部会采用私服

4、hub.daocloud.io

下面是配置私服:

需要在/etc/docker/daemon.json

{

“registry-mirrors”:[“https://registry.docker-cn.com”],

}

重启两个服务

systemctl daemon-reload

systemctl restart docker

三、docker镜像操作

1、拉取镜像到本地: docker pull 镜像名称 [版本] 不写版本会拉取一个默认的版本 方括号表示里面的类容可写可不写

拉取时可以去 hub.daocloud.io中寻找合适的版本,然后复制地址即可

docker pull 地址

Docker 即学即用教程 ------1_linux

可能出现的问题,报 :Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?

解决方法:

重启一下容器试试

sudo systemctl start docker

2、查看所有的本地镜像:

docker images

Docker 即学即用教程 ------1_微服务_02

3、删除本地镜像

docker rmi 唯一标识符

删除时可能会报错:

运行中不能被删除,需要先停用,

4、镜像的导入与导出(不规范)

将本地的镜像导出

docker save -o 导出的路径 镜像id

加载本地的镜像文件

docker load -i 镜像文件

修改镜像名称

docker tag 镜像id 新镜像名称:版本

四、docker容器的操作

1、运行容器: docker run 镜像的标识 | 容器名称[:tag] # 如果本地有会直接运行,如果没有,将会下载运行 (这都是简单的操作)

2、常用参数: docker run -d -p 宿主机端口:容器端口 --name 容器名称 镜像的标识|镜像名称[:tag]

-d 代表后台运行

-p 宿主机端口:容器端口 主要是用于映射,我们在访问容器内的mysql时,需要先找到linux的端口,然后再由linux映射到容器的端口,才能找到。也就是说,这里相当于是一个桥梁

测试

3、查看容器日志:

docker logs

4、 进入到容器内部

docker exec -it 容器id bash

5、 退出容器内部 exit

6、删除容器(删除容器前,需要停止容器)

docker stop 容器id # 停止指定的容器

docker stop $(docker ps -qa) # 停止全部容器

docker rm 容器id # 删除指定的容器

docker rm $(docker ps -qa) # 删除全部容器

docker start 容器id # 启动容器

docker启动mysql:

docker run -d -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=root daocloud.io/library/mysql:5.7.4