linux CentOs7 安装 FastDFS

CentOs7 安装 FastDFS

1. 安装依赖

yum install gcc libevent libevent-devel -y#进入src目录
cd /usr/local/src

2. 安装 libfastcommon 库

libfastcommon 库是 FastDFS 文件系统运行需要的公共 C 语言函数库

# 下载
wget https://github.com/happyfish100/libfastcommon/archive/refs/tags/V1.0.48.tar.gz# 解压
tar -zxvf V1.0.48.tar.gz# 进入目录
cd libfastcommon-1.0.48/#执行make脚本进行编译
./make.sh# 执行make install进行安装
./make.sh install

3.安装 FastDFS

#回到src目录下
cd /usr/local/src#下载
wget https://github.com/happyfish100/fastdfs/archive/refs/tags/V6.07.tar.gz# 解压
tar -zxvf V6.07.tar.gz# 进入解压后目录,编译下载
cd fastdfs-6.07/
./make.sh
./make.sh install

4. 调整目录位置

# 进入fastdfs-6.07 conf目录下
cd /usr/local/src/fastdfs-6.07/conf# 复制文件到 /etc/fdfs
cp http.conf /etc/fdfs/
cp mime.types /etc/fdfs/#进入 /etc/fdfs 修改配置文件
cd /etc/fdfs/# 修改tracker.conf文件
cp tracker.conf.sample tracker.conf
vim tracker.conf
#修改内容
base_path=/opt/fastdfs/tracker               #配置tracker存储数据的目录#修改storage.conf文件
cp storage.conf.sample storage.conf
vim storage.conf
#修改内容
base_path= /opt/fastdfs/storage                      #storage存储数据目录
store_path0= /opt/fastdfs/storage/files          #真正存放文件的目录
# 设置为自己虚拟机ip,配置文件中有两个,注释掉一个即可
tracker_server=192.168.xx.xx:22122        #注册当前存储节点的跟踪器地址
#配置文件最下方,该端口需要与之后,配置的nginx一致,storage默认为8888
# 这里改为,同nginx默认一样为80 ,当然也可以把nginx的端口改为8888
http.server_port = 80#创建上面指定的目录
mkdir -p /opt/fastdfs/tracker
mkdir -p /opt/fastdfs/storage
mkdir -p /opt/fastdfs/storage/files

5. 启动FastDFS(还没完)

#FastDFS服务启动需要启动两个脚本:
#启动FastDFS的tracker服务
#在任意目录下执行:
fdfs_trackerd /etc/fdfs/tracker.conf#启动FastDFS的storage服务
#在任意目录下执行:
fdfs_storaged /etc/fdfs/storage.conf

查看启动进程

ps -ef | grep fdfs

查看storage是否已经注册到了tracker下

fdfs_monitor /etc/fdfs/storage.conf

首次启动storage后,会在配置的路径下创建存储文件的目录

6.重启与关闭

重启tracker
fdfs_trackerd /etc/fdfs/tracker.conf restart重启storage
fdfs_storaged /etc/fdfs/storage.conf restartFastDFS关闭
关闭tracker执行命令
在任意目录下执行:fdfs_trackerd /etc/fdfs/tracker.conf stop关闭storage执行命令
在任意目录下执行:fdfs_storaged /etc/fdfs/storage.conf stop或者kill关闭fastdfs,但不建议在线上使用 kill -9 强制关闭,因为可能会导致文件信息不同步问题

7. FastDFS测试

测试之前,需要修改client.conf配置文件,修改两个配置

# 进入/etc/fdfs 目录下
cd /etc/fdfs#修改配置文件
cp client.conf.sample client.conf
vim client.conf#修改内容
base_path=/opt/fastdfs/client
#与storage.conf 一样注释掉一个
tracker_server=192.168.xx.xx:22122#在/opt/fastdfs/目录下创建client
mkdir -p /opt/fastdfs/client#测试文件上传
fdfs_test /etc/fdfs/client.conf upload    /root/aa.txt
#测试文件删除
fdfs_delete_file /etc/fdfs/client.conf group1/要删除的文件路径

8. 下载fastdfs-nginx

