linux上搭建FastDFS图片服务器

先准备好FastDFS相关的包
在这里插入图片描述
检查linux是否联网,通过ping一个web网址实现。
如果没有联网,先ifconfig查看下此时的ip
使用命令:ifconfig ens33 192.168.1.64 netmask 255.255.255.0 #将ens33的IP改为192.168.1.64。

检查一下你的主机网卡数量及名称,相关信息在 /etc/sysconfig/network-scripts/ 下。
使用vim编辑你需要设置IP的网卡,这里我修改ifcfg-eth0。
修改配置: `
在这里插入图片描述
重启网卡:service network restart #centos6的重启网卡的命令,systemctl restart network #centos7的网卡重启。
再次ping一个网址检验网络。

开始安装
检查系统是否有安装GCC
gcc –version
安装GCC
yum -y install gcc gcc-c++ autoconf pcre pcre-devel make automake
yum -y install wget httpd-tools vim

安装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

安装FastDFS
解压FastDFS_v5.05.tar.gz,然后编译安装FastDFS
tar -zxvf FastDFS_v5.05.tar.gz
./make.sh
./make.sh install
安装成功后将目录conf内的文件拷贝到/etc/fdfs目录下:
cp /data/fastDFS/software/FastDFS/conf/* /etc/fdfs/

安装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,并查看是启动成功(出现如下提示,表示启动成功):restart重启
fdfs_trackerd /etc/fdfs/tracker.conf start
netstat -unltp | grep tracker
在这里插入图片描述
安装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 (连接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,表示二者均正常启动,至此就可以进行上传文件测试了。
在这里插入图片描述
测试图片上传
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端口)
测试命令
/usr/bin/fdfs_test /etc/fdfs/client.conf upload anti-steal.jpg
在这里插入图片描述

安装Nginx。方便外部网络的访问。
#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.12.1.tar.gz
cd nginx-1.12.1
./configure
make
make install
修改/fastdfs-nginx-module/src/config文件。去掉所有的local(三个)
拷贝usr/lib64目录下库文件libfdfsclient.so
cp /usr/lib64/libfdfsclient.so /usr/lib
在nginx安装目录下执行如下命令:把module添加nginx中。通过设置安装参数方式添加模块。
cd nginx-1.12.1
./configure --add-module=…/fastdfs-nginx-module/src
重新安装编译
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
# 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

配置iNginx ,进入/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;
}
注意:
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.local
/usr/local/nginx/sbin/nginx
#设置执行权限
chmod 755 rc.local

查看Nginx是否启动
ps -ef | grep nginx

OK记得云服务的安全组 和防火墙设置需要方通 80、22122、 23000
打开3306端口:firewall-cmd --add-port=3306/tcp --permanent firewall:
systemctl start firewalld.service#启动firewall
systemctl stop firewalld.service#停止firewall
systemctl disable firewalld.service#禁止firewall开机启动

在地址栏中访问成功 http://192.175.231.128/group1/M00/00/00/rBAACVzBeU2AQBKJAAOHDqS1H9o350.jpg

java代码里面使用
pom文件:

<dependencies>
  	<dependency>
  		<groupId>org.csource.fastdfs</groupId>
  		<artifactId>fastdfs</artifactId>
  		<version>1.2</version>
  	</dependency>
  </dependencies>

配置文件:fdfs_client.conf。主要修改里面的tracker_server。

# connect timeout in seconds
# default value is 30s
connect_timeout=30

# network timeout in seconds
# default value is 30s
network_timeout=60

# the base path to store log files
base_path=/home/fastdfs

# tracker_server can ocur more than once, and tracker_server format is
#  "host:port", host can be hostname or ip address
tracker_server=192.168.254.133:22122

#standard log level as syslog, case insensitive, value list:
### emerg for emergency
### alert
### crit for critical
### error
### warn for warning
### notice
### info
### debug
log_level=info

# if use connection pool
# default value is false
# since V4.05
use_connection_pool = false

# connections whose the idle time exceeds this time will be closed
# unit: second
# default value is 3600
# since V4.05
connection_pool_max_idle_time = 3600

# if load FastDFS parameters from tracker server
# since V4.05
# default value is false
load_fdfs_parameters_from_tracker=false

# if use storage ID instead of IP address
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# default value is false
# since V4.05
use_storage_id = false

# specify storage ids filename, can use relative or absolute path
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# since V4.05
storage_ids_filename = storage_ids.conf


#HTTP settings
http.tracker_server_port=80

#use "#include" directive to include HTTP other settiongs
##include http.conf


测试文件:

public static void main(String[] args) throws FileNotFoundException, IOException, Exception {
		//加载配置文件
		ClientGlobal.init("G:\\666\\shenbin\\fastDFSdemo\\src\\main\\resources\\fdfs_client.conf");
		//构建一个管理者客户端
		TrackerClient client=new TrackerClient();
		//链接管理者服务端
		TrackerServer trackerServer = client.getConnection();
		//声明存储的服务端
		StorageServer strStorageServer=null;
		//获取存储服务器的客户端对象
		StorageClient storageClient = new StorageClient(trackerServer, strStorageServer);
		//文件上传
		String[] strings = storageClient.upload_file("G:\\666\\system.ico", "ico", null);
		//显示上传的结果file_id
		for(String str:strings) {
			System.out.println(str);
		}
	}

版权声明:本文为weixin_42808295原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。