最小JDK镜像
- 准备jdk中jre包,并清理掉部分文件,减少体积.
#删除文本文件
rm -rf COPYRIGHT LICENSE README release THIRDPARTYLICENSEREADME-JAVAFX.txtTHIRDPARTYLICENSEREADME.txt Welcome.html \
#删除其他无用文件
rm -rf lib/plugin.jar \
lib/ext/jfxrt.jar \
bin/javaws \
lib/javaws.jar \
lib/desktop \
plugin \
lib/deploy* \
lib/*javafx* \
lib/*jfx* \
lib/amd64/libdecora_sse.so \
lib/amd64/libprism_*.so \
lib/amd64/libfxplugins.so \
lib/amd64/libglass.so \
lib/amd64/libgstreamer-lite.so \
lib/amd64/libjavafx*.so \
lib/amd64/libjfx*.so
https://github.com/sgerrand/alpine-pkg-glibc/releases
#1.指定基础镜像,并且必须是第一条指令
#FROM alpine:latest
FROM alpine:3.12
#2.指明该镜像的作者和其电子邮件
MAINTAINER xyz "540015260@qq.com"
#3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
WORKDIR /home/acrabsoft/jdk
#4.将一些安装包复制到镜像中,语法:ADD/COPY <src>... <dest>
## ADD与COPY的区别:ADD复制并解压,COPY仅复制
## 注意~~~上传的瘦身后的jre
ADD jre1.8.tar.gz /home/acrabsoft/jdk/
## glibc安装包如果从网络下载速度实在是太慢了,先提前下载复制到镜像中
COPY glibc-2.29-r0.apk /home/acrabsoft/jdk/
COPY glibc-bin-2.29-r0.apk /home/acrabsoft/jdk/
COPY glibc-i18n-2.29-r0.apk /home/acrabsoft/jdk/
#5.更新Alpine的软件源为阿里云,因为从默认官源拉取实在太慢了
RUN echo http://mirrors.aliyun.com/alpine/v3.12/main/ > /etc/apk/repositories && \
echo http://mirrors.aliyun.com/alpine/v3.12/community/ >> /etc/apk/repositories
RUN apk update && apk upgrade
#6.时区
RUN apk add -U tzdata
#ENV TZ=Asia/Shanghai
#RUN cp /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
#RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
RUN ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo Asia/Shanghai > /etc/timezone
#RUN apk del tzdata
#7.运行指定的命令
## Alpine linux为了精简本身并没有安装太多的常用软件,apk类似于ubuntu的apt-get,
## 用来安装一些常用软V件,其语法如下:apk add bash wget curl git make vim docker
## wget是linux下的ftp/http传输工具,没安装会报错“/bin/sh: wget: not found”,网上例子少安装wget
## ca-certificates证书服务,是安装glibc前置依赖
RUN apk --no-cache add ca-certificates wget \
&& wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub \
&& apk add glibc-2.29-r0.apk glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk \
&& rm -rf /var/cache/apk/* glibc-2.29-r0.apk glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk
#8.配置环境变量
## 注意~~~没有jdk啦,直接指向jre
ENV JAVA_HOME=/home/acrabsoft/jdk/jre
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
kafka镜像
FROM java8:1.0
MAINTAINER efei "efei@acrabsoft.com"
WORKDIR /home/acrabsoft/kafka
ADD kafka_2.13-2.6.0.tgz /home/acrabsoft/kafka
# 安装bash
RUN apk add --no-cache bash \
bash-doc \
bash-completion \
&& rm -rf /var/cache/apk/* \
&& /bin/bash
EXPOSE 9092
EXPOSE 2181
version: '3.7'
services:
zoo1:
container_name: zoo1
image: kafka:v1.1
networks:
- br0
command: /home/acrabsoft/kafka/kafka_2.13-2.6.0/bin/zookeeper-server-start.sh /home/acrabsoft/kafka/kafka_2.13-2.6.0/config/zookeeper.properties
ports:
- 2181:2181
#主库服务名称
kafka:
#容器名称
container_name: kafka
#镜像名称 提前 docker pull mysql:5.7.30 不然会很慢
image: kafka:v1.1
#docker 重启后容器重启
#restart: always
#选择自建bridge网络
networks:
- br0
#mysql 参数配置 my.cnf里面的配置,这里简单配置下,可以配置volumes /etc/my.cnf:/etc/my.cnf
command: /bin/bash -c "/home/acrabsoft/kafka/kafka_2.13-2.6.0/bin/kafka-server-start.sh /home/acrabsoft/kafka/kafka_2.13-2.6.0/config/server.properties"
environment:
- TZ=Asia/Shanghai
ports:
- 9092:9092
volumes:
- "/home/xefei/docker/kafka/config:/home/acrabsoft/kafka/kafka_2.13-2.6.0/config"
depends_on:
- zoo1
#配置网络
networks:
br0:
name: br0
#强制使用已经创建好的网络,不然报错
external: true
docker network create --driver=bridge --subnet=172.28.0.0/16 --ip-range=172.28.5.0/24 --gateway=172.28.5.254 br0
FROM java8:1.0
MAINTAINER efei "efei@acrabsoft.com"
RUN mkdir -p /home/acrabsoft/zook/zkui
WORKDIR /home/acrabsoft/zook
RUN apk add --no-cache bash \
bash-doc \
bash-completion \
&& rm -rf /var/cache/apk/* \
&& /bin/bash
ADD apache-zookeeper-3.6.1-bin.tar.gz /home/acrabsoft/zook
RUN rm -rf /home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/bin/zkServer.sh
COPY zkServer.sh /home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/bin
COPY zkui-2.0.jar /home/acrabsoft/zook/zkui
COPY config.cfg /home/acrabsoft/zook/zkui
EXPOSE 2181
EXPOSE 9090```
version: '3.7'
services:
zk1:
container_name: zk1
image: zook:v1.1
networks:
- br0
command: /bin/bash -c "/home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/bin/zkServer.sh start /home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/conf/zoo.cfg && cd zkui && java -jar zkui-2.0.jar"
#/home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/bin/zkServer.sh start /home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/conf/zoo.cfg &&
ports:
- 2181:2181
- 9090:9090
volumes:
- "/home/xefei/docker/zook/conf:/home/acrabsoft/zook/apache-zookeeper-3.6.1-bin/conf/"
#配置网络
networks:
br0:
name: br0
#强制使用已经创建好的网络,不然报错
external: true