linux搭建FastDFS文件服务器,安装nginx
Posted liaozk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux搭建FastDFS文件服务器,安装nginx相关的知识,希望对你有一定的参考价值。
本文主要介绍在linux服务器如何搭建FastDFS文件服务器。大概分为9个步骤,由于内容较为繁琐。下面带你入坑!
首先简单介绍一下FastDFS是淘宝资深架构师余庆老师主导开源的一个分布式文件系统,用C语言编写。适应与中小企业,对文件不分块。
主要有Tracker(管理) 和Storage (储存)。
返回路径= 组名 /虚拟盘符M00/00/02 /文件名
1、软件包
wget https://github.com/happyfish100/libfastcommon/archive/V1.0.7.tar.gz
wget http://jaist.dl.sourceforge.net/project/fastdfs/FastDFS%20Nginx%20Module%20Source%20Code/fastdfs-nginx-module_v1.16.tar.gz
wget https://github.com/happyfish100/fastdfs/archive/V5.05.tar.gz
wget http://nginx.org/download/nginx-1.18.0.tar.gz
2、安装gcc
yum -y install gcc gcc-c++ autoconf pcre pcre-devel make automake
yum -y install wget httpd-tools vim
3、安装 libfastcommon
#进入libfastcommon压缩包目录解压,编译,安装 tar -zxvf libfastcommonV1.0.7.tar.gz #进入解压的libfastcommon-1.0.7目录,编译 ./make.sh ./make.sh install #最后,将libfastcommon.so文件复制到usr/lib下 (标红位置,请按照自己的实际文件路径修改) cp /data/fastDFS/software/libfastcommon-1.0.7/src/libfastcommon.so /usr/lib
4、安装 FastDFS
解压FastDFS_v5.05.tar.gz, tar -zxvf FastDFS_v5.05.tar.gz 编译FastDFS ./make.sh 安装FastDFS ./make.sh install 安装成功后将目录conf内的文件拷贝到/etc/fdfs目录下(标红位置请按照实际文件路径修改): cp /data/fastDFS/software/FastDFS/conf/* /etc/fdfs/
5、安装 tracker
进入/etc/fdfs目录,修改tracker.conf文件。如果不存在,就拷贝tracker.conf.sample文件为tracker.conf,然后再修改: base_path=/home/yuqing/fastdfs 修改成 base_path=/home/logs/fastdfs (注解:日志文件) http.server_port=8080 修改成 http.server_port=80 (注解:端口,80是方便默认) store_group=group1 (注解:组名) 其中,/home/logs/fastdfs目录如果不存在,就创建一个。 之后,就启动tracker, fdfs_trackerd /etc/fdfs/tracker.conf start 查看是启动成功(出现如下提示,表示启动成功):restart重启 netstat -unltp | grep tracker
6、安装storage
由于storage和tracker运行的都是fastDFS程序,每一台服务器都部署一台fasfDFS,一台服务器是tracker,一台是storage
修改storage.conf文件。如果不存在,就拷贝storage.conf.sample文件为storage.conf,然后再修改: base_path=/home/yuqing/fastdfs 修改成 base_path=/home/logs/storage (日志路径) store_path0=/home/yuqing/fastdfs 修改成 store_path0=/home/data/storage (实际储存文件路径,可以配置多个) tracker_server=192.168.209.121:22122 修改成 tracker_server=192.168.2.231:22122 (ip为服务器ip地址,如果不确认,用ifconfig查询,连接tracker服务器地址) group_name=group1 (必须和tracker的组名相同) http.server_port=80 (这个端口也要改) 其中,如果/home/logs/storage和/home/data/storage不存在,就创建该目录 然后,就启动storage fdfs_storaged /etc/fdfs/storage.conf start 查看是否成功(出现如下提示,表示启动成功) netstat -unltp | grep storage
最后,查看tracker和storage是不是在通信: fdfs_monitor /etc/fdfs/storage.conf 如下提示,出现ACTIVE,表示二者均正常启动,至此就可以进行上传文件测试了。
7、测试图片上传
Tracker和storage都已经安装完成,使用命令测试文件上传:
FastDFS提供一个文件上传命令:usr/bin/fdfs_test 测试文件上传。测试上传需要连接tracker服务器,连接storage服务器。因此需要指定一个配置文件:client.conf配置文件,通过Client.conf连接tracker服务器。
修改/etc/fdfs下client.conf base_path=/home/logs/client (日志目录) tracker_server=192.168.2.231:22122 (tracker端口,ip为服务器ip,ifconfig能查到) 测试命令 /usr/bin/fdfs_test /etc/fdfs/client.conf upload anti-steal.jpg 如下图返回地址则成功
8、安装Nginx
#gcc安装 yum install gcc-c++ #PCRE pcre-devel 安装 yum install -y pcre pcre-devel # zlib 安装 yum install -y zlib zlib-devel #OpenSSL 安装 yum install -y openssl openssl-devel 解压、编译、安装。 tar -zxvf nginx-1.18.0.tar.gz cd nginx-1.18.0 ./configure make make install
9、安装 fastdfs-nginx-module
首先解压fastdfs-nginx-module_v1.16.tar.gz,修改/fastdfs-nginx-module/src/config文件。去掉所有的local(三个)
拷贝usr/lib64目录下库文件libfdfsclient.so cp /usr/lib64/libfdfsclient.so /usr/lib 在nginx安装目录下执行如下命令:把module添加nginx中。通过设置安装参数方式添加模块。 cd nginx-1.18.0 ./configure --add-module=../fastdfs-nginx-module/src 注意:我这里nginx-1.18.0和fastdfs-nginx-module在同一级目录,所以这样写 重新安装编译 make && make install 查看Nginx的模块 /usr/local/nginx/sbin/nginx -V 复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录, 并修改 cd fastdfs-nginx-module/src cp mod_fastdfs.conf /etc/fdfs/ 进入/etc/fdfs/修改mod_fastdfs.conf如下配置,其他默认 # 连接超时时间 connect_timeout=10 # Tracker Server tracker_server=192.168.2.231:22122(ip地址为本地地址,用ifconfig查询) # StorageServer 默认端口 storage_server_port=23000 # 如果文件ID的uri中包含/group**,则要设置为true url_have_group_name = true # Storage 配置的store_path0路径,必须和storage.conf中的一致 store_path0=/home/data/storage # the base path to store log files base_path=/home/logs/storage 配置Nginx ,进入/usr/local/nginx/conf目录下修改nginx.conf 注意:无论你在哪解压安装的。必须进这个目录/usr/local/nginx/conf下修改nginx.conf vim nginx.conf 修改配置,其它的默认 在80端口下添加fastdfs-nginx模块 location ~/group([0-9])/M00 ngx_fastdfs_module; 注意:下面#user nobody;改成 #user root;
注意:
listen 80 端口值是要与 /etc/fdfs/storage.conf 中的 http.server_port=80 (前面改成80了)相对应。如果改成其它端口,则需要统一,同时在防火墙中打开该端口
location 的配置,如果有多个group则配置location ~/group([0-9])/M00 ,没有则不用配group。
在文件存储目录下创建软连接,将其链接到实际存放数据的目录,注意这个文件存储的位置后面多个data目录是系统自动生成的
ln -s /home/data/storage/data /home/data/storage/data/M00
启动nginx
#启动nginx cd /usr/local/nginx/sbin/ ./nginx 直接启动 /usr/local/nginx/sbin/nginx 设置开机自启 vim /etc/rc.d/rc.local 加入:/usr/local/nginx/sbin/nginx 使/etc/rc.d/rc.local变成可执行文件 chmod +x /etc/rc.d/rc.local
以上是关于linux搭建FastDFS文件服务器,安装nginx的主要内容,如果未能解决你的问题,请参考以下文章
Linux 7.X 分布式文件存储服务FastDFS搭建部署