二十五、Docker 安装 Tomcat
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源
Docker 可以让开发者打包它们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化
Docker 使用完全使用沙箱机制,两个容器之间不会有任何接口 (这个有点像 iPhone 的 app ) ,更重要的是容器性能开销极低
学习前提
在继续阅读之前,我们希望你对 Linux 有一些基本的了解,包括
1、 会使用Linux常用的命令;
2、 知道大部分的Linux常识,比如终端、service、ip、用户、组等;
3、 熟练使用Ubuntu或者Centos或者MacOS种的一种昂;
如果你对这些知识还是一知半解,可以访问我们的 Linux 基础教程 先进行一些简单的了解
Docker的应用场景
1、 Web应用的自动化打包和发布;
2、 自动化测试和持续集成、发布;
3、 在服务型环境中部署和调整数据库或其他的后台应用;
4、 从头编译或者扩展现有的OpenShift或CloudFoundry平台来搭建自己的PaaS环境;
Docker 的优点
1、 简化程序;
Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化
Docker 改变了虚拟化的方式,使开发者可以直接将自己的成果放入 Docker 中进行管理
方便快捷已经是 Docker 的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成
2、 解决运维配置噩梦;
在没有 Docker 之前,每一台机器,每一个要用到的依赖,几乎都要重新配置一遍
比如新增一台 MySQL 数据库,就要从头开始配置所有环境
有了 Docker 之后,只需要从仓库里把之前的 MySQL 镜像拉出来,直接使用
3、 节省开支;
使用 Docker ,可以在一台电脑上部署多个服务,多个应用,从而充分榨干每一滴性能
同时,又不用担心多个应用之间出现相互访问的情况
相关链接
Docker 官网: http://www.docker.com
Github Docker 源码: https://github.com/docker/docker
Tomcat 是 Java Web 最流行的容器之一,Docker 安装 Tomcat
有两种方法
我们以当前最新的版本 9.0.8
安装为例
因为Tomcat
需要 Java 环境,我们使用的是 jre8
1. docker pull tomcat
这种方法非常适合只需要使用 Tomcat
的开发者
1、 查找DockerHub上的tomcat镜像;
[root@www.hotmindshare.com ~]# docker search tomcat
NAME DESCRIPTION OFFICIAL
tomcat Apache Tomcat is an open source ... [OK]
...
有很多版本,我们选择官方的 tomcat
2、 拉取官方的镜像,标签为9.0.8-jre8
;
[root@www.hotmindshare.com ~]# docker pull tomcat:9.0.8-jre8
9.0.8-jre8: Pulling from library/tomcat
3、 稍等片刻,就能在本地镜像列表里看到tomcat
了;
[root@www.hotmindshare.com ~]# docker images tomcat
REPOSITORY TAG IMAGE ID CREATED SIZE
tomcat 9.0.8-jre8 fffeb191ae8c 2 weeks ago 465.6 MB
一个 Tomcat 容器 400m ....
4、 通过Dockerfile构建;
可以使用 Dockerfile
定制自己的 Tomcat 容器
1、 创建目录tomcat
,用于存放后面的相关东西;
[root@www.hotmindshare.com ~]# mkdir -p ~/tomcat/webapps ~/tomcat/logs ~/tomcat/conf
<table>
<thead>
<tr>
<th align="left">目录</th>
<th align="left">说明</th>
</tr>
</thead>
<tbody>
<tr>
<td align="left">webapps</td>
<td align="left">将映射为 tomcat 容器配置的应用程序目录</td>
</tr>
<tr>
<td align="left">logs</td>
<td align="left">将映射为 tomcat 容器的日志目录</td>
</tr>
<tr>
<td align="left">conf</td>
<td align="left">该目录下的配置文件将映射为 tomcat 容器的配置文件</td>
</tr>
</tbody>
</table>
2、 进入tomcat
目录,创建Dockerfile
;
[root@www.hotmindshare.com ~]# cd tomcat
[root@www.hotmindshare.com tomcat]# vi Dockerfile
复制并粘贴以下内容:
FROM openjdk:8-jre
ENV CATALINA_HOME /usr/local/tomcat
ENV PATH $CATALINA_HOME/bin:$PATH
RUN mkdir -p "$CATALINA_HOME"
WORKDIR $CATALINA_HOME
let "Tomcat Native" live somewhere isolated
ENV TOMCAT_NATIVE_LIBDIR $CATALINA_HOME/native-jni-lib
ENV LD_LIBRARY_PATH ${LD_LIBRARY_PATH:+$LD_LIBRARY_PATH:}$TOMCAT_NATIVE_LIBDIR
runtime dependencies for Tomcat Native Libraries
Tomcat Native 1.2+ requires a newer version of OpenSSL than debian:jessie has available
> checking OpenSSL library version >= 1.0.2...
> configure: error: Your version of OpenSSL is not compatible with this version of tcnative
see http://tomcat.10.x6.nabble.com/VOTE-Release-Apache-Tomcat-8-0-32-tp5046007p5046024.html (and following discussion)
and https://github.com/docker-library/tomcat/pull/31
ENV OPENSSL_VERSION 1.1.0f-3+deb9u2
RUN set -ex; \
currentVersion="$(dpkg-query --show --showformat '${Version}\n' openssl)"; \
if dpkg --compare-versions "$currentVersion" '<<' "$OPENSSL_VERSION"; then \
if ! grep -q stretch /etc/apt/sources.list; then \
only add stretch if we're not already building from within stretch
{ \
echo 'deb http://deb.debian.org/debian stretch main'; \
echo 'deb http://security.debian.org stretch/updates main'; \
echo 'deb http://deb.debian.org/debian stretch-updates main'; \
} > /etc/apt/sources.list.d/stretch.list; \
{ \
add a negative "Pin-Priority" so that we never ever get packages from stretch unless we explicitly request them
echo 'Package: *'; \
echo 'Pin: release n=stretch*'; \
echo 'Pin-Priority: -10'; \
echo; \
... except OpenSSL, which is the reason we're here
echo 'Package: openssl libssl*'; \
echo "Pin: version $OPENSSL_VERSION"; \
echo 'Pin-Priority: 990'; \
} > /etc/apt/preferences.d/stretch-openssl; \
fi; \
apt-get update; \
apt-get install -y --no-install-recommends openssl="$OPENSSL_VERSION"; \
rm -rf /var/lib/apt/lists/*; \
fi
RUN apt-get update && apt-get install -y --no-install-recommends \
libapr1 \
&& rm -rf /var/lib/apt/lists/*
ENV TOMCAT_MAJOR 9
ENV TOMCAT_VERSION 9.0.8
ENV TOMCAT_TGZ_URLS \
https://issues.apache.org/jira/browse/INFRA-8753?focusedCommentId=14735394#comment-14735394
https://www.apache.org/dyn/closer.cgi?action=download&filename=tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz \
if the version is outdated, we might have to pull from the dist/archive :/
https://www-us.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz \
https://www.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz \
https://archive.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz
ENV TOMCAT_ASC_URLS \
https://www.apache.org/dyn/closer.cgi?action=download&filename=tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz.asc \
not all the mirrors actually carry the .asc files :'(
https://www-us.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz.asc \
https://www.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz.asc \
https://archive.apache.org/dist/tomcat/tomcat-$TOMCAT_MAJOR/v$TOMCAT_VERSION/bin/apache-tomcat-$TOMCAT_VERSION.tar.gz.asc
RUN set -eux; \
\
savedAptMark="$(apt-mark showmanual)"; \
apt-get update; \
\
apt-get install -y --no-install-recommends gnupg dirmngr; \
\
apt-get install -y --no-install-recommends wget ca-certificates; \
\
success=; \
for url in $TOMCAT_TGZ_URLS; do \
if wget -O tomcat.tar.gz "$url"; then \
success=1; \
break; \
fi; \
done; \
[ -n "$success" ]; \
\
tar -xvf tomcat.tar.gz --strip-components=1; \
rm bin/*.bat; \
rm tomcat.tar.gz*; \
\
nativeBuildDir="$(mktemp -d)"; \
tar -xvf bin/tomcat-native.tar.gz -C "$nativeBuildDir" --strip-components=1; \
apt-get install -y --no-install-recommends \
dpkg-dev \
gcc \
libapr1-dev \
libssl-dev \
make \
"openjdk-${JAVA_VERSION%%[.~bu-]*}-jdk=$JAVA_DEBIAN_VERSION" \
; \
( \
export CATALINA_HOME="$PWD"; \
cd "$nativeBuildDir/native"; \
gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; \
./configure \
--build="$gnuArch" \
--libdir="$TOMCAT_NATIVE_LIBDIR" \
--prefix="$CATALINA_HOME" \
--with-apr="$(which apr-1-config)" \
--with-java-home="$(docker-java-home)" \
--with-ssl=yes; \
make -j "$(nproc)"; \
make install; \
); \
rm -rf "$nativeBuildDir"; \
rm bin/tomcat-native.tar.gz; \
\
reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
apt-mark auto '.*' > /dev/null; \
[ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; \
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
rm -rf /var/lib/apt/lists/*; \
\
sh removes env vars it doesn't support (ones with periods)
https://github.com/docker-library/tomcat/issues/77
find ./bin/ -name '*.sh' -exec sed -ri 's|^#!/bin/sh$|#!/usr/bin/env bash|' '{}' +
verify Tomcat Native is working properly
RUN set -e \
&& nativeLines="$(catalina.sh configtest 2>&1)" \
&& nativeLines="$(echo "$nativeLines" | grep 'Apache Tomcat Native')" \
&& nativeLines="$(echo "$nativeLines" | sort -u)" \
&& if ! echo "$nativeLines" | grep 'INFO: Loaded APR based Apache Tomcat Native library' >&2; then \
echo >&2 "$nativeLines"; \
exit 1; \
fi
EXPOSE 8080
CMD ["catalina.sh", "run"]
3、 使用dockerbuild
命令通过Dockerfile
创建一个镜像my-tomcat:9.0.8-jre8
;
[root@www.hotmindshare.com tomcat]# docker build -t my-tomcat:9.0.8-jre8 .
Sending build context to Docker daemon 10.75 kB
...
4、 稍等片刻,创建完成后就可以在本地的镜像列表里查找到刚刚创建的镜像;
[root@www.hotmindshare.com tomcat]# docker images my-tomcat
REPOSITORY TAG IMAGE ID CREATED SIZE
my-tomcat 9.0.8-jre8 d0ff57656e50 11 days ago 463.8 MB
运行 tomcat 容器
首先创建 tomcat/webapps/demo
目录并在 demo
目录下放一个 index.html
文件,内容如下
<!DOCTYPE html>
<meta charset="utf-8">
<h2>Hello www.hotmindshare.com</h2>
<p>www.hotmindshare.com 安仔的技术指南,教程 </p>
然后使用 docker run
运行 my-tomcat
容器
[root@www.hotmindshare.com tomcat]# docker run -d --name tomcat -p 8080:8080 -v $PWD/webapps/demo:/usr/local/tomcat/webapps/demo tomcat:9.0.8-jre8
e139c23bf7bc3a4926db947e63fa0c07b771fc9b400645668945c07cb8dfd05a
命令说明
1、 -p8080:8080
;
将容器的 8080 端口映射到主机的 8080 端口
2、 -v$PWD/webapps/demo:/usr/local/tomcat/webapps/demo
;
将主机中当前目录下的 webapps/demo 挂载到容器的 /usr/local/tomcat/webapps/demo
查看容器启动情况
可以使用 docker ps -a
查看 tomcat 容器的运行状况
[root@www.hotmindshare.com tomcat]# docker ps -a
CONTAINER ID IMAGE STATUS
e139c23bf7bc tomcat:9.0.8-jre8 Up About a minute
通过浏览器访问 http://localhost:8080/demo/
输出如下
