## 准备工作

用到的工具, Xshell5, Xftp5, jdk-7u79-linux-x64.tar.gz, zookeeper-3.4.9.tar.gz, docker.io/centos:latest镜像

关于docker的安装和设置加速, 请参考这篇博文centos7系统下 docker 环境搭建

jdk7和zookeeper 可以去我的百度网盘分享里面拿https://pan.baidu.com/share/home?uk=2567919817

创建工作目录

mkdir -p /z/docker && cd /z/docker

通过Xftp工具把下载的jdk7和zookeeper复制到当前目录

解压缩, 并且重命名文件夹

mkdir jdk && tar -zxvf jdk-7u79-linux-x64.tar.gz -C jdk --strip-components
mkdir zookeeper && tar -zxvf zookeeper-3.4..tar.gz -C zookeeper --strip-components

进入zookeeper下的conf文件夹, 把zoo_sample.cfg复制一份, 重命名为zoo.cfg, zookeeper启动的默认配置文件为zoo.cfg

cp zoo_sample.cfg zoo.cfg

最终目录结构:

[root@localhost docker]# ls
Dockerfile jdk jdk-7u79-linux-x64.tar.gz zookeeper zookeeper-3.4..tar.gz

如果想精简jdk, 压缩最终生成的镜像大小, 可以参考这篇博文 从零开始构建一个centos+jdk7+tomcat7的镜像文件

适量删减jdk包中内容, 再进入下一步操作

## 制作Dockerfile文件

编辑Dockerfile文件, 插入以下内容

#使用的基础镜像
FROM docker.io/centos:latest
#作者信息
MAINTAINER yzzhouyalei "yzzhouyalei@foxmail.com"
#创建目录(这个目录是指将来打包的镜像, 里面的目录, 不是当前的宿主机目录)
RUN mkdir -p /z/java/jdk1..0_79 && mkdir -p /z/java/zookeeper-3.4. && mkdir -p /tmp/zookeeper
#把当前目录下的jdk文件夹添加到镜像
ADD jdk /z/java/jdk1..0_79
ADD zookeeper /z/java/zookeeper-3.4.
#开放端口
EXPOSE
#添加环境变量
ENV JAVA_HOME /z/java/jdk1..0_79
ENV PATH $PATH:$JAVA_HOME/bin
#容器入口
ENTRYPOINT ["/z/java/zookeeper-3.4.9/bin/zkServer.sh"]
#前台运行, 如果不设置这个, zookeeper后台运行的话, 容器会自动关闭, 进入Exited状态
CMD ["start-foreground"]

## 构建镜像

执行命令docker build命令构建镜像

[root@localhost docker]# docker build -t centos-jdk7-zookeeper:0.0.1 .
Sending build context to Docker daemon MB
Step : FROM docker.io/centos:latest
---> 67591570dd29
Step : MAINTAINER yzzhouyalei "yzzhouyalei@foxmail.com"
.............................................#步骤省略
Removing intermediate container 0bb26e35b54d
Successfully built deca0be3af0e
[root@localhost docker]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos-jdk7-zookeeper 0.0.1 deca0be3af0e 6 seconds ago 541.5 MB
centos-jdk7-tomcat7 0.0. 1821b3e09e20 days ago 347.7 MB
registry.cn-hangzhou.aliyuncs.com/repos_zyl/centos-jdk7-tomcat7 0.0. 1821b3e09e20 days ago 347.7 MB
192.168.16.181:/centos-jdk-tomcat7 0.0. 1821b3e09e20 days ago 347.7 MB
192.168.16.181:/centos-base 0.0. 67591570dd29 weeks ago 191.8 MB
docker.io/centos latest 67591570dd29 weeks ago 191.8 MB
[root@localhost docker]#

最终镜像大小541MB, 建议精简一下jdk文件夹下的内容应该可以控制在300-400MB之间

## 运行镜像

[root@localhost docker]# docker run -d -p 2181:2181 --name test-zookeeper centos-jdk7-zookeeper:0.0.1
f45d1de49626dc7a9afa6017470eb71a35015e3dd123100749150ff57fa77775
[root@localhost docker]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f45d1de49626 centos-jdk7-zookeeper:0.0. "/z/java/zookeeper-3." seconds ago Up seconds /tcp, 0.0.0.0:->/tcp, /tcp test-zookeeper

-d: 表示后台守护模式运行
-p: 小写p后面跟宿主机端口:容器端口映射
--name: 为启动的容器命名
最后一个参数为repository+tag
看到name为test-zookeeper的容器状态为Up, 说明容器在运行中

## 测试

进入宿主机的zookeeper/bin目录, 运行zkCli.sh客户端, 与容器内的zookeeper交互

[root@localhost bin]# ./zkCli.sh -server localhost:2181
Connecting to localhost:2181
2017-02-15 15:44:55,331 [myid:] - INFO [main:Environment@100] - Client environment:zookeeper.version=3.4.9-1757313, built on 08/23/2016 06:50 GMT
...........................#省略
WATCHER:: WatchedEvent state:SyncConnected type:None path:null
[zk: localhost:2181(CONNECTED) 0] ####已经连上了
[zk: localhost:2181(CONNECTED) 1] get /zookeeper cZxid = 0x0
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x0
cversion = -1
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 0
numChildren = 1

用的宿主机IP地址:2181, 连上容器内部的zookeeper了

如果是外部调用的话, 宿主机可能需要开放2181端口

到此步骤->制作docker-jdk7-zookeeper镜像(非集群版) 已经完成

