FastDFS安装并整合Openresty
FastDFS安装并整合Openresty
- 一、安装环境准备【CentOS7.9】
- 二、FastDFS--tracker安装
- 2.1.下载fastdfs
- 2.2.FastDFS安装环境
- 2.3.安装FastDFS依赖libevent库
- 2.4.安装libfastcommon
- 2.5.安装 libserverframe 网络框架
- 2.6.tracker编译安装
- 2.7.安装之后文件目录介绍
- 2.8.错误处理
- 2.9.配置FastDFS跟踪器(Tracker)
- 2.9.1.FastDFS 配置文件详解
- 2.9.2.备份tracker配置文件并修改
- 2.9.3.创建tracker基础数据目录
- 2.9.4.防火墙放行端口
- 2.9.5.初次成功启动
- 2.10.启动
- 三、FastDFS--storage安装
- 3.1.安装libevent
- 3.2.安装libfastcommon
- 3.3.storage编译安装
- 3.4.配置 FastDFS 存储 (Storage)
- 3.4.1.备份storage配置文件并修改
- 3.4.2.创建Storage基础数据目录,对应base_path目录
- 3.4.3.防火墙放行端口
- 3.4.4.初次启动
- 3.5.启动
- 3.6.查看Storage和Tracker是否在通信
- 3.7.Storage 目录
- 四、FastDFS 服务启动、停止、重启设置
- 4.1.创建文件夹管理脚本
- 4.2.编辑启动脚本文件 startFastDFS.sh
- 4.3.编辑停止脚本文件 stopFastDFS.sh
- 4.4.编辑重启脚本文件 restartFastDFS.sh
- 4.5.FastDFS安装成系统服务
- 4.6.fastdfs常用命令
- 五、上传图片测试:通过fdfs_test程序
- 5.1.FastDFS安装成功可通过`/usr/bin/fdfs_test`测试上传、下载等操作
- 5.2.修改/etc/fdfs/client.conf
- 5.3.上传文件使用格式
- 5.4.打印如下日志
- 5.5.下载路径
- 六、FastDFS 和nginx整合
- 6.1.nginx代理
- 6.2.在Storage上安装openresty
- 6.2.1.下载fastdfs-nginx-module模块
- 6.2.2.修改config文件将/usr/local/路径改为/usr/
- 6.2.3.将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下
- 6.2.4.修改`mod_fastdfs.conf`的内容
- 6.2.5.openresty安装【添加fastdfs-nginx-module模块】
- 6.2.6.编辑nginx配置文件nginx.conf
- 6.3.访问测试
- 6.3.1.访问storage:
- 6.3.2.访问tracker:
- 6.3.3.使用域名访问 (推荐):
- 6.4.测试上传图片
- 6.5.访问图片预览效果【success】
- endl
一、安装环境准备【CentOS7.9】
[root@localhost ~]# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
libfastcommon-1.0.72.tar.gz
libserverframe-1.2.2.tar.gz
fastdfs-6.11.0.tar.gz
openresty/1.25.3.1
fastdfs-nginx-module-1.24.tar.gz
二、FastDFS–tracker安装
分别在192.168.229.141和192.168.229.142上安装tracker
注:初次安装可只安装一台tracker方便调试
2.1.下载fastdfs
tracker和storage使用相同的安装包,下载地址:https://github.com/happyfish100/FastDFS
2.2.FastDFS安装环境
FastDFS是C语言开发,建议在linux上运行,本教程使用Centos7.9作为安装环境。
安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc
yum install gcc-c++
2.3.安装FastDFS依赖libevent库
yum -y install libevent
2.4.安装libfastcommon
libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。
下载地址:https://github.com/happyfish100/libfastcommon
将libfastcommon-1.0.72.tar.gz拷贝至/usr/local/下
cd /usr/localtar -zxvf libfastcommon-1.0.72.tar.gzcd libfastcommon-1.0.72./make.sh./make.sh installcd /usr/lib
安装完成之后查看相关文件,默认情况下:
头文件安装在/usr/include/fastcommon目录下
动态库安装在/usr/lib64/和/usr/lib/目录下
2.5.安装 libserverframe 网络框架
安装包下载地址
:https://github.com/happyfish100/libserverframe
cd /usr/localtar -zxvf libserverframe-1.2.2.tar.gzcd libserverframe-1.2.2./make.sh ./make.sh install
2.6.tracker编译安装
将fastdfs-6.11.0.tar.gz拷贝至/usr/local/下
cd /usr/localtar -zxvf fastdfs-6.11.0.tar.gzcd fastdfs-6.11.0./make.sh./make.sh install
安装成功将安装目录下的conf下的文件拷贝到/etc/fdfs/下
cp /usr/local/fastdfs-6.11.0/conf/* /etc/fdfs/
2.7.安装之后文件目录介绍
安装之后,工具安装在/usr/bin/目录下:fdfs_delete_file:删除文件
fdfs_download_file:下载文件
fdfs_upload_file:上传文件
fdfs_trackerd:启动tracker服务
fdfs_storaged:启动storage服务
fdfs_file_info:用来检查一个文件的信息,参数传递一个FastDFS文件
[root@localhost fastdfs-6.11.0]# ls /usr/bin/fdfs_*
/usr/bin/fdfs_appender_test /usr/bin/fdfs_crc32 /usr/bin/fdfs_file_info
/usr/bin/fdfs_storaged /usr/bin/fdfs_trackerd
/usr/bin/fdfs_appender_test1 /usr/bin/fdfs_delete_file /usr/bin/fdfs_monitor
/usr/bin/fdfs_test /usr/bin/fdfs_upload_appender
/usr/bin/fdfs_append_file /usr/bin/fdfs_download_file /usr/bin/fdfs_regenerate_filename
/usr/bin/fdfs_test1 /usr/bin/fdfs_upload_file
配置文件默认安装在/etc/fdfs/目录下:
client.conf.sample:客户端默认配置文件
storage.conf.sample:storage服务默认配置文件
storage_ids.conf.sample:
tracker.conf.sample:tracker服务默认配置文件
[root@localhost fastdfs-6.11.0]# ls /etc/fdfs
anti-steal.jpg client.conf http.conf mime.types storage.conf storage_ids.conf tracker.conf
动态库文件分别安装在/usr/lib/目录和/usr/lib64/目录下
2.8.错误处理
[root@localhost fastdfs-6.11.0]# ./make.sh
gcc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O1 -DDEBUG_FLAG -c -o ../common/fdfs_global.o ../common/fdfs_global.c -I../common -I/usr/local/include
In file included from ../common/fdfs_global.c:21:0:
../common/fdfs_global.h:17:26: 致命错误:sf/sf_global.h:没有那个文件或目录#include "sf/sf_global.h"^
编译中断。
make: *** [../common/fdfs_global.o] 错误 1
gcc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O1 -DDEBUG_FLAG -c -o ../common/fdfs_global.o ../common/fdfs_global.c -I. -Itrunk_mgr -I../common -I../tracker -I../client -Ifdht_client -I/usr/include/fastcommon
In file included from ../common/fdfs_global.c:21:0:
../common/fdfs_global.h:17:26: 致命错误:sf/sf_global.h:没有那个文件或目录#include "sf/sf_global.h"^
编译中断。
make: *** [../common/fdfs_global.o] 错误 1
gcc -Wall -D_FILE_OFFSET_BITS=64 -D_GNU_SOURCE -g -O1 -DDEBUG_FLAG -c -o ../common/fdfs_global.o ../common/fdfs_global.c -I../common -I../tracker -I/usr/include/fastcommon
In file included from ../common/fdfs_global.c:21:0:
../common/fdfs_global.h:17:26: 致命错误:sf/sf_global.h:没有那个文件或目录#include "sf/sf_global.h"^
编译中断。
make: *** [../common/fdfs_global.o] 错误 1
原因
:在安装较新版得 fastdfs 时,从github 下载得安装包缺少文件,缺少了 libserverframe 网络框架
解决方法
:`安装 libserverframe 网络框架``
安装包下载地址
:https://github.com/happyfish100/libserverframe
cd /usr/localtar -zxvf libserverframe-1.2.2.tar.gzcd libserverframe-1.2.2./make.sh ./make.sh install
安装完成后重新编译 fastdfs
2.9.配置FastDFS跟踪器(Tracker)
2.9.1.FastDFS 配置文件详解
FastDFS 配置文件详解:http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=1941456&extra=page%3D1%26filter%3Ddigest%26digest%3D1
2.9.2.备份tracker配置文件并修改
cd /etc/fdfs# 备份tracker配置文件
cp tracker.conf tracker.conf.bak# 修改文件
vi tracker.conf
# 配置文件是否不生效,false 为生效
disabled=false# 提供服务的端口
port=22122# Tracker 数据和日志目录地址(根目录必须存在,子目录会自动创建)
#base_path = /opt/fastdfs
#base_path=/home/fastdfs/Tracker
base_path = /home/fastdfs# HTTP 服务端口 默认8080 ,建议修改 防止冲突
#http.server_port = 8080
http.server_port = 80
2.9.3.创建tracker基础数据目录
# 创建tracker基础数据目录,即base_path对应的目录
mkdir -p /home/fastdfs
2.9.4.防火墙放行端口
# 检查端口号是否被占用
netstat -apn | grep 22122# 防火墙放行端口(默认的22122)
firewall-cmd --zone=public --add-port=22122/tcp --permanent# 配置立即生效
firewall-cmd --reload# 查询开放端口
firewall-cmd --list-ports
2.9.5.初次成功启动
初次成功启动,会在 /home/fastdfs/ (配置的base_path)下创建 data、logs 两个目录
[root@localhost fdfs]# ls /home/fastdfs/
data logs
${base_path}
|__data
| |__storage_groups.dat:存储分组信息
| |__storage_servers.dat:存储服务器列表
|__logs
| |__trackerd.log: tracker server 日志文件
2.10.启动
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf stop# 检查是否启动
ps aux | grep fdfs*
三、FastDFS–storage安装
分别在192.168.229.143、192.168.229.144、192.168.229.145、192.168.229.146上安装storage
注:初次安装可只安装一台storage方便调试。
3.1.安装libevent
同上
3.2.安装libfastcommon
同上
3.3.storage编译安装
同tracker编译安装
3.4.配置 FastDFS 存储 (Storage)
3.4.1.备份storage配置文件并修改
cd /etc/fdfs# 备份storage配置文件
cp storage.conf storage.conf.bakvi storage.conf
# 配置文件是否不生效,false 为生效
disabled=false # 指定此 storage server 所在 组(卷)
group_name = group1# storage server 服务端口
port=23000# 心跳间隔时间,单位为秒 (这里是指主动向 tracker server 发送心跳)
heart_beat_interval=30# Storage 数据和日志目录地址(根目录必须存在,子目录会自动生成)
#base_path = /opt/fastdfs
#base_path=/home/fastdfs/Storage
base_path = /home/fastdfs# 存放文件时 storage server 支持多个路径。这里配置存放文件的基路径数目,通常只配一个目录。
store_path_count=1# 逐一配置 store_path_count 个路径,索引号基于 0。
#store_path0 = /opt/fastdfs
store_path0 = /home/fastdfs/fdfs_storage
#store_path1 = /opt/fastdfs2
#如果有多个挂载磁盘则定义多个store_path,如下
#store_path1=.....
#store_path2=......# FastDFS 存储文件时,采用了两级目录。这里配置存放文件的目录个数。
# 如果本参数只为 N(如: 256),那么 storage server 在初次运行时,会在 store_path 下自动创建 N * N 个存放文件的子目录。
subdir_count_per_path=256#tracker_server = 192.168.209.121:22122
#tracker_server = 192.168.209.122:22122
#配置tracker服务器:IP
tracker_server = 192.168.229.141:22122
#如果有多个则配置多个tracker
#tracker_server = 192.168.229.142:22122# 允许系统同步的时间段 (默认是全天) 。一般用于避免高峰同步产生一些问题而设定。
sync_start_time=00:00
sync_end_time=23:59# 访问端口 默认80 建议修改 防止冲突
#http.server_port = 8888
#配置http端口
http.server_port = 80
3.4.2.创建Storage基础数据目录,对应base_path目录
# 对应base_path
mkdir -p /home/fastdfs# 这是配置的store_path0路径,有多个要创建多个
mkdir -p /home/fastdfs/fdfs_storage
3.4.3.防火墙放行端口
# 检查端口号是否被占用
netstat -apn | grep 23000# 防火墙放行端口(默认的 23000)
firewall-cmd --zone=public --add-port=23000/tcp --permanent# 配置立即生效
firewall-cmd --reload# 查询开放端口
firewall-cmd --list-ports
3.4.4.初次启动
启动Storage前确保Tracker是启动的
初次启动成功,会在 /home/fastdfs/fdfs_storage/base(base_path) 目录下创建 data、 logs 两个目录
3.5.启动
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart/usr/bin/fdfs_storaged /etc/fdfs/storage.conf stop
# 检查是否启动
ps aux | grep fdfs*
3.6.查看Storage和Tracker是否在通信
/usr/bin/fdfs_monitor /etc/fdfs/storage.conf
3.7.Storage 目录
同Tracker一样,Storage 启动成功后,在base_path 下创建了data、logs目录,记录着 Storage Server 的信息
在 store_path0/data 目录下,创建了N*N个子目录:
[root@localhost fdfs]# ls /home/fastdfs/fdfs_storage/data/
00 07 0E 15 1C 23 2A 31 38 3F 46 4D 54 5B 62 69 70 77 7E 85 8C 93 9A A1 A8 AF
B6 BD C4 CB D2 D9 E0 E7 EE F5 FC 01 08 0F 16 1D 24 2B 32 39 40 47 4E 55 5C 63
6A 71 78 7F 86 8D 94 9B A2 A9 B0 B7 BE C5 CC D3 DA E1 E8 EF F6 FD 02 09 10 17
1E 25 2C 33 3A 41 48 4F 56 5D 64 6B 72 79 80 87 8E 95 9C A3 AA B1 B8 BF C6 CD
D4 DB E2 E9 F0 F7 FE 03 0A 11 18 1F 26 2D 34 3B 42 49 50 57 5E 65 6C 73 7A 81
88 8F 96 9D A4 AB B2 B9 C0 C7 CE D5 DC E3 EA F1 F8 FF 04 0B 12 19 20 27 2E 35
3C 43 4A 51 58 5F 66 6D 74 7B 82 89 90 97 9E A5 AC B3 BA C1 C8 CF D6 DD E4 EB
F2 F9 05 0C 13 1A 21 28 2F 36 3D 44 4B 52 59 60 67 6E 75 7C 83 8A 91 98 9F A6
AD B4 BB C2 C9 D0 D7 DE E5 EC F3 FA 06 0D 14 1B 22 29 30 37 3E 45 4C 53 5A 61
68 6F 76 7D 84 8B 92 99 A0 A7 AE B5 BC C3 CA D1 D8 DF E6 ED F4 FB
四、FastDFS 服务启动、停止、重启设置
4.1.创建文件夹管理脚本
mkdir -p /usr/fdfscd /usr/fdfs
4.2.编辑启动脚本文件 startFastDFS.sh
# 编辑脚本
vi startFastDFS.sh# 给所有人添加执行权限
chmod a+x startFastDFS.sh# 启动脚本
./startFastDFS.sh# 查看是否启动成功
ps aux | grep fdfs*
脚本内容:
#!/bin/bash
# 启动tracker服务
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf start# 启动storage服务
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf startecho 'FastDFS start success'
4.3.编辑停止脚本文件 stopFastDFS.sh
# 编辑脚本
vi stopFastDFS.sh# 给所有人添加执行权限
chmod a+x stopFastDFS.sh# 停止脚本
./stopFastDFS.sh# 查看是否停止成功
ps aux | grep fdfs*
脚本内容:
#!/bin/bash
# 停止tracker服务
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf stop# 停止storage服务
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf stopecho 'FastDFS stop success'
4.4.编辑重启脚本文件 restartFastDFS.sh
# 编辑脚本
vi restartFastDFS.sh# 给所有人添加执行权限
chmod a+x restartFastDFS.sh# 重启脚本
./restartFastDFS.sh# 查看是否停止成功
ps aux | grep fdfs*
脚本内容:
#!/bin/bash
# 重启tracker服务
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart# 重启storage服务
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restartecho 'FastDFS restart success'
4.5.FastDFS安装成系统服务
# 创建脚本
vi /usr/lib/systemd/system/fastdfs.service# 重新加载系统服务
systemctl daemon-reload
服务脚本内容
[Unit]
Description=fastdfs - Fast Distributed File System
After=network.target[Service]
Type=forking
ExecStart=/usr/fdfs/startFastDFS.sh
ExecReload=/usr/fdfs/stopFastDFS.sh
ExecStop=/usr/fdfs/stopFastDFS.sh
PrivateTmp=true[Install]
WantedBy=default.target
[Unit]:服务的说明
Description:描述服务
After:描述服务类别
[Service]服务运行参数的设置
Type=forking是后台运行的形式ExecStartpre是检查配置文件
ExecStart为服务的具体运行命令
ExecReload为重启命令
ExecStop为停止命令
PrivateTmp=True表示给服务分配独立的临时空间
注意:[Service]的启动、重启、停止命令全部要求使用绝对路径
[Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3
4.6.fastdfs常用命令
# 启动服务
systemctl start fastdfs#停止
systemctl stop fastdfs#重启
systemctl restart fastdfs# 查看fastdfs状态
systemctl status fastdfs# 开机启动
systemctl enable fastdfs# 查看fdfs
ps aux | grep fdfs*
五、上传图片测试:通过fdfs_test程序
5.1.FastDFS安装成功可通过/usr/bin/fdfs_test
测试上传、下载等操作
5.2.修改/etc/fdfs/client.conf
vi /etc/fdfs/client.conf
tracker_server根据自己部署虚拟机的情况配置
#Client 的数据和日志目录
#base_path=/home/fastdfs/client
base_path=/home/fastdfs
tracker_server=192.168.229.141:22122
#tracker_server=192.168.229.142:22122
5.3.上传文件使用格式
/usr/bin/fdfs_test 客户端配置文件地址 upload 上传文件
比如将/etc/fdfs/anti-steal.jpg
下的图片上传到FastDFS中:
/usr/bin/fdfs_test /etc/fdfs/client.conf upload /etc/fdfs/anti-steal.jpg
5.4.打印如下日志
[root@localhost fdfs]# vi client.conf
[root@localhost fdfs]#
[root@localhost fdfs]# /usr/bin/fdfs_test /etc/fdfs/client.conf upload /etc/fdfs/anti-steal.jpg
This is FastDFS client test program v6.11.0Copyright (C) 2008, Happy Fish / YuQingFastDFS may be copied only under the terms of the GNU General
Public License V3, which may be found in the FastDFS source kit.
Please visit the FastDFS Home Page http://www.fastken.com/
for more detail.[2024-02-09 18:33:56] DEBUG - base_path=/home/fastdfs, connect_timeout=5, network_timeout=60, tracker_server_count=1,
anti_steal_token=0, anti_steal_secret_key length=0, use_connection_pool=0, g_connection_pool_max_idle_time=3600s,
use_storage_id=0, connect_first_by=tracker, storage server id count: 0, multi storage ips: 0tracker_query_storage_store_list_without_group: server 1. group_name=, ip_addr=192.168.229.141, port=23000group_name=group1, ip_addr=192.168.229.141, port=23000
storage_upload_by_filename
group_name=group1, remote_filename=M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041.jpg
source ip address: 192.168.229.141
file timestamp=2024-02-09 18:33:57
file size=23981
file crc32=3835630198
example file url: http://192.168.229.141/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041.jpg
storage_upload_slave_by_filename
group_name=group1, remote_filename=M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg
source ip address: 192.168.229.141
file timestamp=2024-02-09 18:33:57
file size=23981
file crc32=3835630198
example file url: http://192.168.229.141/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg
5.5.下载路径
http://192.168.229.141/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg
就是文件的下载路径
对应storage服务器上的
/home/fastdfs/fdfs_storage/data/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg文件
由于现在还没有和nginx整合无法使用http下载
六、FastDFS 和nginx整合
6.1.nginx代理
nginx代理storage上的nginx,并进行负载均衡
nginx的安装细节参考nginx文档,这里使用单机nginx,也可以使用两台nginx
组成高可用或者采用lvs+nginx
访问Storage上的nginx
创建nginx-fdfs.conf
配置文件:
#storage群group1组
upstream storage_server_group1{server 192.168.229.143:80 weight=10;server 192.168.229.144:80 weight=10;}
#storage群group2组
upstream storage_server_group2{server 192.168.229.145:80 weight=10;server 192.168.229.146:80 weight=10;}server {listen 80;server_name location;location /group1{proxy_redirect off;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://storage_server_group1;}location /group2{proxy_redirect off;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://storage_server_group2;}
}
6.2.在Storage上安装openresty
6.2.1.下载fastdfs-nginx-module模块
下载地址:https://github.com/happyfish100/fastdfs-nginx-module
将fastdfs-nginx-module-1.24.tar.gz传至/openresty/core/moudle/下
cd /openresty/core/moudletar -zxvf fastdfs-nginx-module-1.24.tar.gzmv fastdfs-nginx-module-1.24 fastdfs-nginx-modulecd fastdfs-nginx-module/src
6.2.2.修改config文件将/usr/local/路径改为/usr/
#修改config文件将/usr/local/路径改为/usr/
cd fastdfs-nginx-module/srcvi config
6.2.3.将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下
#将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下
cp mod_fastdfs.conf /etc/fdfs/
6.2.4.修改mod_fastdfs.conf
的内容
vi /etc/fdfs/mod_fastdfs.conf
# 连接超时时间
connect_timeout=10base_path=/home/fastdfstracker_server=192.168.229.141:22122
#tracker_server=192.168.229.142:22122# StorageServer 默认端口
storage_server_port=23000# 如果文件ID的uri中包含/group**,则要设置为true
url_have_group_name=true#指定文件存储路径,Storage配置的store_path0路径,必须和storage.conf中的一致
store_path0=/home/fastdfs/fdfs_storage
find / -name libfdfsclient.so#将libfdfsclient.so拷贝至/usr/lib下
cp /usr/lib64/libfdfsclient.so /usr/lib/
6.2.5.openresty安装【添加fastdfs-nginx-module模块】
openresty安装:https://blog.csdn.net/qq_45740503/article/details/135887895
./configure --add-module=/openresty/core/moudle/fastdfs-nginx-module/srcmake && make installnginx -V
6.2.6.编辑nginx配置文件nginx.conf
新建nginx配置文件nginx-fdfs.conf
直接编辑nginx.conf
vi /usr/local/openresty/nginx/conf/nginx.conf
server {listen 80;server_name 192.168.229.141;#在80端口下添加fastdfs-nginx-module模块location ~/group([0-9])/M00 {root /home/fastdfs/fdfs_storage/data;ngx_fastdfs_module;}
}
说明:
server_name指定本机iplocation /group1/M00/:group1为nginx 服务fastdfs的分组名称,
M00是fastdfs自动生成编号,对应store_path0=/home/fastdfs/fdfs_storage,
如果fastdfs定义store_path1,这里就是M01
listen 80端口值是要与 /etc/fdfs/storage.conf 中的 http.server_port=80相对应。
如果改成其它端口,则需要统一,同时在防火墙中打开该端口。
6.3.访问测试
通过java客户端上传文件,使用浏览器http访问文件,这里访问上传图片测试的文件:
6.3.1.访问storage:
http://192.168.229.143/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg
如果配置了多个ip地址改为192.168.229.144也行,因为同一个分组的storage文件互相同步。
6.3.2.访问tracker:
http://192.168.229.141/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041.jpg
如果配置了多个ip地址改为192.168.229.142也行
6.3.3.使用域名访问 (推荐):
nginx对外由vip提供服务,使用域名访问如下:
比如vip对应的域名为img.test.com:
http://img.test.com/group1/M00/00/00/wKjljWXF_5WALK3dAABdreSfEnY041_big.jpg
6.4.测试上传图片
/usr/bin/fdfs_test 客户端配置文件地址 upload 上传文件
/usr/bin/fdfs_test /etc/fdfs/client.conf upload /etc/fdfs/22.png
6.5.访问图片预览效果【success】
http://192.168.229.141/group1/M00/00/00/wKjljWXGIWKATkMkAAVtZBzi-RU560.png
http://192.168.229.141/group1/M00/00/00/wKjljWXGIWKATkMkAAVtZBzi-RU560_big.png
endl
相关文章:

FastDFS安装并整合Openresty
FastDFS安装并整合Openresty 一、安装环境准备【CentOS7.9】二、FastDFS--tracker安装2.1.下载fastdfs2.2.FastDFS安装环境2.3.安装FastDFS依赖libevent库2.4.安装libfastcommon2.5.安装 libserverframe 网络框架2.6.tracker编译安装2.7.安装之后文件目录介绍2.8.错误处理2.9.配…...

93 log4j-slf4j-impl 搭配上 log4j-to-slf4j 导致的 StackOverflow
前言 呵呵 最近想要 做一个 mongo 低版本的客户端读取高版本的服务端传递过来的数据造成的一个错误的时候, 出现了这样的问题 引入了 mongo-java-driver 之后, 使用相关 api 的时候会触发 com.mongo.internal.connection.BaseCluser 的初始化, 其依赖的 Loggers 间接的依赖…...

客户端会话技术-Cookie
一、会话技术 1.1 概述 会话:一次会话中包含多次**请求和响应** 一次会话:浏览器第一次给服务器资源发送请求,此时会话建立,直到有一方断开为止 会话的功能:在一次会话的范围内的多次请求间,共享数据 …...
rsa加密登录解决方案
1.问题 账密登录方式中用户输入密码后,把账号、密码通过http传输到后端进行校验,然而密码属于敏感信息,不能以明文传输,否则容易被拦截窃取,因此需要考虑如何安全传输密码 2.解决方案 使用rsa加密方式,r…...
速盾:海外服务器用了cdn还是卡怎么办
海外服务器使用CDN卡顿问题的解决办法 在如今互联网高速发展的时代,海外服务器成为了许多企业和个人用户的首选,因为它能够提供更高的带宽和更稳定的网络连接。然而,尽管海外服务器在网络性能方面表现出色,但在使用过程中仍然可能…...
[python-opencv] PNG 裁切物体
拿到一组图PNG的图,边缘有点太宽了,需要裁切一下,为了这个需求,简单复习一下基本语法。 1. 读取PNG的4个通道 image cv.imread(image_path, cv.IMREAD_UNCHANGED) 附参数说明: IMREAD_UNCHANGED -1 返…...

机器学习——有监督学习和无监督学习
有监督学习 简单来说,就是人教会计算机学会做一件事。 给算法一个数据集,其中数据集中包含了正确答案,根据这个数据集,可以对额外的数据希望得到一个正确判断(详见下面的例子) 回归问题 例如现在有一个…...
MySQL单主模式部署组复制集群
前言 本篇文章介绍MySQL8.0.27版本的组复制详细搭建过程,教你如何快速搭建一个三节点的单主模式组复制集群。 实际上,MySQL组复制是MySQL的一个插件 group_replication.so,组中的每个成员都需要配置并安装该插件,配置和安装过程…...

【大厂AI课学习笔记】【1.5 AI技术领域】(10)对话系统
对话系统,Dialogue System,也称为会话代理。是一种模拟人类与人交谈的计算机系统,旨在可以与人类形成连贯通顺的对话,通信方式主要有语音/文本/图片,当然也可以手势/触觉等其他方式 一般我们将对话系统,分…...

【ARM 嵌入式 编译系列 2.7 -- GCC 编译优化参数详细介绍】
请阅读【嵌入式开发学习必备专栏 】 文章目录 GCC 编译优化概述常用优化等级-O1 打开的优化选项-O2 打开的优化选项-O3 打开的优化选项-Os 打开的优化选项优化技术使用优化选项的注意事项GCC 编译优化概述 GCC(GNU Compiler Collection)包含了用于C、C++、Objective-C、Fort…...

《剑指 Offer》专项突破版 - 面试题 38、39 和 40 : 通过三道面试题详解单调栈(C++ 实现)
目录 面试题 38 : 每日温度 面试题 39 : 直方图最大矩形面积 方法一、暴力求解 方法二、递归求解 方法三、单调栈法 面试题 40 : 矩阵中的最大矩形 面试题 38 : 每日温度 题目: 输入一个数组,它的每个数字是某天的温度。请计算每天需要等几天才会…...
动态规划C语言
#include <stdio.h> #include <stdlib.h> //0-1背包问题是一种经典的组合优化问题, //问题描述为:有一个给定容量的背包和一组具有不同价值和重量的物品,如何选择物品放入背包中,以使得背包中物品的总价值最大化&…...

基于微信小程序的校园二手交易平台
博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...

K8S系列文章之 [使用 Alpine 搭建 k3s]
官方文档:K3s - 轻量级 Kubernetes | K3s 官方描述,可运行在 systemd 或者 openrc 环境上,那就往精简方向走,使用 alpine 做系统。与 RHEL、Debian 的区别,主要在防火墙侧;其他基础配置需求类似࿰…...

计算机视觉 | OpenCV 实现手势虚拟控制亮度和音量
Hi,大家好,我是半亩花海。在当今科技飞速发展的时代,我们身边充斥着各种智能设备,然而,如何更便捷地与这些设备进行交互却是一个不断被探索的课题。本文将主要介绍一个基于 OpenCV 的手势识别项目,通过手势…...

python28-Python的运算符之三目运算符
Python可通过if语句来实现三目运算符的功能,因此可以近似地把这种if语句当成三目运算符。作为三目运算符的f语句的语法格式如下 True_statements if expression else False_statements 三目运算符的规则是:先对逻辑表达式expression求值,如果逻辑表达式…...

高德 API 10009
问题 笔者使用高德地图所提供的API接口,访问接口报错 {"info":"USERKEY_PLAT_NOMATCH","infocode":"10009","status":"0","sec_code_debug":"d41d8cd98f00b204e9800998ecf8427e"…...

Go 语言中如何大小端字节序?int 转 byte 是如何进行的?
嗨,大家好!我是波罗学。 本文是系列文章 Go 技巧第十五篇,系列文章查看:Go 语言技巧。 我们先看这样一个问题:“Go 语言中,将 byte 转换为 int 时是否涉及字节序(endianness)&#x…...

论文阅读——MP-Former
MP-Former: Mask-Piloted Transformer for Image Segmentation https://arxiv.org/abs/2303.07336 mask2former问题是:相邻层得到的掩码不连续,差别很大 denoising training非常有效地稳定训练时期之间的二分匹配。去噪训练的关键思想是将带噪声的GT坐标…...

JPEG图像的压缩标准(1)
分3个博客详细介绍JPEG图像的压缩标准,包含压缩和解压缩流程,熵编码过程和文件存储格式。 一、JPEG压缩标准概述 JPEG压缩标准由国际标准化组织 (International Organization for Standardization, ISO) 制订,用于静态图像压缩。JPEG标准包…...
论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)
HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!
5月28日,中天合创屋面分布式光伏发电项目顺利并网发电,该项目位于内蒙古自治区鄂尔多斯市乌审旗,项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站,总装机容量为9.96MWp。 项目投运后,每年可节约标煤3670…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...

sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!
简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求,并检查收到的响应。它以以下模式之一…...

网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...

如何更改默认 Crontab 编辑器 ?
在 Linux 领域中,crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用,用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益,允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...

Golang——6、指针和结构体
指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...
深入理解Optional:处理空指针异常
1. 使用Optional处理可能为空的集合 在Java开发中,集合判空是一个常见但容易出错的场景。传统方式虽然可行,但存在一些潜在问题: // 传统判空方式 if (!CollectionUtils.isEmpty(userInfoList)) {for (UserInfo userInfo : userInfoList) {…...

使用SSE解决获取状态不一致问题
使用SSE解决获取状态不一致问题 1. 问题描述2. SSE介绍2.1 SSE 的工作原理2.2 SSE 的事件格式规范2.3 SSE与其他技术对比2.4 SSE 的优缺点 3. 实战代码 1. 问题描述 目前做的一个功能是上传多个文件,这个上传文件是整体功能的一部分,文件在上传的过程中…...