Centos安装FastDFS+Nginx

 

一、安装环境:

 gcc:安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:

yum install gcc-c++

PCRE:PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

yum install -y pcre pcre-devel

注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。

zlib:zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

yum install -y zlib zlib-devel

openssl:OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

yum install -y openssl openssl-devel

二、下载,安装文件信息

软件包

软件版本

下载链接

FastDFS

v5.05

https://pan.baidu.com/s/1eTGCi34

Fastdfs-nginx-module

v1.16

https://pan.baidu.com/s/1c3HwkgS

Libevent

v2.0.21

https://pan.baidu.com/s/1gheWCnT

libfastcommon

 V1.0.7

https://pan.baidu.com/s/1gheWCoV

nginx

v1.8.0

https://pan.baidu.com/s/1c3IIfzq

三、安装
3.1先安装libfastcommonV1.0.7.tar.gz
解压安装命令:

tar -zxvf libfastcommonV1.0.7.tar.gz
./make.sh
./make.sh install

注意:libfastcommon安装好后会自动将库文件拷贝至/usr/lib64下,由于FastDFS程序引用usr/lib目录所以需要将/usr/lib64下的库文件拷贝至/usr/lib下。

3.2安装 libevent-2.0.21-stable.tar.gz

①先用:ls -al /usr/lib | grep libevent 查看是否已安装,如果已安装且版本低于1.3,则先通过:rpm -e libevent —nodeps 进行卸载。

②下载libevent安装包:libevent-2.0.21-stable.tar.gz,然后解压

tar -zxvf libevent-2.0.21-stable.tar.gz

③切换到解压后的 libevent 主目录:

cd libevent-1.4.13-stable

④依次执行:

./configure –prefix=/usr (或 ./configure --program-prefix=/usr)
make
make install

3.3 tracker编译安装

安装FastDFS_v5.05.tar.gz

解压安装命令:

 将FastDFS_v5.05.tar.gz拷贝至/usr/local/下

tar -zxvf FastDFS_v5.05.tar.gz

cd FastDFS

./make.sh
./make.sh install

安装成功将安装目录下的conf下的文件拷贝到/etc/fdfs/下。

tracker配置:

安装成功后进入/etc/fdfs目录:

拷贝一份新的tracker配置文件:

cp tracker.conf.sample tracker.conf

修改tracker.conf

vi tracker.conf

base_path=/home/yuqing/FastDFS  

改为:

base_path=/home/FastDFS

启动tracker:

/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart(好奇怪为什么没有start)

启动的日志显示先停止5619进程(实际环境不是5619)再启动,如下图:

注意:如果没有显示上图要注意是否正常停止原有进程。

l  设置开机自动启动。

将运行命令行添加进文件:/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

FastDFS--storage安装及配置

storage在tracker安装时已经安装,在这里只需要配置storage.conf文件,即可启动

安装成功后进入/etc/fdfs目录:

拷贝一份新的storage配置文件:

cp storage.conf.sample storage.conf

修改storage.conf

vi storage.conf

group_name=group1

base_path=/home/yuqing/FastDFS改为:base_path=/home/FastDFS

store_path0=/home/yuqing/FastDFS改为:store_path0=/home/FastDFS/fdfs_storage

#如果有多个挂载磁盘则定义多个store_path,如下

#store_path1=.....

#store_path2=......
tracker_server=172.16.2.15:22122   #配置tracker服务器:IP

#如果有多个则配置多个tracker

tracker_server=172.16.2.14:22122

启动storage:

/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

启动的日志显示先停止8931进程(实际环境不是8931)再启动,如下图:

注意:如果没有显示上图要注意是否正常停止原有进程。

l  设置开机自动启动。

将运行命令行添加进文件:/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

上传图片测试:

