容器化部署fastdfs文件存储

目录

一、软件信息

二、构建fastdfs镜像

三、docker 启动fdfs服务

四、k8s部署fdfs服务

1、fdfs部署文件

五、外部服务访问


一、软件信息

  1. fastdfs版本:fastdfs:V5.11

  2. libfastcommon版本: V1.0.36

  3. fastdfs-nginx-module版本:V1.20

  4. nginx版本:1.18.0

二、构建fastdfs镜像

        为了减少操作了文件数,我是直接把启动文件和dockerfile写一起了,也可以把启动脚本 start.sh 单独于dockerfile;然后在构建镜像的时候把启动文件 COPY 到镜像里。

        以下是包括了启动文件为一起的dockerfile构建文件。直接使用该dockerfile即可完成镜像构建。然后按照自己的实际情况来修改配置文件和挂载,即可完成容器化运行fastdfs件存储服务。

FROM centos:7

LABEL creator=tudou date="2024-06-02"

ENV FASTDFS_PATH=/var/fastdfs \
    TZ=Asia/Shanghai \
    TRACKER_PORT= \
    STORAGE_PORT= \
    TRACKER_SERVER= \
    GROUP_NAME= 
    

#get all the dependences
RUN yum install -y git wget zip unzip gcc make \
    perl openssl openssl-devel pcre pcre-devel zlib zlib-devel libevent libevent-devel \
 && yum clean all \
 && mkdir -p ${FASTDFS_PATH}/files

RUN git clone --branch V1.0.36 --depth 1 https://github.com/happyfish100/libfastcommon.git ${FASTDFS_PATH}/libfastcommon \
 && cd ${FASTDFS_PATH}/libfastcommon \
 && ./make.sh \
 && ./make.sh install \
 && rm -rf ${FASTDFS_PATH}/libfastcommon

