Docker虚拟机配置手札(centos)
一、Docker只支持CentOS7及以上系统,不支持6.x系统
二、yum安装Docker
1、安装相关环境和设置仓库
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
2、安装Docker社区版
yum install docker-ce docker-ce-cli containerd.io
Docker 安装完默认未启动。并且已经创建好 docker 用户组,但该用户组下没有用户。
3、启动Docker systemctl start docker
4、运行hello-world docker run hello-world
三、修改Docker镜像存放目录
docker 默认的存储路径在 /var/lib/docker ,但机子的数据盘挂载在/home目录下,
所以修改docker存储路径到 /home/docker 中。
1、查找 docker.service 配置文件,不知道配置文件在哪里可以用以下命令显示
systemctl disable docker systemctl enable docker #显示结果 Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.
2、修改 docker.service 配置文件
vi /usr/lib/systemd/system/docker.service
3、在里面的EXECStart找到这样一行
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock ,将其修改为
ExecStart=/usr/bin/dockerd --graph /home/docker -H fd:// --containerd=/run/containerd/containerd.sock 保存并退出
4、重载并重启docker服务
systemctl daemon-reload #重载配置文件 systemctl restart docker #重启docker systemctl enable docker #设为自启动
5、查看docker运行信息 docker info
其中 Docker Root Dir: /home/docker 即表示已经成功修改运行目录了
6、重新下载和运行hello-world镜像
docker run hello-world
四、容器和镜像的导入导出
镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
docker images 查看镜像列表; docker ps 查看容器列表;
1、保存容器为镜像 docker commit mycentos myos202005 mycentos是容器名,即现正运行的这个虚拟机的名;myos202005是导出的虚拟机镜像名,可用于发布、备份等操作;
2、导出镜像(转格式)为文件 docker save myos202005:latest > /home/myos202005.img
3、导出容器(正在运行的虚拟机)为文件 docker export mycentos > /home/myos202005.img
4、导入镜像, docker load --input /home/myos202005.img
5、导入容器, docker import /home/myos202005.img myos202005
区别:
docker save保存的是镜像(image),docker export保存的是容器(container);
docker load用来载入镜像包,docker import用来载入容器包,但两者都会恢复为镜像;
docker load不能对载入的镜像重命名,而docker import可以为镜像指定新名称。
(如果VMware中的虚拟机centos空间不足,需要扩容,参考这篇文章)
五、运行虚拟机和进入虚拟机系统
1、后台运行镜像(会新建一个容器)
docker run -itd --privileged=true --name myos202005 myos202005:latest
(注:以特权模式运行,容器中才能使用启动服务systemctl等系统命令)
2、如果有运行过,则应该启动容器 docker ps -a docker start 容器ID
2、进入容器(虚拟机),使用 docker ps 查看容器信息,然后 docker exec -it 容器ID /bin/bash
3、退出容器(虚拟机),不关闭容器 Ctrl + P + Q
4、关闭容器, docker stop 容器ID ;重启容器 docker restart 容器ID ;启动容器 docker start 容器ID
5、查看包括已退出的容器 docker ps -a ;删除容器 docker rm 容器ID ;删除镜像 docker rmi 镜像ID
PS:容器ID 和 容器名是等效的,以上命令均可以用容器名替代容器ID。
六、虚拟机端口映射
1、先分别查看本机和docker机的进程端口使用情况 netstat -nlpt
2、查看容器列表信息 docker ps
3、停止容器、停止docker服务
docker stop 容器ID systemctl stop docker
4、修改容器的配置文件,两个配置文件都要改
vi /var/lib/docker/containers/容器ID/hostconfig.jsonvi /var/lib/docker/containers/容器ID/config.v2.json
PS:如果第三步修改过docker存放目录,如 /home/docker,则配置文件的位置也在相应新的位置
例如把docker中mysql 3306端口,映射到外面的13306端口,以便远程访问docker中的数据库
5、hostconfig.json修改
找到 PortBindings ,把那一段JSON修改为 "PortBindings":{"3306/tcp":[{"HostIp":"","HostPort":"13306"}]}
6、config.v2.json修改
修改值 config > ExposedPorts 和 NetworkSettings > Ports
"Config": { .... "ExposedPorts": { "22/tcp": {}, "3306/tcp": {} }, .... }, "NetworkSettings": { .... "Ports": { "22/tcp":null, "3306/tcp": [{ "HostIp": "", "HostPort": "13306" }], }, ... }
7、修改完成后先检查两个文件是否JSON格式正确
8、启动docker,启动容器, 查看容器列表信息,查看端口映射是否生效
systemctl start docker docker start 容器ID docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 容器ID myos202005:latest "/usr/sbin/init" 3 hours ago Up 5 seconds 22/tcp, 1300/tcp, 0.0.0.0:13306->3306/tcp cranky_franklin
如上标红的 13306->3306,则表示端口映射成功
9、查看端口使用情况 netstat -nlpt ,可以看到 docker-proxy 进程使用13306端口
七、服务器防火墙开放相应的端口
#查看开放的端口 firewall-cmd --list-port #添加端口(永久) firewall-cmd --zone=public --add-port=13306/tcp --permanent #重载防火墙 firewall-cmd --reload
如果是用的阿里云,还有“安全组”策略限制了端口访问,需要在阿里云后台操作添加端口
八、Nginx / Apache 反向代理部分域名到docker中
实现效果:blog.batsing.com 正常定向在服务器中,blog.demo.batsing.com 定向到docker中。都是使用80端口。
实现过程:
1、docker机里有内网IP(默认172.17.0.2)
2、服务器可以通过此IP访问到docker中的nginx curl 172.17.0.2:80
3、服务器配置系统hosts,把demo域名指向docker内网IP
cat /etc/hosts 172.17.0.2 blog.demo.batsing.com
4、Nginx中配置vhost,将demo域名转发到域名自身
server { listen 80; server_name blog.demo.batsing.com; location / { proxy_pass http://blog.demo.batsing.com; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-NginX-Proxy true; } }
转发到域名自身,因为服务器的hosts配置,所以会转发到docker机中,从而实现部分域名转入到docker中的功能。
服务器中其他站点域名,按nginx正常配置即可。
docker中的nginx配置,也是按正常配置即可,无需另行特殊配置。