@Test
    public void testUpload() throws Exception {
        //创建一个配置文件。文件名任意。内容就是tracker服务器的地址。
        //使用全局对象加载配置文件。
        ClientGlobal.init("D:/java/mall_working/mowe-manager-web/src/main/resources/conf/client.conf");
        //创建一个TrackerClient对象
        TrackerClient trackerClient = new TrackerClient();
        //通过TrackClient获得一个TrackerServer对象
        TrackerServer trackerServer = trackerClient.getConnection();
        //创建一个StrorageServer的引用,可以是null
        StorageServer storageServer = null;
        //创建一个StorageClient,参数需要TrackerServer和StrorageServer
        StorageClient storageClient = new StorageClient(trackerServer, storageServer);
        //使用StorageClient上传文件。
        String[] strings = storageClient.upload_file("D:/java/Java_Tools/FastDFS/sjz.jpg", "jpg", null);
        for (String string : strings) {
            System.out.println(string);
        }
        
    }

FastDFS 和nginx整合:

在tracker上安装nginx

nginx的安装细节参考nginx文档。

在每个tracker上安装nginx,的主要目的是做负载均衡及实现高可用。如果只有一台tracker服务器可以不配置nginx。

在Storage上安装nginx:

解压:fastdfs-nginx-module_v1.16.tar.gz

tar -zxvf fastdfs-nginx-module_v1.16.tar.gz

cd FastDFS-nginx-module/src

修改config文件将/usr/local/路径改为/usr/

将FastDFS-nginx-module/src下的mod_FastDFS.conf拷贝至/etc/fdfs/下

cp mod_FastDFS.conf /etc/fdfs/

并修改mod_FastDFS.conf的内容:

vi /etc/fdfs/mod_FastDFS.conf
#base_path
=/home/FastDFS tracker_server=172.16.2.15:22122 #tracker_server=172.16.2.14:22122(多个tracker配置多行) url_have_group_name=true #url中包含group名称 store_path0=/home/FastDFS/fdfs_storage #指定文件存储路径

将libfdfsclient.so拷贝至/usr/lib下

cp /usr/lib64/libfdfsclient.so /usr/lib/
mkdir -p /var/temp/nginx/client

下面分为两种情况
第一种:没有安装nginx,需要重新安装这个过程的

第二种,已经安装好nginx,现在是添加模块的。

针对第一种情况:
进入nginx的源码目录(nginx自行下载)

./configure --prefix=... --add-module=/home/bing/fastdfs-nginx-module/src/
make 
make install

这里安装就不写nginx的其他模块了,比如
--prefix=path :定义一个目录,存放服务器上的文件 ,也就是nginx的安装目录。默认使用 /usr/local/nginx。
--sbin-path=path :设置nginx的可执行文件的路径,默认为  prefix/sbin/nginx.
--conf-path=path :设置在nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动,通过命令行中的-c选项。默认为prefix/conf/nginx.conf.
--pid-path=path :设置nginx.pid文件,将存储的主进程的进程号。安装完成后,可以随时改变的文件名 , 在nginx.conf配置文件中使用 PID指令。默认情况下,文件名 为prefix/logs/nginx.pid.
--error-log-path=path :设置主错误,警告,和诊断文件的名称。安装完成后,可以随时改变的文件名 ,在nginx.conf配置文件中 使用 的error_log指令。默认情况下,文件名 为prefix/logs/error.log.

在这里就直接写--add-module,这里指向的就是fastdfs-nginx-module的源码路径,一定要进入到src目录下,然后执行make ,再执行make install

 make:主要是用来编译的,它从Makefile中读取指令,然后编译生成一个可执行文件在nginx源码目录下的objs,这个可执行文件时nginx

make install:主要是实现安装,它也从Makefile中读取指令,安装到指定的位置。

针对第二种情况:

下面继续说一下如果安装完成nginx,现在在安装一个模块的问题,该如何解决,很多时候,我们是不能说,再重新安装nginx的,所以必须想一个办法实现动态安装module。

