Docker--DockerFile創建自己的image


echo編輯整理,歡迎轉載,轉載請聲明文章來源。歡迎添加echo微信(微信號:t2421499075)交流學習。 百戰不敗,依不自稱常勝,百敗不頹,依能奮力前行。——這才是真正的堪稱強大!!!


在我們使用docker庫中的諸多image的時候,我們可以去了解一下他的生成的過程,這樣有利於我們自己封裝自己的image。改文章主要是用於介紹dockerfile生成自己的image,介紹了基本的操作和一個實例,熟練的可以略過

image生成的關鍵dockerfile

Dockerfile是一個文本格式的配置文件,用戶可以使用Dockerfile快速創建自定義的鏡像。一般而言,Dockerfile分為四部分:基礎鏡像信息、維護者信息、鏡像操作指令和容器啟動時執行指令。我們可以登錄github找到docker的官方倉庫:https://github.com/docker-library/mysql/blob/master/5.7/Dockerfile 找到mysql對應的dockerfile來分析一下。(里面的注釋全是為了方便解讀后面加上去的,官網原地址上並沒有這些注釋)

# FROM指定基礎鏡像,比如 FROM ubuntu:14.04
FROM debian:stretch-slim

# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
RUN groupadd -r mysql && useradd -r -g mysql mysql

