使用docker编译部署开源c/c++程序(三)

程序可以编译出来了,后面就要着手只做docker镜像,方面以后的使用。编写c++程序的Dockerfile,可以参考别人是如何制作ffmpeg镜像的
https://github.com/jrottenberg/ffmpeg/blob/master/docker-images/4.0/alpine/Dockerfile

依葫芦画瓢,写了一个poppler的镜像制作文件

FROM alpine:3.8 AS base

RUN echo "https://mirror.tuna.tsinghua.edu.cn/alpine/v3.8/main" > /etc/apk/repositories
RUN echo "https://mirror.tuna.tsinghua.edu.cn/alpine/v3.8/community" >> /etc/apk/repositories
RUN apk add --no-cache libstdc++ freetype fontconfig libjpeg-turbo openjpeg


FROM base AS build

RUN apk add build-base cmake freetype-dev fontconfig-dev libjpeg-turbo-dev openjpeg-dev openjpeg-tools

WORKDIR /usr/include
RUN \
    ln -s openjpeg-2.3/openjpeg.h openjpeg.h && \
    ln -s openjpeg-2.3/opj_stdint.h opj_stdint.h && \
    ln -s openjpeg-2.3/opj_config.h opj_config.h

WORKDIR /tmp
RUN \
    wget https://poppler.freedesktop.org/poppler-0.72.0.tar.xz && \
    tar xJf poppler-0.72.0.tar.xz && \
    cd poppler-0.72.0/ && \
    mkdir build && \
    cd build && \
    cmake ../ && \
    make && \
    make install


FROM base AS release
COPY --from=build /usr/local/bin /usr/local/bin
COPY --from=build /usr/local/lib64 /usr/local/lib

简单说明一下这个Dockerfile。最前面一部分是把apk的安装源改为国内的,同时安装poppler运行所必须的库。第二部分是安装编译所需要的头文件以及开发工具,然后针对poppler的编译做些修改。然后就是下载源码编译了。最后一部分是把编译好的二进制拷贝出来,放到发行的镜像中

构造我们的poppler镜像,并命令为poppler-test
docker build -t poppler-test .
敲命令的时候不要忘了最后一个点"."

docker build比较曹丹的地方在于出错了,又要从头来一遍了,所以编写Dockerfile要仔细检查好再运行。

镜像构造成功之后用docker images命令查看

# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
poppler-test        latest              962169e69975        23 seconds ago      39.5MB
                            6529113968ff        24 seconds ago      315MB
alpine              3.8                 491e0ff7a8d5        4 weeks ago         4.41MB

会发现多出来一个没有名字的IMAGE。这个是编译环境遗留下的IMAGE,到时候用docker rmi命令删掉就行了。

测试编译好的docker镜像,docker run -it poppler-test /bin/sh 启动容器。在容器中输入pdfinfo命令,可以正常运行,说明镜像已经制作好了。

回到上一篇文章的问题,如何解决容器与宿主机之间文件共享。这里可以参考ffmpeg docker的一些做法

docker run --rm -v=`pwd`:/tmp poppler-test pdftoppm -jpeg /tmp/1.pdf /tmp/1

这条命令是将宿主机当前目录下的1.pdf打印成jpg图片。这条命令一是加了--rm,在命令执行完毕后自动删除容器,不造成垃圾;二是使用-v参数,将当前目录映射到容器的/tmp目录,因此当前目录下的1.pdf就成了容器里面的/tmp/1.pdf。转码的输出也是输出到/tmp目录下,以保证写回宿主机

docker run --rm -v=`pwd`:/tmp -w="/tmp" poppler-test pdftoppm -jpeg 1.pdf 1

这条命令还能改造一下,加入-w参数以声明容器的workdir,pdftoppm后面的输入输出文件就不需要再指定路径了

你可能感兴趣的:(使用docker编译部署开源c/c++程序(三))