docker镜像制作

最小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
  • 下载apk包
https://github.com/sgerrand/alpine-pkg-glibc/releases
  • 编写dockerfile文件
#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镜像

  • dockerfile
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
  • docker-kafka.yaml 运行
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 网络创建
docker network create --driver=bridge --subnet=172.28.0.0/16 --ip-range=172.28.5.0/24 --gateway=172.28.5.254 br0
  • zookeeper镜像
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```

  • docker-zookeeper.yaml 运行
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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值