一、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.json
vi /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端口

10、服务器防火墙开放相应的端口

#查看开放的端口
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配置,也是按正常配置即可,无需另行特殊配置。

Docker虚拟机配置手札(centos)的更多相关文章

  1. 【转】Virtualbox虚拟机配置安装CentOS 6.5图文教程

    http://www.111cn.net/sys/CentOS/61709.htm 什么是Virtualbox? VirtualBox 是一款开源虚拟机软件(注:跟vmware差不多).Virtual ...

  2. CentOS上安装 Docker-CE以及Docker 加速器配置

    在CentOS 7.0上安装 Docker-CE 官方源安装教程 https://docs.docker.com/install/linux/docker-ce/centos/#install-usi ...

  3. Linux 如何配置虚拟机下的Centos静态ip

    如何配置虚拟机下的Centos静态ip 1.        配置虚拟机的虚拟路由器 2.        配置物理主机的虚拟网卡(VMNET8) 3.        配置虚拟主机Centos的网卡 vi ...

  4. 虚拟机中的CentOS 7设置固定IP连接最理想的配置

    说明:在网上搜了好多文章都是大同小异,都没有完全解决我想要的固定IP后要达到的如下效果, 1.笔记本主机IP为设置自动获取,不管什么情况下,不受虚拟机影响,只要连接外网就可以正常上网: 2.只要笔记本 ...

  5. 为centos虚拟机配置固定ip

    在virtual上安装centos虚拟机以后,发现虚拟机没有ip,无法联网 将虚拟机的网络适配器改为桥接模式,桥接到物理机的无线网卡 为虚拟机配置固定IP(vi /etc/sysconfig/netw ...

  6. 虚拟机中的CentOS 7设置固定IP连接最理想的配置(转载)

    来源:虚拟机中的CentOS 7设置固定IP连接最理想的配置(https://my.oschina.net/panhongju/blog/826814) 转载说明:这是我看了很多篇虚拟机静态IP配置写 ...

  7. VM Ware 给Centos虚拟机配置静态IP

    前言:在大家的日常运维工作中,肯定多多少少都会用到虚拟机,但是默认情况下VMware创建的虚拟机每次启动都有可能更换IP这就对我们的工作造成了一定的麻烦,下面我就给大家介绍下,如何给centos虚拟机 ...

  8. 为CentOS下的Docker安装配置python3【转】

    * 安装python3以及docker yum install docker docker pull centos service docker start systemctl enable dock ...

  9. Docker 学习笔记(CentOS 7.1)

    基本概念 Docker 包括三个基本概念 镜像(Image) 容器(Container) 仓库(Repository)理解了这三个概念,就理解了 Docker 的整个生命周期. Docker 镜像 D ...

随机推荐

  1. 使用mysqldump自动备份数据库脚本

    每天利用计划任务在凌晨1点自动执行,备份zabbix的数据库至本地的/backup/mysql_backup目录 #!/bin/sh DUMP=/usr/bin/mysqldump OUT_DIR=/ ...

  2. win7乱码问题解决方法(cmd变小,plsql客户端乱码)

    1.点击控制面板:时钟.语言和区域:区域和语言:管理点击更改系统区域设置,选中英语(英国):重启 2.点击控制面板:时钟.语言和区域:区域和语言:管理点击更改系统区域设置,选中中文(简体,中国):重启 ...

  3. docker cannot open directory .: Permission denied无权限问题

    docker运行一个容器后,将主机中当前目录下的文件夹挂载到容器的文件夹后 进入到docker容器内对应的挂载目录中,运行命令ls后提示: ls: cannot open directory .: P ...

  4. P2774 方格取数问题 网络流重温

    P2774 方格取数问题 这个题目之前写过一次,现在重温还是感觉有点难,可能之前没有理解透彻. 这个题目要求取一定数量的数,并且这些数在方格里面不能相邻,问取完数之后和最大是多少. 这个很好的用了网络 ...

  5. 从excel表格加载数据返回DataSet

    添加命名空间:using System.Data.OleDb; /// <summary> /// 从excel表格加载数据返回DataSet /// </summary> / ...

  6. 深入理解CSS定位—浮动模型

    前面我们讲到了绝对定位,在这篇文章中,我们将讲到3种定位模型中的浮动模型.主要参考 张鑫旭在慕课网的 深入理解float 那些年我们一起清过的浮动---by 一丝丝凉 精通CSS 注意:第二小节基本参 ...

  7. 浅谈mybatis如何半自动化解耦和ORM实现

    在JAVA发展过程中,涌现出一系列的ORM框架,JPA,Hibernate,Mybatis和Spring jdbc,本系列,将来研究Mybatis. 通过研究mybatis源码,可将mybatis的大 ...

  8. CSS:必须要掌握的重要基础知识点

    目录 1. 盒子 2. 常用选择器 3. 优先级 4. CSS继承 5. 伪元素(pseudo-element)和伪类(pseudo-class) 6. CSS:元素定位机制(positioning ...

  9. mybatis association的使用

    在上一篇文章中介绍了collection的使用以及java bean,表的结构,今天进行association使用的学习,在多对一的映射关系中,查询到多的一方顺带查询出一的一方是常见的!在此例子中,在 ...

  10. SpringCloud Netflix (五) : Hystrix 服务熔断和服务降级

    什么是Hystrix 在分布式环境中,许多服务依赖项中的一些服务依赖不可避免地会失败.Hystrix是一个库,通过添加延迟容忍和容错逻辑,帮助您控制这些分布式服务之间的交互.Hystrix通过隔离服务 ...