#跳转目录
cd /usr/local/src#下载
wget https://github.com/happyfish100/fastdfs-nginx-module/archive/refs/tags/V1.22.tar.gz#解压tar -zxvf V1.22.tar.gz#装依赖
yum install gcc openssl openssl-devel pcre pcre-devel zlib zlib-devel –y#跳转到nginx目录下(根据自己目录而定)
#nginx下载 详见 linux下载nginx.md
cd /usr/local/nginx/nginx-1.21.6/#添加模块(注意路径)
./configure --prefix=/usr/local/nginx --with-http_ssl_module  --add-module=/usr/local/src/fastdfs-nginx-module-1.22/src#编译
make & make install#复制  出现overwrite 输入y重新即可
cp ./objs/nginx /usr/local/nginx/sbin/#查看安装情况
/usr/local/nginx/sbin/nginx -V#将/home/soft/fastdfs-nginx-module-master/src(自己实际存放Nginx扩展模块的目录)目录下的mod_fastdfs.conf文件拷贝到 /etc/fdfs/目录下,这样才能正常启动Nginx
#出现overwrite 输入y重写即可
cp /usr/local/src/fastdfs-nginx-module-1.22/src/mod_fastdfs.conf /etc/fdfs/#切换目录,修改配置文件
cd  /etc/fdfs/
#修改mod_fastdfs.conf配置文件
vim mod_fastdfs.conf#修改内容
base_path=/opt/fastdfs/nginx_mod
tracker_server=192.168.xx.xx:22122
url_have_group_name = true
store_path0=/opt/fastdfs/storage/files#在/opt/fastdfs/目录下创建nginx_mod目录
mkdir -p /opt/fastdfs/nginx_mod#修改Nginx.config:
vim /usr/local/nginx/conf/nginx.conf#修改内容
location ~ /group[1-9]/M0[0-9] {   ngx_fastdfs_module; 
}

9. 启动nginx

#指定配置文件
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf重启或启动FastDFS服务进程 详见 6.重启与关闭
记得放开端口开放端口:23000,80,8080(没有用到的话,可以不放),22122(linux常见指令中有相关操作)

10. 原文nginx配置

