## 准备工作

用到的工具, 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. Luogu P4358 密钥破解 题解报告

    题目传送门 [题目大意] 给定一个正整数N,可以被分解为两个不同的质数p和q,计算出r=(p-1)*(q-1). 然后给出了一个小于r且与r互质的整数e,已知e*d≡1(mod r),求d. 最后给定 ...

  2. mysql删除表结构中的“关键字”字段

    问题描述:一同事误将“describe”关键字放入建表语句中,虽成功建表,但因未关键词的缘故,无法插入数据.故需将字段drop并换为非关键字的字段. 解决过程: 按常规删除字段语句操作报错,语句如下: ...

  3. 医学图像数据(三)——TCIA部分数据下载方式

    前为止,本人还没有找到不需要账号的就可以部分下载的方式,因此这里讲的是需要注册账号下载部分数据的方法. 注意:下载部分数据需要注册账号 注册账号网址:https://public.cancerimag ...

  4. GitLab实战操作指南

    一.Git原理 1.Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). 2.Git有什么特点? 简单来说就是:高端大气上档次! 3.GIt与SVN区别 SVN管理: 属于集中式 ...

  5. sublime text3输出窗口中文显示乱码问题解决方案

    1 前言 略 2 方案 修改Python3.sublime-build内容为 { "cmd": ["C:/Users/Administrator/AppData/Loca ...

  6. python 视频转成代码视频

    # -*- coding:utf-8 -*- # coding:utf-8 import os, cv2, subprocess, shutil from cv2 import VideoWriter ...

  7. JAVA Scanner的简单运用

    package Code428; import java.util.Scanner; /*Scanner 可以实现键盘输入数据 引用的步骤1.import 包路径.类名称只有java.lang包下的内 ...

  8. 解决vuecli3.0构建的vue2.0项目在IE9可能出现的兼容性问题

    1,unit8Array等未定义问题 解决办法 <1>npm install @babel/polyfill <2>分别在main.js和vuex的主文件 import '@b ...

  9. SQL语句完整的执行顺序(02)

    这是对SQL语句完整的执行顺序(01)的补充: 数据库是mysql,使用的数据库表名称是my_student. 表的完整数据信息是: 完整语法是: Select [select选项] 字段列表[字段别 ...

  10. mysql_config not found和error: command 'gcc' failed with exit status 1

    要想使python可以操作mysql 就需要MySQL-python驱动,它是python 操作mysql必不可少的模块. 下载地址:https://pypi.python.org/pypi/MySQ ...