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 | 賦值指定的
|
COPY | 賦值本地主機的
|
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
- 啟動成功之后,我們可以在瀏覽器訪問一下,看看是否成功運行。出現如下界面就證明我們的操作成功了。
做一個有底線的博客主