# RUN在鏡像內部執行一些命令,比如安裝軟件,配置環境等,換行可以使用""
RUN apt-get update && apt-get install -y --no-install-recommends gnupg dirmngr && rm -rf /var/lib/apt/lists/*

# add gosu for easy step-down from root

# ENV :設置變量的值,ENV MYSQL_MAJOR 5.7,可以通過docker run --e key=value修改,后面可以直接使 用${MYSQL_MAJOR}
ENV GOSU_VERSION 1.7
RUN set -x \
	&& apt-get update && apt-get install -y --no-install-recommends ca-certificates wget && rm -rf /var/lib/apt/lists/* \
	&& wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \
	&& wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \
	&& export GNUPGHOME="$(mktemp -d)" \
	&& gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \
	&& gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \
	&& gpgconf --kill all \
	&& rm -rf "$GNUPGHOME" /usr/local/bin/gosu.asc \
	&& chmod +x /usr/local/bin/gosu \
	&& gosu nobody true \
	&& apt-get purge -y --auto-remove ca-certificates wget

RUN mkdir /docker-entrypoint-initdb.d

RUN apt-get update && apt-get install -y --no-install-recommends \
# for MYSQL_RANDOM_ROOT_PASSWORD
		pwgen \
# for mysql_ssl_rsa_setup
		openssl \
# FATAL ERROR: please install the following Perl modules before executing /usr/local/mysql/scripts/mysql_install_db:
# File::Basename
# File::Copy
# Sys::Hostname
# Data::Dumper
		perl \
	&& rm -rf /var/lib/apt/lists/*

RUN set -ex; \
# gpg: key 5072E1F5: public key "MySQL Release Engineering <mysql-build@oss.oracle.com>" imported
	key='A4A9406876FCBD3C456770C88C718D3B5072E1F5'; \
	export GNUPGHOME="$(mktemp -d)"; \
	gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys "$key"; \
	gpg --batch --export "$key" > /etc/apt/trusted.gpg.d/mysql.gpg; \
	gpgconf --kill all; \
	rm -rf "$GNUPGHOME"; \
	apt-key list > /dev/null

ENV MYSQL_MAJOR 5.7
ENV MYSQL_VERSION 5.7.28-1debian9

RUN echo "deb http://repo.mysql.com/apt/debian/ stretch mysql-${MYSQL_MAJOR}" > /etc/apt/sources.list.d/mysql.list

# the "/var/lib/mysql" stuff here is because the mysql-server postinst doesn't have an explicit way to disable the mysql_install_db codepath besides having a database already "configured" (ie, stuff in /var/lib/mysql/mysql)
# also, we set debconf keys to make APT a little quieter
RUN { \
		echo mysql-community-server mysql-community-server/data-dir select ''; \
		echo mysql-community-server mysql-community-server/root-pass password ''; \
		echo mysql-community-server mysql-community-server/re-root-pass password ''; \
		echo mysql-community-server mysql-community-server/remove-test-db select false; \
	} | debconf-set-selections \
	&& apt-get update && apt-get install -y mysql-server="${MYSQL_VERSION}" && rm -rf /var/lib/apt/lists/* \
	&& rm -rf /var/lib/mysql && mkdir -p /var/lib/mysql /var/run/mysqld \
	&& chown -R mysql:mysql /var/lib/mysql /var/run/mysqld \
# ensure that /var/run/mysqld (used for socket and lock files) is writable regardless of the UID our mysqld instance ends up having at runtime
	&& chmod 777 /var/run/mysqld \
# comment out a few problematic configuration values
	&& find /etc/mysql/ -name '*.cnf' -print0 \
		| xargs -0 grep -lZE '^(bind-address|log)' \
		| xargs -rt -0 sed -Ei 's/^(bind-address|log)/#&/' \
# don't reverse lookup hostnames, they are usually another container
	&& echo '[mysqld]\nskip-host-cache\nskip-name-resolve' > /etc/mysql/conf.d/docker.cnf

# VOLUME : 指定數據的掛在目錄
VOLUME /var/lib/mysql

# COPY : 將主機的文件復制到鏡像內,如果目錄不存在,會自動創建所需要的目錄,注意只是復制,不會提取和解壓
COPY docker-entrypoint.sh /usr/local/bin/
RUN ln -s usr/local/bin/docker-entrypoint.sh /entrypoint.sh # backwards compat
ENTRYPOINT ["docker-entrypoint.sh"]

# EXPOSE : 指定鏡像要暴露的端口,啟動鏡像時,可以使用-p將該端口映射給宿主機
EXPOSE 3306 33060
CMD ["mysqld"]

基本指令整理

指令 說明
FROM 指定所創建鏡像的基礎鏡像
MAINTAINER 指定維護者信息
RUN 運行命令
CMD 指定啟動容器時默認執行的命令
LABEL 指定生成鏡像的元數據標簽信息
EXPOSE 聲明鏡像內服務所監聽的端口
ENV 指定環境變量
ADD 賦值指定的 路徑下的內容到容器中的 路徑下, 可以為URL;如果為tar文件,會自動解壓到 路徑下
COPY 賦值本地主機的 路徑下的內容到容器中的 路徑下;一般情況下推薦使用COPY而不是ADD
ENTRYPOINT 指定鏡像的默認入口
VOLUME 創建數據掛載點
USER 指定運行容器時的用戶名或UID
WORKDIR 配置工作目錄
ARG 指定鏡像內使用的參數(例如版本號信息等)
ONBUILD 配置當前所創建的鏡像作為其他鏡像的基礎鏡像時,所執行的創建操作的命令
STOPSIGNAL 容器退出的信號
HEALTHCHECK 如何進行健康檢查
SHELL 指定使用SHELL時的默認SHELL類型

Dockerfile實戰Spring Boot項目

這里提供一個項目,鏈接:https://git.coding.net/xlsorry/docker-demo.git

下載之后驗證可以在idea中啟動,並且訪問有返回值:
在這里插入圖片描述

完成這些基本的驗證之后,我們將項目打包成為jar

mvn clean package
  • 完成這些操作之后,我們將jar包傳入已經安裝了docker的linux中。
  • 在安裝了docker環境中新建一個目錄"first-dockerfile"
  • 進入first-dockerfile,將我們打好的jar包放入該目錄下
  • 創建Dockerfile文件,編寫如下內容
FROM openjdk:8
MAINTAINER 2421499075@qq.com
LABEL name="dockerfile-demo" version="1.0" author="2421499075@qq.com"
COPY springboot-0.0.1-SNAPSHOT.jar dockerfile-image.jar
CMD ["java","-jar","dockerfile-image.jar"]

完成之后如下圖:
在這里插入圖片描述

  • 在該目錄下執行:docker build -t test-docker-image .

在這里插入圖片描述

  • 完成之后我們可以執行docker images查看是否打包成功。

在這里插入圖片描述
我們可以看到images中多了一個test-docker-image,名稱是我們在執行命令的時候,使用了該名字。這個image通過我們創建dockerfile打包出來的。

  • 基於image創建container,運行我們剛剛打包的docker
docker run -d --name springboot01 -p 10080:8080 test-docker-image
  • 啟動成功之后,我們可以在瀏覽器訪問一下,看看是否成功運行。出現如下界面就證明我們的操作成功了。
    在這里插入圖片描述

做一個有底線的博客主


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM