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 地址
可能出现的问题,报 :Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
解决方法:
重启一下容器试试
sudo systemctl start docker
2、查看所有的本地镜像:
docker images
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