Docker 简单总结

写这个目的主要目的是为了记录了一些最近使用Docker的情况

背景

部门要求部署一个云应用,要求实现多租户,而现有的项目代码改造比较费事,所以采用了这种虚拟容器来实现

Docker 主要是弄清出容器和镜像的关系就可以了,简单来说
镜像就是就像安装系统用的GHOST文件或是光盘
而容器就是 安装好的操作系统
镜像可以生成容器
容器也可以修改后生成新的镜像

步骤

Docker的操作系统现在要求比较高,我这里用的是centos 7 。要求是64位操作系统,内核最好是在3.1以上

  1. 安装docker
yum install -y epel-release
yum install docker-io # 安装docker
# 配置文件 /etc/sysconfig/docker

chkconfig docker on  # 加入开机启动
service docker start # 启动docker服务

# 基本信息查看
docker version # 查看docker的版本号,包括客户端、服务端、依赖的Go等
docker info # 查看系统(docker)层面信息,包括管理的images, containers数等
docker pull centos 下载
docker images [ centos ] 查看
docker run -i -t centos /bin/bash

2.镜像和容器的使用
docker run 和 docker create 参数基本一样,run是创建容器并后台启动,create是只创建容器。
docker run 相当于docker create 和 docker start

# 搜索镜像
docker search <image> # 在docker index中搜索image
# 下载镜像
docker pull <image>  # 从docker registry server 中下拉image
# 查看镜像 
    docker images: # 列出images
    docker images -a # 列出所有的images(包含历史)
    docker rmi  <image ID>: # 删除一个或多个image
un创建容器:docker run -itd
create创建: docker create -it
    -t, --tty                       Allocate a pseudo-TTY
    -i, --interactive               Keep STDIN open even if not attached
    -d, --detach                    Run container in background and print container ID #run的参数

3.容器资源限制参数

-m 1024m --memory-swap=1024m  # 限制内存最大使用(bug:超过后进程被杀死)
--cpuset-cpus="0,1"           # 限制容器使用CPU

docker容器随系统自启参数

docker run --restart=always redis

no – 默认值,如果容器挂掉不自动重启
on-failure – 当容器以非 0 码退出时重启容器
同时可接受一个可选的最大重启次数参数 (e.g. on-failure:5).
always – 不管退出码是多少都要重启

docker run -itd --name test01 -p IP:sport:dport  -m 1024m --memory-swap=1024m --cpuset-cpus="0,1" --restart=always <image ID> 
docker exec -it test01 bash  # 进入容器也可以用exec命令

查看容器状态信息

[root@localhost ~]# docker stats 
[root@localhost ~]# docker stats --no-stream

查看正在运行的容器

docker ps

查看所有的容器,包括已经关闭

docker ps -a

容器的关闭和启动

docker start 容器id
docker stop 容器id

4.进入容器

docker exec -ti 容器id /bin/bash

拷贝宿主机的文件到容器

docker cp ecoa.war 38caf7612d21:/home/puchao/.

拷贝文件到容器

5.删除容器或镜像

docker rmi  镜像id
docker rm 容器id

6.容器提交成镜像

可以把这个容器提交成一个镜像

docker commit 容器id 镜像名

7.我制作的镜像的启动

docker run  -d -p 9081:9080  -itv /home/ict:/data/software  centos/zjoa1 /bin/bash /home/puchao/start.sh

-d: 是以默认后台的方式进行
-p 是宿主机端口:容器端口 的映射, 可以写多个 需要写多个 -p 端口:端口
-v 是可以挂载宿主机的目录 宿主机目录:容器目录
后面是容器启动后执行的脚本
我写了个启动脚本,用于容器启动后启动mysql 和tomcat
这样可以通过浏览器直接访问 宿主机的9081端口 就可以访问容器的tomcat了

我的部署想法是
- 在docker仓库中下载一个centos的镜像
- 启动镜像并进入容器
- 安装项目用的数据库mysql,并导入数据,这一步遇到不少问题,要增加不少配置项,这个以后再说
- 安装tomcat,并部署项目
- 启动tomcat 看看有什么问题,有可能会遇到内存溢出,乱码等问题,好解决
- 保存容器为镜像
- 可以重复启动这个镜像并暴露相关的端口映射

未完成

管理界面还没有写,这个要写好启动的脚本,暴露的端口不能重复,可以放到数据库中进行管理。启动后会返回容器的id,也可以保存到数据库中进行管理
然后在写个脚本进行对这些已经启动或是未启动的容器进行管理。

应该还有更好的解决方案,暂时先写到这里