RUN git clone --branch V5.11 --depth 1 https://github.com/happyfish100/fastdfs.git ${FASTDFS_PATH}/fastdfs \
 && cd ${FASTDFS_PATH}/fastdfs  \
 && ./make.sh \
 && ./make.sh install \
 && cp -r  conf/*.* /etc/fdfs/ \
 && rm -rf ${FASTDFS_PATH}/fastdfs 

RUN git clone --branch V1.20 https://github.com/happyfish100/fastdfs-nginx-module.git /usr/local/fastdfs-nginx-module \
 && cp /usr/lib64/libfastcommon.so /usr/local/lib/libfastcommon.so \
 && sed -i "s@/usr/local/include@/usr/include/fastdfs /usr/include/fastcommon@g" /usr/local/fastdfs-nginx-module/src/config \
 && cd ${FASTDFS_PATH} \
 && wget https://nginx.org/download/nginx-1.18.0.tar.gz \
 && tar -xzvf nginx-1.18.0.tar.gz \
 && cd nginx-1.18.0 \
 && ./configure --prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module/src \
 && make \
 && make install \
 && cp /usr/local/fastdfs-nginx-module/src/mod_fastdfs.conf  /etc/fdfs/ \
 && rm -rf ${FASTDFS_PATH}/nginx-1.18.0* 

WORKDIR ${FASTDFS_PATH}

# 启动脚本 start.sh
RUN cat > /usr/bin/start.sh <<-EOF
#!/bin/bash

cd \$(dirname \$0)

# start.sh trackerd 
# start.sh storaged

# # 自定义环境变量初始化,若无自定义环境变量,则直接跳过使用配置文件的默认值
function init_config(){
  if [[ -n \${STORAGE_PORT} ]];then
     sed -i "s|^port=.*$|port=\${STORAGE_PORT}|g" /etc/fdfs/storage.conf
  fi
  if [[ -n \${TRACKER_PORT} ]];then
     sed -i "s|^port=.*$|port=\${TRACKER_PORT}|g" /etc/fdfs/tracker.conf
  fi
  
  if [[ -n \${GROUP_NAME} ]];then
     sed -i "s|group_name=.*$|group_name=\${GROUP_NAME}|g" /etc/fdfs/storage.conf
     sed -i "s|group_name=.*$|group_name=\${GROUP_NAME}|g" /etc/fdfs/mod_fastdfs.conf
     sed -i "s|url_have_group_name =.*$|url_have_group_name = true|g" /etc/fdfs/mod_fastdfs.conf
  fi
  
  if [[ -n \${TRACKER_SERVER} ]];then
     sed -i "s|tracker_server=.*$|tracker_server=\${TRACKER_SERVER}|g" /etc/fdfs/storage.conf
     sed -i "s|tracker_server=.*$|tracker_server=\${TRACKER_SERVER}|g" /etc/fdfs/client.conf
     sed -i "s|tracker_server=.*$|tracker_server=\${TRACKER_SERVER}|g" /etc/fdfs/mod_fastdfs.conf
  fi
  
  sed -i "s|base_path=.*$|base_path=\${FASTDFS_PATH}|g" /etc/fdfs/tracker.conf
  sed -i "s|base_path=.*$|base_path=\${FASTDFS_PATH}|g" /etc/fdfs/storage.conf
  sed -i "s|base_path=.*$|base_path=\${FASTDFS_PATH}|g" /etc/fdfs/client.conf
  sed -i "s|base_path=.*$|base_path=\${FASTDFS_PATH}|g" /etc/fdfs/mod_fastdfs.conf
}

init_config

case \$1 in
     trackerd)
        echo "start trackerd ..."
        fdfs_trackerd /etc/fdfs/tracker.conf start  && tail -f ${FASTDFS_PATH}/logs/trackerd.log
     ;;
	
     storaged)
        sed -i "s|store_path0.*$|store_path0=\${FASTDFS_PATH}/files|g" /etc/fdfs/storage.conf
        sed -i "s|store_path0.*$|store_path0=\${FASTDFS_PATH}/files|g" /etc/fdfs/mod_fastdfs.conf

        echo "start storaged ..."
        fdfs_storaged /etc/fdfs/storage.conf start \
     && /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf \
     && tail -f ${FASTDFS_PATH}/logs/storaged.log
     ;;

     *)
        echo "USAGE sh $0 [ trackerd|storaged ]"
        exit 1
     ;;
esac

EOF
# 启动脚本 start.sh

# 默认fastdfs端口
EXPOSE 22122 23000 8080 8888 80

RUN chmod a+x /usr/bin/start.sh 

ENTRYPOINT ["/usr/bin/start.sh"]
CMD ["trackerd"]
#CMD ["storaged"]
# 构建 fdfs 应用镜像

# docker build -t fdfs:v1.0 -f dockerfile . --no-cache

docker build -t fdfs:v1.0 -f dockerfile . 

三、docker 启动fdfs服务

# 容器启动 trackerd 服务,并且自定义环境变量值,可不指定环境变量值

docker run -itd --name trackerd -e TRACKER_PORT=22122 -e TRACKER_SERVER=192.168.159.132:22122 -p 22122:22122   fdfs:v1.0 trackerd


# 容器启动 storaged 服务,并且自定义环境变量值,可不指定环境变量值

docker run -itd --name storage -e STORAGE_PORT=23000 -e TRACKER_SERVER=192.168.159.132:22122 -p 23000:23000   fdfs:v1.0 storaged

# 分别查看容器应用的日志

docker logs trackerd


docker logs storage


四、k8s部署fdfs服务

1、fdfs部署文件

         由于storage存储是各自独立的,所以要使用有状态部署。tracker是透明无状态的,可以使用无状态负载deploy部署,也可以使用有状态负载StatefulSet部署。
# kubectl apply -f fdfs.yaml -n fdfs

# fdfs 配置文件
---
kind: ConfigMap
apiVersion: v1
metadata:
  name: fdfs-config
  namespace: fdfs
  annotations:
    kubesphere.io/creator: admin
data:
  mod_fastdfs.conf: |-
    base_path=/var/fastdfs
    tracker_server=tracker-svc:22122
    storage_server_port=23000
    group_name=group1
    url_have_group_name = true
    store_path_count=1
    store_path0=/var/fastdfs/files
    group_count = 1
    # 在末尾增加组的具体信息 
    [group1] 
    group_name=group1 
    storage_server_port=23000 
    store_path_count=1 
    store_path0=/var/fastdfs/files

    [group2] 
    group_name=group2 
    storage_server_port=23000 
    store_path_count=1 
    store_path0=/data/fastdfs 
  nginx.conf: |-
    user root;
    worker_processes  2;
    events {
        worker_connections  65535;
        use epoll;
    }
    http {
        include       mime.types;
        default_type  application/octet-stream;
        sendfile        on;
        keepalive_timeout  65;
        server {
            listen       80;
            server_name  localhost;
            charset utf-8;
            server_tokens off;
            location ~group[0-9]/M00 {
                root /var/fastdfs/files/data;
                ngx_fastdfs_module;
            }
            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }
        }
    }
  storage.conf: |-
    group_name=group1
    port=23000
    base_path=/var/fastdfs
    store_path_count=1
    store_path0=/var/fastdfs/files
    tracker_server=tracker-svc:22122
    http.server_port=80
  tracker.conf: |-
    disabled=false
    port=22122
    base_path=/var/fastdfs
    http.server_port=80

---

# kubectl apply -f fdfs-trackerd.yaml -n fdfs
---
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: fdfs-trackerd
  name: fdfs-trackerd
  namespace: fdfs
spec:
  replicas: 1
  selector:
    matchLabels:
      app: fdfs-trackerd
  strategy:
    rollingUpdate:
      maxSurge: 25%
      maxUnavailable: 25%
    type: RollingUpdate
  template:
    metadata:
      labels:
        app: fdfs-trackerd
    spec:
      containers:
      - args:
        - trackerd
        command:
        - /usr/bin/start.sh
        image: swr.cn-south-1.myhuaweicloud.com/tudou/fastdfs:latest
        imagePullPolicy: IfNotPresent
        name: trackerd
        ports:
        - containerPort: 22122
          name: http-0
          protocol: TCP
        - containerPort: 8080
          name: http-1
          protocol: TCP
        resources: {}
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        volumeMounts:
        - mountPath: /etc/fdfs/tracker.conf
          name: volume-b8e30i
          readOnly: true
          subPath: tracker.conf
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      serviceAccount: default
      serviceAccountName: default
      terminationGracePeriodSeconds: 30
      volumes:
      - configMap:
          defaultMode: 420
          name: fdfs-config
        name: volume-b8e30i
---
---
apiVersion: v1
kind: Service
metadata:
  labels:
    app: fdfs-trackerd
  name: fdfs-trackerd
  namespace: fdfs
spec:
  ports:
  - name: port-1
    port: 22122
    protocol: TCP
    targetPort: 22122
  - name: port-2
    port: 8080
    protocol: TCP
    targetPort: 8080
  selector:
    app: fdfs-trackerd
  type: ClusterIP
---



# kubectl apply -f fdfs-storaged.yaml -n fdfs
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  labels:
    app: fdfs-storaged
  name: fdfs-storaged
  namespace: fdfs
spec:
  podManagementPolicy: OrderedReady
  replicas: 2
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      app: fdfs-storaged
  serviceName: fdfs-storaged
  template:
    metadata:
      labels:
        app: fdfs-storaged
    spec:
      containers:
      - args:
        - storaged
        command:
        - /usr/bin/start.sh
        image: swr.cn-south-1.myhuaweicloud.com/tudou/fastdfs:latest
        imagePullPolicy: IfNotPresent
        name: storage
        ports:
        - containerPort: 23000
          name: http-0
          protocol: TCP
        - containerPort: 8888
          name: http-1
          protocol: TCP
        - containerPort: 80
          name: http-2
          protocol: TCP
        resources: {}
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        volumeMounts:
        - mountPath: /etc/fdfs/storage.conf
          name: volume-ssmj62
          readOnly: true
          subPath: storage.conf
        - mountPath: /etc/fdfs/mod_fastdfs.conf
          name: volume-zlknkz
          readOnly: true
          subPath: mod_fastdfs.conf
        - mountPath: /usr/local/nginx/conf/nginx.conf
          name: volume-q4ylwb
          readOnly: true
          subPath: nginx.conf
        - mountPath: /var/fastdfs
          name: fdfs-storage-data
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      serviceAccount: default
      serviceAccountName: default
      terminationGracePeriodSeconds: 30
      volumes:
      - configMap:
          defaultMode: 420
          name: fdfs-config
        name: volume-ssmj62
      - configMap:
          defaultMode: 420
          name: fdfs-config
        name: volume-zlknkz
      - configMap:
          defaultMode: 420
          name: fdfs-config
        name: volume-q4ylwb
  updateStrategy:
    rollingUpdate:
      partition: 0
    type: RollingUpdate
  volumeClaimTemplates:
  - apiVersion: v1
    kind: PersistentVolumeClaim
    metadata:
      name: fdfs-storage-data
    spec:
      accessModes:
      - ReadWriteOnce
      resources:
        requests:
          storage: 120Gi
      storageClassName: local
      volumeMode: Filesystem
---
---
apiVersion: v1
kind: Service
metadata:
  labels:
    app: fdfs-storaged
  name: fdfs-storaged
  namespace: fdfs
spec:
  clusterIP: None
  clusterIPs:
  - None
  internalTrafficPolicy: Cluster
  ipFamilies:
  - IPv4
  ipFamilyPolicy: SingleStack
  ports:
  - name: http-0
    port: 23000
    protocol: TCP
    targetPort: 23000
  - name: http-1
    port: 8888
    protocol: TCP
    targetPort: 8888
  - name: http-2
    port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: fdfs-storaged
  sessionAffinity: None
  type: ClusterIP
---

五、外部服务访问

        当外部服务需要访问fdfs时,需要将服务的 22122和服务的 80 端口暴露。可以将这两个端口对应的服务创建NodePort类型的服务来实现端口暴露。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/677434.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

自动驾驶---Control之LQR控制

1 前言 在前面的系列博客文章中为读者阐述了很多规划相关的知识&#xff08;可参考下面专栏&#xff09;&#xff0c;本篇博客带领读者朋友们了解控制相关的知识&#xff0c;后续仍会撰写规控相关文档。 在控制理论的发展过程中&#xff0c;人们逐渐认识到对于线性动态系统的控…

Websocket服务端结合内网穿透发布公网实现远程访问发送信息

文章目录 1. Java 服务端demo环境2. 在pom文件引入第三包封装的netty框架maven坐标3. 创建服务端,以接口模式调用,方便外部调用4. 启动服务,出现以下信息表示启动成功,暴露端口默认99995. 创建隧道映射内网端口6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号7. 以…

Audition 2024 for Mac/Win:音频录制与编辑的卓越之选

随着数字媒体的不断发展&#xff0c;音频内容创作已经成为各行各业中不可或缺的一部分。无论是音乐制作、广播节目、播客录制还是影视配音&#xff0c;都需要高品质的音频录制和编辑工具来实现专业水准的作品。在这个充满竞争的时代&#xff0c;要想在音频创作领域脱颖而出&…

如何合理使用群发短信呢?(短信接口JSON实例)

随着时代的发展&#xff0c;越来越多的营销推广也开始有线下转移到了线上&#xff0c;短信也变成了企业与用户之间交流沟通的桥梁&#xff0c;那么这么多的企业选择使用短信平台&#xff0c;到底群发短信好不好用呢&#xff1f;今天乐讯通短信平台就为大家来介绍一下群发短信营…

【C++进阶】深入STL之vector:构建高效C++程序的基石

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ ⏩收录专栏⏪&#xff1a;C “ 登神长阶 ” &#x1f921;往期回顾&#x1f921;&#xff1a;模拟实现string &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀STL之vector &#x1f4d2;1.ve…

NLP基础——序列模型(动手学深度学习)

序列模型 定义 序列模型是自然语言处理&#xff08;NLP&#xff09;和机器学习领域中一类重要的模型&#xff0c;它们特别适合处理具有时间顺序或序列结构的数据&#xff0c;例如文本、语音信号或时间序列数据。 举个例子&#xff1a;一部电影的评分在不同时间段的评分可能是…

【个数】滑动窗口-1004. 最大连续1的个数 III 1493. 删掉一个元素以后全为 1 的最长子数组

题目链接及描述 1004. 最大连续1的个数 III - 力扣&#xff08;LeetCode&#xff09; 题目分析 今日写到这个题目&#xff0c;是滑动窗口的标签&#xff0c;但首先看到后感觉和之前做过的滑动窗口题目有点区别&#xff0c;之前滑动窗口通过给定一个区间长度&#xff0c;随后区…

.NET集成DeveloperSharp实现图片的裁剪、缩放、与加水印

&#x1f3c6;作者&#xff1a;科技、互联网行业优质创作者 &#x1f3c6;专注领域&#xff1a;.Net技术、软件架构、人工智能、数字化转型、DeveloperSharp、微服务、工业互联网、智能制造 &#x1f3c6;欢迎关注我&#xff08;Net数字智慧化基地&#xff09;&#xff0c;里面…

第一篇 逻辑门(与门、或门、非门、异或门)

一、实验目的 了解DE1-SOC开发板一些外设。 掌握常用组合逻辑门电路的基本原理。 学习Verilog HDL的基本语法。 学习使用ModelSim工具对设计的电路进行仿真&#xff0c;包括编写Testbench仿真代码&#xff0c;以及ModelSim工具的使用。 熟悉使用Quartus软件从创建Quartus工…

el-tooltip使用记录

记录工作中使用el-toolitp的情况 需求一&#xff1a;列表项内容超出限制时&#xff0c;点击单元格展示Tooltip 需求描述&#xff1a;某列表项内容返回过多&#xff0c;超出最大限制时&#xff1a; 1.点击该单元格再显示tooltip&#xff1b; 2.点击下一行更新tooltip内容&…

《数字图像处理-OpenCV/Python》第15章:图像分割

《数字图像处理-OpenCV/Python》第15章&#xff1a;图像分割 本书京东 优惠购书链接 https://item.jd.com/14098452.html 本书CSDN 独家连载专栏 https://blog.csdn.net/youcans/category_12418787.html 第15章&#xff1a;图像分割 图像分割是由图像处理到图像分析的关键步骤…

关于gitee上传成功没有绿点

今天上传完代码以后&#xff0c;打开gitee看了一下&#xff0c;但是看到昨天和今天都没有小绿点&#xff0c;仔细思考了一番&#xff0c;是仓库满了&#xff1f;不对啊&#xff0c;如果满了的话&#xff0c;上传就会失败啊&#xff0c;那这是什么问题呢&#xff1f; 原来是因为…

Parallels Desktop for Mac 19.4.0更新了哪些内容?有什么改进?

带来了重新设计的共享 Mac 文件夹版本&#xff0c;这些文件夹现在是符号链接&#xff0c;像指针一样指向您的 Mac 文件夹中的文件&#xff0c;同时仍然显示在 Windows 的本地磁盘上。 修复了由于共享文件夹问题导致 NinjaTrader 无法正常启动的问题。 修复了由于共享文件夹问…

2024中国跨境电商海外营销观察报告

来源&#xff1a;霞光智库 近期历史回顾&#xff1a;战略测量的未来报告 2024影响力系列白皮书&#xff08;第五册&#xff09;——绿氢 2024年Z世代与千禧一代调研报告.pdf 2023中国车规级芯片产业白皮书.pdf 2024全球网文应用营销洞察报告.pdf 2024年Q1抖音女性卫生用品行业趋…

操作系统教材第6版——个人笔记1

第一章 计算机操作系统概述 操作系统是计算机系统中最重要的系统软件&#xff0c;它统一管理计算机系统的硬件资源与信息资源&#xff0c;控制与调度上层软件的执行并为其提供易于使用的接口。从资源管理、程序控制、操作控制、人机交互、程序接口、系统结构6个角度深入观察操…

JS冒泡排序案例详解

先看一下案例效果&#xff1a; HTML代码&#xff1a; <input type"text" value"" id"bubble-input"> <button onclick"bubbleSort()">冒泡排序</button> <h4 id"bubbleSort-result"></h4>J…

vue2 bug求助!!!(未解决,大概是浏览器缓存的问题或者是路由的问题)

我的vue2项目出现了一个超级恶心的bug 过程&#xff1a; 1 操作流程&#xff1a;页面a点击a标签->到页面b->页面b用户退出刷新页面->点击浏览器的返回按钮返回上一页 2 结果&#xff1a;返回页面后页面没有刷新导致用户名还显示着&#xff0c;页面没有发生任何变化&a…

5.3.2网安学习第五阶段第三周回顾(个人学习记录使用)

本周重点 ①网络安全攻防技术体系 ②Windows入侵排查 ③Linux入侵排查 ④僵蠕木毒排查与处理 本周主要内容 ①网络安全攻防技术体系 一、攻击层面 1、分类 &#xff08;1&#xff09;指定目标&#xff1a;APT攻击手段&#xff0c;对指定目标进行长期作战和渗透&#x…

从Multisim到Proteus,再到SmartEDA:电子设计软件的进化之旅

在电子设计领域&#xff0c;软件工具的演进犹如一条璀璨的轨迹&#xff0c;记录着科技进步的每一个步伐。从Multisim的初创&#xff0c;到Proteus的崛起&#xff0c;再到如今SmartEDA的崭露头角&#xff0c;这些电子设计软件不仅极大地提升了设计效率&#xff0c;更推动了整个行…

函数高级:函数的默认参数|函数的占位参数|函数重载

函数的默认参数 函数占位参数 函数重载 总结&#xff1a; 函数的形参&#xff0c;有自己的参数值就用参数值&#xff0c;没有就用形参列表的默认值。 参数列表中&#xff0c;某位置有自己的默认值&#xff0c;从该位置起&#xff0c;往后就都必须设有默认值。 函数声明和函数…