#user  nobody;
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;#pid        logs/nginx.pid;events {worker_connections  1024;
}http {include       mime.types;default_type  application/octet-stream;#log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '#                  '$status $body_bytes_sent "$http_referer" '#                  '"$http_user_agent" "$http_x_forwarded_for"';#access_log  logs/access.log  main;#上传大小限制client_max_body_size 5000m;#下载大小限制proxy_max_temp_file_size 5000m;#设置为on表示启动高效传输文件的模式sendfile        on;#tcp_nopush     on;#keepalive_timeout  0;keepalive_timeout  65;#gzip  on;server {listen       80;server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;location / {root   /data/build/;add_header Cache-Control no-store;add_header Cache-Control no-cache;try_files $uri $uri/ /index.html;index  index.html index.htm;}location ^~ /static/ {alias   /data/build/static/;}location ~ /group[1-9]/M0[0-9] {    ngx_fastdfs_module;  }#error_page  404              /404.html;# redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}# proxy the PHP scripts to Apache listening on 127.0.0.1:80##location ~ \.php$ {#    proxy_pass   http://127.0.0.1;#}# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000##location ~ \.php$ {#    root           html;#    fastcgi_pass   127.0.0.1:9000;#    fastcgi_index  index.php;#    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;#    include        fastcgi_params;#}# deny access to .htaccess files, if Apache's document root# concurs with nginx's one##location ~ /\.ht {#    deny  all;#}}# another virtual host using mix of IP-, name-, and port-based configuration##server {#    listen       8000;#    listen       somename:8080;#    server_name  somename  alias  another.alias;#    location / {#        root   html;#        index  index.html index.htm;#    }#}# HTTPS server##server {#    listen       443 ssl;#    server_name  localhost;#    ssl_certificate      cert.pem;#    ssl_certificate_key  cert.key;#    ssl_session_cache    shared:SSL:1m;#    ssl_session_timeout  5m;#    ssl_ciphers  HIGH:!aNULL:!MD5;#    ssl_prefer_server_ciphers  on;#    location / {#        root   html;#        index  index.html index.htm;#    }#}}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用梧桐数据库进行销售趋势分析和预测

在当今竞争激烈的商业环境中,企业需要深入了解销售数据,以便做出明智的决策。销售趋势分析和预测是帮助企业把握市场动态、优化库存管理、制定营销策略的重要工具。本文将介绍如何使用SQL来创建销售数据库的表结构,插入示例数据,并…

6.2024.10.22

2024.10.22 2024.10.22 2024.10.22 今天没怎么学习嵌入式的,找时间补上今天学习的空缺。

qt EventFilter用途详解

一、概述 EventFilter是QObject类的一个事件过滤器,当使用installEventFilter方法为某个对象安装事件过滤器时,该对象的eventFilter函数就会被调用。通过重写eventFilter方法,开发者可以在事件处理过程中进行拦截和处理,实现对事…

go 语言 Gin Web 框架的实现原理探究

Gin 是一个用 Go (Golang) 编写的 Web 框架,性能极优,具有快速、支持中间件、crash处理、json验证、路由组、错误管理、内存渲染、可扩展性等特点。 官网地址:https://gin-gonic.com/ 源码地址:https://github.com/gin-gonic/gi…

Shell重定向输入输出

我的后端学习大纲 我的Linux学习大纲 重定向介绍 标准输入介绍 从键盘读取用户输入的数据,然后再把数据拿到Shell程序中使用; 标准输出介绍 Shell程序产生的数据,这些数据一般都是呈现到显示器上供用户浏览查看; 默认输入输出文件 每个…

重新认识Linux下的硬链接和软链接

文章目录 前言1、软链接?1.1 工作原理1.2 特点 2、硬链接2.1 工作原理2.2 特点 3、 总结 前言 让自己永远保持一颗好奇心 今天无意间听别人提到了硬链接和软链接,起初我想这么基础的知识我肯定是知道的,毕竟大学接触Linux到现在工作了那么多…

ubuntu20.04 opencv4.0 /usr/local/lib/libgflags.a(gflags.cc.o): relocation报错解决

在一个只有ubuntu20.04的docker环境中配置opencv4.0.0, 什么库都没有,都要重新安装, 其他的问题在网上都找到了解决方案,唯独这个问题比较棘手: [ 86%] Linking CXX executable …/…/bin/opencv_annotation /usr/bin/ld: /usr/lo…

前OpenAI首席技术官为新AI初创公司筹资;我国发布首个应用临床眼科大模型 “伏羲慧眼”|AI日报

文章推荐 2024人工智能报告.zip |一文迅速了解今年的AI界都发生了什么? 今日热点 据报道,前OpenAI首席技术官Mira Murati正在为一家新的AI初创公司筹集资金 据路透社报道,上个月宣布离职的OpenAI首席技术官Mira Murati正在为一…

栈和队列(一)

栈和队列的定义和特点 栈和队列是一种特殊的线性表,只能在表的端点进行操作 栈的定义和特点 这就是栈的结构,是一个特殊的线性表,只能在栈顶(或者说是表尾)进行操作。其中top为栈顶,base为栈底 栈s的存储…

C语言结构体数组 java静动数组及问题

1. (1)先声明,后定义:如上一天 //(2).声明时直接定义 #define N 5 typedef struct student { int num; int score; }STU; int main(void) { STU class3[N] { {10,90},{14,70},{8,95} }; …

全面解析:集成AWS、云原生和监控的开源运维管理平台

在当今复杂的IT环境中,寻找一个能够同时支持AWS、云原生技术(如Kubernetes)和全面监控功能的开源运维管理平台,已成为许多组织的迫切需求。本文将深入探讨几个有潜力满足这些需求的开源解决方案,分析它们的优势、局限性…

华为:高级ACL 特定ip访问特定ip命令

网络拓扑图: 网络环境: 全网互通即可 1.创建一个名为test的高级ACL acl name test advance 2.添加规则 ##拒绝所有ip访问 rule 10 deny ip source any destination 192.168.1.10 0.0.0.0 只允许特定ip访问特定ip rule 5 permit ip source 192.168.2.10…

【Vulnhub靶场】Kioptrix Level 5

目标 本地IP:192.168.118.128 目标IP:192.168.118.0/24 信息收集 nmap探测存活主机,扫全端口,扫服务 首先探测到目标ip为:192.168.118.136 nmap -sP 192.168.118.0/24nmap -p- 192.168.118.136nmap -sV -A 192.168.…

BurpSuite渗透工具的简单使用

BurpSuite渗透工具 用Burp Suite修改请求 step1: 安装Burp Suite。官网链接:Burp Suite官网 step2: 设置代理 step3: 如果要拦截https请求,还需要在客户端安装证书 step4: 拦截到请求可以在Proxy ->…

句柄是什么?有什么用?举例说明

在C#编程中,“句柄”(Handle)是一个与操作系统资源相关联的标识符。句柄是一个指针或者索引,用于在程序代码中引用系统资源,如窗口、文件、线程等。由于直接操作这些资源非常危险且复杂,操作系统提供句柄作…

虚拟机风格

虚拟机风格是一种构建系统架构的方法,旨在创建一个抽象的运行环境,以便在其上运行和解释特定的程序语言或规则集。这种架构风格增加了系统的灵活性,允许用户在一个统一的虚拟环境中执行不同的代码、应用程序或规则,避免直接依赖底…

JAVA本地编译运行出现的找不到类名问题

问题描述: JAVA本地编译运行: $ javac TestProgram.java $ java TestProgram $ 错误: 找不到或无法加载主类 TestProgram 问题排查以及解决方案: 命令行路径正确且当前目录下成功编译了TestProgram.class,java -version显示正常…

【嵌入式实时操作系统开发】智能家居入门4(FreeRTOS、MQTT服务器、MQTT协议、STM32、微信小程序)

前面已经发了智能家居入门的1、2、3了,在实际开发中一般都会使用到实时操作系统,这里就以FreeRTOS为例子,使用标准库。记录由裸机转到实时操作系统所遇到的问题以及总体流程。相较于裸机,系统实时性强了很多,小程序下发…

opencv环境配置-适配b站阿童木的opencv教程

首先,opencv作为一个库文件,目的是为了让更多人不需要学习底层像素操作就能上手视觉技术,所以他适配很多环境,目前电脑端我知道的就可以适配C语言 C Python MCU端就是openmv跟他最类似,还有个k210 canmv 阿童木教的…

Unity 山水树木

本章节内容 1. Unity对3D游戏物体的简单操作; 2. 构建山水树木的场景 1. Unity 简易操作 1.1 新建3D游戏场景 1. 打开Unity Hub,点击 New Project (新建项目)按键,选择第二项 3D(Built-In Render Pipeline)&#xf…