【FastDfs】Docker自定义构建ARM架构的FastDfs镜像

由于服务器环境为ARM架构,在部署fastdfs时,发现网上的镜像几乎都是X86_64的,不同架构的镜像还不能通用,这个就有点烦了。。。。。

由于之前没有从头编译制作过镜像,步步都是坑,在折腾了几天之后,终于倒腾出来了,这里记录下构建过程。可以举一反三,定制自己的镜像。

这里贴一下官方的原贴:happyfish100/fastdfs,目前的源码,按照这个部署还是没问题的。

1. 环境准备

1.1 下载源码包

拉取官方模块代码工具包,这里推荐使用github下载最新版代码,其中,我们需要的是这三个
【FastDfs】Docker自定义构建ARM架构的FastDfs镜像
fastdfs:

git clone https://github.com/happyfish100/fastdfs.git --depth 1

fastdfs-nginx-module

git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1

libfastcommon

git clone https://github.com/happyfish100/libfastcommon.git --depth 1

如果提示 git clone 出现fatal: unable to access ‘https://github ,将上面地址git clone https换成 git clone git

下载nginx压缩包

wget http://nginx.org/download/nginx-1.15.4.tar.gz 

2. 初步构建只包含安装包的基础镜像

下载完成后,开始编写 Dockerfile :vi Dockerfile

FROM centos:7

MAINTAINER lmm "1632284989@qq.com"

WORKDIR /

ADD libfastcommon /usr/local/src/libfastcommon

ADD fastdfs /usr/local/src/fastdfs

ADD fastdfs-nginx-module /usr/local/src/fastdfs-nginx-module

ADD nginx-1.15.4.tar.gz /usr/local/src

这里先制作一个基础镜像,将源码包整到镜像里面。构建基础镜像:docker build -t fastdfs:V1.0.0 . 注意这里最后的点,表示在当前目录下构建镜像。

这里并没有直接编译,等会可以进入容器里面手动编译,如果编译出错,可以直接使用基础镜像重新启动一个容器。

使用docker images 可以看到镜像 fastdfs:V1.0.0

2. 初步构建只包含安装包的基础镜像

接着以交互式的方式运行上面的基础镜像:docker run -itd --name fastdfs_container fastdfs:V1.0.0 /bin/bash

进入容器内部,到特定文件夹下手动编译:

mkdir /home/fastdfs #创建数据存储目录
cd /usr/local/src #切换到安装目录准备下载安装包
  1. 初始化编译环境:
yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel wget vim -y
  1. 编译安装 libfastcommon :
cd libfastcommon/
./make.sh && ./make.sh install #编译安装
  1. 安装FastDFS
cd ../ #返回上一级目录
git clone https://github.com/happyfish100/fastdfs.git --depth 1
cd fastdfs/
./make.sh && ./make.sh install #编译安装
  1. 安装fastdfs-nginx-module
cd ../ #返回上一级目录
cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs
  1. 安装nginx
cd nginx-1.15.4/
#添加fastdfs-nginx-module模块
./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/ 
make && make install #编译安装

至此编译构建完成,可以提交容器为新的镜像,留存下来。

docker commit -a 'linmengmeng' -m '编译完成,默认配置' 80a87ad6b80e  fastdfs:V1.0.3

接着可再次编写构建脚本,以 fastdfs:V1.0.3 为基础镜像进行构建。

首先编写启动软件的脚本:fastdfs_start.sh

#!/bin/sh

mkdir -p /home/fastdfs

new_val=$FASTDFS_IPADDR
old="192.168.0.165"

new_WEB_PORT=$WEB_PORT
old_WEB_PORT="8888"

echo 'FASTDFS_IPADDR=' ${new_val}
echo 'WEB_PORT=' ${new_WEB_PORT}

sed -i "s/$old/$new_val/g" /etc/fdfs/client.conf
sed -i "s/$old/$new_val/g" /etc/fdfs/storage.conf
sed -i "s/$old/$new_val/g" /etc/fdfs/mod_fastdfs.conf

sed -i "s/$old_WEB_PORT/$new_WEB_PORT/g" /usr/local/nginx/conf/nginx.conf

echo "start trackerd"
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

echo "start storage"
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
 
echo "start nginx"
/usr/local/nginx/sbin/nginx 
 
tail -f  /dev/null

这里加入了动态参数:FASTDFS_IPADDRWEB_PORT,并赋予默认值,可接收启动命令中的 -e后面指定的参数值。

新建 Dockerfile : vi Dockerfile

MAINTAINER lmm "1632284989@qq.com"

WORKDIR /

ADD fastdfs_start.sh /home/fastdfs_start.sh

RUN chmod u+x /home/fastdfs_start.sh

EXPOSE 80 8888 23000 22122

# 设置环境变量 USERNAME 默认值为 admin,后面可以通过docker run -e USERNAME="XXXXXX"修改,这个环境变量在容器里也可以$USERNAME获取
ENV FASTDFS_IPADDR=192.168.0.165 WEB_PORT=8888

CMD ["/home/fastdfs_start.sh"]

构建镜像:docker build -t fastdfs:V1.0.4 ., 此时最终的镜像构建完成。

其中从 fastdfs:V1.0.3fastdfs:V1.0.4 的过程是一个逐渐调试的过程,进入 fastdfs:V1.0.3 的容器里面,手动调试,然后修改 fastdfs_start.sh 脚本的内容。最终才有了正常的 fastdfs:V1.0.4版本镜像。

调试了半天,整的眼都花了。。。。。。。

上一篇:MySQL中的insert ignore into, replace into等的一些用法总结


下一篇:jquery源码解析:jQuery数据缓存机制详解1