首先查看nginx已经安装了哪些模块

# nginx -V
nginx version: nginx/1.10.0
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-17) (GCC) 
built with OpenSSL 1.0.1e-fips 11 Feb 2013
TLS SNI support enabled
configure arguments: --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-http_gzip_static_module --with-ipv6 --with-http_sub_module

可以看到列出了一些nginx的信息,包括已经安装的一些模块。

那么我们可以重新编译这些模块,同时在通过--add-module添加模块

例如上面的,重新进入nginx的源码目录

./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-http_gzip_static_module --with-ipv6 --with-http_sub_module--add-module=/home/bing/fastdfs-nginx-module/src/

make 

可以看到红色部分,重新添加一个--add-module,指定需要添加的模块的源码目录路径,然后执行make,特别注意,这里不需要执行make install

编译之后,将会在objs的目录下重新生成一个nginx的可执行文件,可以复制,然后用来覆盖原来安装nginx时生成的nginx文件,这个文件默认在/usr/local/nginx/sbin/下,为了安全起见,向备份原来的文件

cd /usr/local/nginx/sbin

cp nginx nginx.back
cp ..../objs/nginx /usr/local/nginx/sbin

然后重新启动nginx


那么查看是否安装成功这个模块

/usr/local/nginx/sbin/nginx -V

在这里要注意,我们也可以复制nginx 到/usr/local/sbin下面,这个样子就可以直接nginx -V,不需要输入完整路径。


安装完成这个fastdfs-nginx-module后,接下来,将是如何配置这个模块
在fastdfs的源码安装包下面的conf下面,我们需要复制两个文件至/etc/fdfs/下

cp http.conf mime.types /etc/fdfs/

 

同时把fastdfs-nginx-modul源码包的src目录下的mod_fastdfs.conf复制至/etc/fdfs/


那么可以看到/etc/fdfs下有的文件

 

然后配置mod_fastdfs.conf这个文件,主要以下几个

# the base path to store log files
base_path=/tmp

tracker_server=172.16.2.15:22122

#include http.conf

group_name=group1
url_have_group_name = true 
store_path0=/home/FastDFS

# group settings for group #1
# since v1.14
# when support multi-group on this storage server, uncomment following section
[group1]
group_name=group1
storage_server_port=23000
store_path_count=1
store_path0=/home/FastDFS
# group settings for group #2
# since v1.14
# when support multi-group, uncomment following section as neccessary
#[group2]
#group_name=group2
#storage_server_port=23000
#store_path_count=1
#store_path0=/home/FastDFS

如果这里有多个group,测配置多个group,这里只有一个group,所以只配置group1
配置完成这个之后,我们将在nginx的配置文件中配置一下

 #检查语法

/usr/local/nginx/sbin/nginx -t

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

从这里可以看出,默认使用的是/usr/local/nginx/conf/nginx.conf这个配置文件

修改这个配置文件:

 server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        #location / {
         #   root   html;
         #   index  index.html index.htm;
        #}
        location /group1/M00/ {
            root   /home/FastDFS/data;
            ngx_fastdfs_module;
        }

#启动-指定配置文件

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

/usr/local/nginx/sbin/nginx -s reload

如Nginx不能正常启动,则需要执行以下命令让插件重启:

配置防火墙,重新启动,重新上传
iptables -I INPUT -p tcp -m state --state NEW -m tcp --dport 23000 -j ACCEPT
/etc/init.d/iptables save


/usr/local/nginx/sbin/nginx


/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
/usr/bin/fdfs_test /etc/fdfs/client.conf upload /etc/fdfs/client.conf

重启tracker、storage
重启Nginx
搞定啦

访问http://172.16.2.16/group1/M00/00/00/rBACEFpXEuGARm1tAADq5W3h4Nc650.jpg

 

posted @ 2018-01-11 21:40  墨飞_Max  阅读(757)  评论(0编辑  收藏  举报