如需帮助可向我发起QQ聊天发起QQ聊天

友情赞助

如果您喜欢此文,感觉对您工作有帮助,预期领导会给您涨工资,不妨小额赞助一下,让我有动力继续努力。

赞助方式:打开支付宝App,使用“扫一扫”付款,付款码见下图,别忘了付款留言哦!


或使用微信, 不用加好友就能付款

制作docker-jdk7-zookeeper镜像(非集群版)的更多相关文章

  1. Docker快速搭建Zookeeper和kafka集群

    使用Docker快速搭建Zookeeper和kafka集群 镜像选择 Zookeeper和Kafka集群分别运行在不同的容器中zookeeper官方镜像,版本3.4kafka采用wurstmeiste ...

  2. 使用Docker快速搭建Zookeeper和kafka集群

    使用Docker快速搭建Zookeeper和kafka集群 镜像选择 Zookeeper和Kafka集群分别运行在不同的容器中zookeeper官方镜像,版本3.4kafka采用wurstmeiste ...

  3. 基于zookeeper的Swarm集群搭建

    简介 Swarm:docker原生的集群管理工具,将一组docker主机作为一个虚拟的docker主机来管理. 对客户端而言,Swarm集群就像是另一台普通的docker主机. Swarm集群中的每台 ...

  4. Docker化高可用redis集群

    最近遇到部分系统因为redis服务挂掉,导致部分服务不可用.所以希望搭建一个redis集群镜像,把原先散落各处的redis服务器统一管理起来,并且保障高可用和故障自动迁移. 一:redis集群分类 大 ...

  5. 同主机下Docker+nginx+tomcat负载均衡集群搭建

    想用Docker模拟一下nginx+tomcat集群部署,今天折腾了一天,遇坑无数,终于在午夜即将到来之际将整个流程走通,借本文希望给同样遇到类似问题的小伙伴们留点线索. 主机环境是CentOS 7, ...

  6. 使用Docker Swarm搭建分布式爬虫集群

    https://mp.weixin.qq.com/s?__biz=MzIxMjE5MTE1Nw==&mid=2653195618&idx=2&sn=b7e992da6bd1b2 ...

  7. Zookeeper简介与集群搭建【转】

    Zookeeper简介 Zookeeper是一个高效的分布式协调服务,可以提供配置信息管理.命名.分布式同步.集群管理.数据库切换等服务.它不适合用来存储大量信息,可以用来存储一些配置.发布与订阅等少 ...

  8. docker下搭建fastfds集群版

    搭建过程参考 作者 https://me.csdn.net/feng_qi_1984 的课程视频 声明:集群版是在我之前写的单机版基础之上进行搭建的,我将安装了fastfds单机版的docker打包成 ...

  9. docker下rabbitMQ高可用集群部署

    第一步:docker 安装: mac 下安装命令: brew cask install docker 安装完之后查看版本 docker --version 第二步:开始集群搭建: 采用bijukunj ...

随机推荐

  1. 两个div不同高度并排显示

    在HTML中让两个div并排显示,通常情况下有三种实现方式,包括: (1)设置为行内样式,display:inline-block (2)设置float浮动 (3)设置position定位属性为abs ...

  2. React Router 4.x 开发,这些雷区我们都帮你踩过了

    前言 在前端框架层出不穷的今天,React 以其虚拟 DOM .组件化开发思想等特性迅速占据了主流位置,成为前端开发工程师热衷的 Javascript 库.作为 React 体系中的重要组成部分:Re ...

  3. idea如何快速查看接口的实现类

    查找接口的实现类: IDEA 风格 ctrl + alt +B 在按F2查看详细文档注解 查看类或接口的继承关系: ctrl + h

  4. UOJ #450「集训队作业2018」复读机

    UOJ #450 题意 有$ k$台复读机,每时每刻有且只有一台复读机进行复读 求$ n$时刻后每台复读机的复读次数都是$ d$的倍数的方案数 $ 1\leq d \leq 3,k \leq 5·10 ...

  5. css3新单位vw、vh、vmin、vmax的使用详解(转载)

    文章传送门: https://blog.csdn.net/ZNYSYS520/article/details/76053961

  6. Win10蓝屏的一些解决办法

    请仔细回想这个错误是什么时候出现的: 第一次发生时你对系统做了哪些操作: 发生时正在进行什么操作: 从这些信息中找出可能的原因: 从而选择相应解决方案并尝试排除. 0x0000000A:IRQL_NO ...

  7. django 模型models

    1. django 模型models 常用字段          1.models.AutoField 自增列 = int(11) 如果没有的话,默认会生成一个名称为 id 的列 如果要显式的自定义一 ...

  8. 【JS】VUE学习

    VUE的全家桶:vue-cli,vue-router,vue-resource,vuex 环境搭建:https://www.jianshu.com/p/32beaca25c0d 先码在这儿吧. htt ...

  9. SQL语句:子查询

    一,子查询定义: 子查询就是嵌套在主查询中的查询. 子查询可以嵌套在主查询中所有位置,包括SELECT.FROM.WHERE.GROUP BY.HAVING.ORDER BY. 但并不是每个位置嵌套子 ...

  10. C语言博客作业2--循环结构

    1.1 思维导图 1.2 本章学习体会及代码量学习体会 1.2.1 学习体会 对本章学习感觉相对前面的难度有较大提升,而且刚开始对嵌套循环比较陌生,像龟兔赛跑和输出菱形都是用了较长时间才完成,所以我认 ...