用一次FastDFS
FastDFS
c编写的分布式文件系统,用于搭建文件服务器集群提供文件的上传、下载
特点
- 冗余备份
- 负载均衡
- 线性扩容
- 高性能、高可用
FastDFS架构
Tracker server
负载均衡和调度、任务状态跟踪
Storage server
文件上传,存储client
Tracker server and Storage server都可以配置集群 每个节点地位相同 没有主从概念
FastDFS 安装
安装FastDFS依赖包
tar -zxvf libfastcommon-master.zip
cd libfastcommon-master
./make.sh
sudo ./make.sh install
安装FastDFS
tar -zxvf fastdfs-master.zip
cd fastdfs-master
./make.sh
sudo ./make.sh install
配置Tracker Server
sudo cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
- 在当前用户的家目录下创建目录fastdfs/tracker
mkdir -p /home/mark/fastdfs/tracker
sudo vim /etc/fdfs/tracker.conf
base_path=/home/mark/fastdfs/tracker
配置Storage Server
sudo cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
- 在当前用户的家目录下创建目录fastdfs/storage
mkdir -p /home/mark/fastdfs/storage
sudo vim /etc/fdfs/storage.conf
base_path=/home/mark/fastdfs/storage
store_path0=/home/mark/fastdfs/storage
tracker_server=Tracker Server的IP+端口 默认端口22122
启动Tracker and Storage server
sudo service fdfs_trackerd start
sudo service fdfs_storaged start
在ubuntu18上源码编译安装不会自动生成systemd文件,上述方法无法启动服务
可以使用fdfs_trackerd <config file> start
的方式启动
测试
sudo cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf
sudo vim /etc/fdfs/client.conf
base_path=/home/mark/fasdfs/tracker
tracker_server=Tracker Server的ip+port
- 上传文件测试
mark@ocarina:~$ fdfs_upload_file /etc/fdfs/client.conf /home/mark/图片/hack.jpg
group1/M00/00/00/wKgDDlxFMc2ATakWAACLAixyQHY987.jpg
上传文件成功
安装nginx+fastdfs-nginx-module
nginx服务器在提供静态资源方面性能好,所以将nginx和FastDFS结合
FastDFS负责上传,下载文件的任务交给nginx服务器
tar -zxvf nginx-1.14.2.tar.gz
cd nginx-1.14.2/
执行
mark@ocarina:~/package/nginx-1.14.2$ sudo ./configure --prefix=/usr/local/nginx/
--add-module=/home/mark/package/fastdfs-nginx-module-master/src
--without-http_rewrite_module
--without-http_gzip_module
sudo make
sudo make install
将
fastdfs-nginx-module-master
解压后的目录中src下的mod_fastdfs.conf
复制到/etc/fdfs/mod_fastdfs.conf
修改内容:
connect_timeout=10
tracker_server=Tracker Server 的ip地址:22122
url_have_group_name=true
store_path0=/home/mark/fastdfs/storage
将解压缩的
fastdfs-master
目录conf目录中的mime.types
、http.conf
复制到/etc/fdfs/
中sudo vim /usr/local/nginx/conf/nginx.conf
#在http部分中添加配置信息如下:
server {
listen 8888;
server_name localhost;
location ~/group[0-9]/ {
ngx_fastdfs_module;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
启动nginx服务
sudo /usr/local/nginx/sbin/nginx
(关闭nginx -s stop)
Python与FastDFS交互
使用pip install fdfs_client-py-master.zip
安装fdfs_client-py-master.zip
# 引入Fdfs_client类
from fdfs_client.client import Fdfs_client
# 创建Fdfs_client类对象 参数是配置文件的路径
client = Fdfs_client('/etc/fdfs/client.conf')
# 上传文件
ret = client.upload_by_filename('base_model.py')
# 返回值
print(ret)
-----------------------------------------
getting connection
<fdfs_client.connection.Connection object at 0x7f5ce39307f0>
<fdfs_client.fdfs_protol.Tracker_header object at 0x7f5ce3930d30>
{'Group name': 'group1', 'Remote file_id': 'group1/M00/00/00/wKgDDlxFQ0-ARToDAAACBtn6q1o4007.py', 'Status': 'Upload successed.', 'Local file name': 'base_model.py', 'Uploaded size': '518B', 'Storage IP': '192.168.3.14'}
fdfs_client-py from x import StringIO 及 import basestring 报错
修改为 from io import StringIO basestring在python3中没有 将这一行注释掉
将 isinstance(filename, basestring) 改为 isinstance(filename, str)
用一次FastDFS的更多相关文章
- 【架构设计】分布式文件系统 FastDFS的原理和安装使用
本文地址 分享提纲: 1.概述 2. 原理 3. 安装 4. 使用 5. 参考文档 1. 概述 1.1)[常见文件系统] Google了一下,流行的开源分布式文件系统有很多,介绍如下: -- mo ...
- FASTDFS调研报告(V1.0)
之前的文章,现在放出来,以供参阅. 一.fastdfs简介 FastDFS是一个轻量级的开源分布式文件系统 FastDFS主要解决了大容量的文件存储和高并发访问的问题,文件存取时实现了负载均衡 Fas ...
- 网站文件系统发展&&分布式文件系统fastDFS
网站文件系统发展 1.单机时代的图片服务器架构 初创时期由于时间紧迫,开发人员水平也很有限等原因.所以通常就直接在website文件所在的目录下,建立1个upload子目录,用于保存用户上传的图片文件 ...
- FastDFS 安装及使用
FastDFS 安装及使用 2012-11-17 13:10:31| 分类: Linux|举报|字号 订阅 Google了一下,流行的开源分布式文件系统有很多,介绍如下: mogileF ...
- 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署
少啰嗦,直接装 看过上一篇分布式文件系统 - FastDFS 简单了解一下的朋友应该知道,本次安装是使用目前余庆老师开源的最新 V5.05 版本,是余庆老师放在 Github 上的,和目前你能在网络上 ...
- 分布式文件系统 - FastDFS 简单了解一下
别问我在哪里 也许我早已不是我自己,别问我在哪里,我一直在这里. 突然不知道说些什么了... 初识 FastDFS 记得那是我刚毕业后进入的第一家公司,一个技术小白进入到当时的项目组后,在开发中上传用 ...
- 分布式文件系统 - FastDFS 配置 Nginx 模块及上传测试
也不说废话,直接干 上一篇 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署 中安装了 FastDFS 后,并配置启动了 Tracker 和 Storage 服务,已经可以上传文件 ...
- centos 系统下安装FastDFS+nginx+fastdfs-nginx-module安装配置
前言: 以前的项目上传的文件都是保存到本地或者是局域网内的共享文件夹下,由于数据量,服务器的负载均衡(分机的某些图片无法访问的问题处理)等因素的情况下,就想到用fastdfs来文件管理,花了几天时间硬 ...
- FastDFS+Nginx(单点部署)事例
FastDFS是由淘宝的余庆先生所开发,是一个轻量级.高性能的开源分布式文件系统,用纯C语言开发,包括文件存储.文件同步.文件访问(上传.下载).存取负载均衡.在线扩容.相同内容只存储一份等功能,适合 ...
- 在虚拟机中配置FastDFS+Nginx模块
先上部署图 提示一下, ip 192.168.72.138 上面部署了两个group, 分别为 group1和g2. 另外, 同组之内的 port 要保持一致. 一.安装准备 1. #每台机器都添加两 ...
随机推荐
- Redis 哨兵 Sentinel
Redis Sentinel:redis集群应用,分布式系统. 多个Sentinal进程之间通过 gossip 协议来接收主服务器是否下线的信息,通过 Raft 一致性协议来决定故障转移及转移服务 ...
- header field token is not allowed by Access-Control-Allow-Headers in preflight response问题解决
今天下午,本来打算使用aioxs在header里传一个token给后台服务器,如下图所示: 结果,控制台报了如下的错: 然后,我不停地百度,不停的改后台express的header设置,一直没有效果: ...
- 【Shell 开发】Shell 目录
目录 [第一章]Shell 概述 [第二章]Shell 变量 [第三章]Shell 变量的数值计算 [第四章]Shell 条件测试表达式 [shell 练习1]编写Shell条件句练习 [shell ...
- [线性DP][codeforces-1110D.Jongmah]一道花里胡哨的DP题
题目来源: Codeforces - 1110D 题意:你有n张牌(1,2,3,...,m)你要尽可能多的打出[x,x+1,x+2] 或者[x,x,x]的牌型,问最多能打出多少种牌 思路: 1.三组[ ...
- springboot集成jpa,在postgresql数据库中创建主键自增表
依赖文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http:/ ...
- [python]序列的重复操作符
当你需要需要一个序列的多份拷贝时,重复操作符非常有用,它的语法如下: sequence * copies_int In [1]: a = [1,2,3,4] In [2]: a * 5 Out[2]: ...
- 使用 MPI for Python 并行化遗传算法
前言 本文中作者使用MPI的Python接口mpi4py来将自己的遗传算法框架GAFT进行多进程并行加速.并对加速效果进行了简单测试. 项目链接: GitHub: https://github.com ...
- pyextend库-merge可迭代对象合并函数
pyextend - python extend lib merge (iterable1, *args) 参数: iterable1: 实现 __iter__的可迭代对象, 如 str, tupl ...
- “Hello World!团队”Beta发布—视频链接+文案+美工
视频链接:http://v.youku.com/v_show/id_XMzE3MjEyMzkyMA==.html?spm=a2h3j.8428770.3416059.1 文案+美工:http://ww ...
- AVL树 算法思想与代码实现
AVL树是高度平衡的二叉搜索树,按照二叉搜索树(Binary Search Tree)的性质,AVL首先要满足: 若它的左子树不为空,则左子树上所有结点的值均小于它的根结点的值: 若它的右子树不为空, ...