zoukankan      html  css  js  c++  java
  • Centos7 上安装 FastDFS

     

    1、安装gcc(编译时需要)

    FastDFS是C语言开发,安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc

    yum install -y gcc gcc-c++

    2、安装libevent(运行时需求)

    若安装了桌面图形界面,就不需要安装;FastDFS依赖libevent库;

    yum -y install libevent

    3、 安装libfastcommon

     libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。

    (1)上传 libfastcommonV1.0.7.tar.gz到Centos机器上;

    (2)将 libfastcommonV1.0.7.tar.gz解压至/usr/local/下:

    tar -zxvf libfastcommonV1.0.7.tar.gz -C /usr/local/

    (3)切换目录到:/usr/local/libfastcommon-1.0.7/ 下,接着进行编译和安装;

    cd /usr/local/libfastcommon-1.0.7/
    ./make.sh           #编译
    ./make.sh install   #安装

    安装后的截图:

     

    (4)libfastcommon安装好后会在/usr/lib64 目录下生成 libfastcommon.so 库文件;

      

      注意:由于FastDFS程序引用usr/lib目录所以需要将/usr/lib64下的库文件拷贝至/usr/lib下。

    cp libfastcommon.so /usr/lib

     

    4、安装tracker

    (1)上传 FastDFS_v5.05.tar.gz 到 centos 上;

    (2)将FastDFS_v5.05.tar.gz 解压至/usr/local/下

    tar -zxvf FastDFS_v5.05.tar.gz -C /usr/local

    (3)切换目录到: /usr/local/FastDFS/ 下,编译和安装;

    cd /usr/local/FastDFS/
    ./make.sh && ./make.sh install #编译之后接着进行安装

    安装后的截图:

     

    (4)安装成功将安装目录下的conf下的文件拷贝到/etc/fdfs/下;

    cp /usr/local/FastDFS/conf/* /etc/fdfs/

     

    5、配置和启动tracker

    (1)切换目录到: /etc/fdfs/ 目录下;

    (2)拷贝一份新的tracker配置文件

    cp tracker.conf.sample tracker.conf
    

    (3)修改tracker.conf ; vim tracker.conf

    base_path=/home/yuqing/fastdfs  改为:  base_path=/home/fastdfshttp.server_port  改为: 80
    base_path=/home/fastdfs
    http.server_port=80  #配置http端口
    

    (4)创建 /home/fastdfs 目录

    mkdir /home/fastdfs
    

    (5)启动tracker,运行如下命令:

    /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
    

    注意:在/home/fastdfs/ 目录下生成两个目录, 一个是数据,一个是日志;

     

    6、配置和启动storage

    由于上面已经安装过FastDFS,这里只需要配置storage就好了;

    (1)切换目录到: /etc/fdfs/ 目录下;

    (2)拷贝一份新的storage配置文件

    cp storage.conf.sample storage.conf
    

    (3)修改storage.conf ; vim storage.conf

    group_name=group1 #配置组名base_path=/home/yuqing/fastdfs    改为:  base_path=/home/fastdfs#store存放文件的位置(store_path)store_path0=/home/yuqing/fastdfs  改为: store_path0=/home/fdfs_storage #如果有多个挂载磁盘则定义多个store_path,如下#store_path1=.....#store_path2=......#配置tracker服务器:IPtracker_server=192.168.172.20:22122#如果有多个则配置多个tracker#tracker_server=192.168.101.4:22122#配置http端口http.server_port=88
    

    (4)创建 /home/fdfs_storage 目录

    mkdir /home/fdfs_storage
    

    (5)启动storage, 运行命令如下:

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

    启动完成后进入 /home/fdfs_storage/data 目录下,显示目录如下:

     

    7、使用FastDFS自带工具测试

    (1)切换目录到 /etc/fdfs/ 目录下;

    (2)拷贝一份新的client配置文件

    cp client.conf.sample client.conf
    

    (3)修改client.conf ; vim client.conf,修改基本路径和tracker_server如下:

    注意:若tracker有多个,可以配置多个,如下:

      #tracker_server=......

      #tracker_server=......

    (4)拷贝一张图片luzhouYue.jpg 到Centos服务器上的 /usr1 目录下;

      

    (5)进行测试,运行如下:(运行测试程序,读取/etc/fdfs/client.conf 文件,上传/usr1目录下的luzhouYue.jpg文件)

    /usr/bin/fdfs_test /etc/fdfs/client.conf upload /usr1/luzhouYue.jpg
    

    结果如下,表示搭建成功;

    以上图中的文件地址:http://192.168.172.20/group1/M00/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg 对应storage服务器上的/home/fdfs_storage/data/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg文件;

    由于现在还没有和nginx整合无法使用http下载。

     

    8、FastDFS 和nginx整合

    8.1 在tracker上安装 nginx

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

    一个tracker对应多个storage,通过nginx对storage负载均衡;

    8.2 在storage 上安装nginx

    (1)上传 fastdfs-nginx-module_v1.16.tar.gz 到Centos服务器上;

    (2)解压 fastdfs-nginx-module_v1.16.tar.gz 到 /usr/local目录下;

    tar -zxvf fastdfs-nginx-module_v1.16.tar.gz -C /usr/local
    

    (3)切换目录到: /usr/local/fastdfs-nginx-module/src/ 目录下

    cd /usr/local/fastdfs-nginx-module/src/
    

    (4)修改config文件,将文件中的所有 /usr/local/ 路径改为 /usr/

    修改完成后:

    (5)将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下

    cp mod_fastdfs.conf /etc/fdfs/
    

    (6)并修改 /etc/fdfs/mod_fastdfs.conf 的内容;vi /etc/fdfs/mod_fastdfs.conf

    base_path=/tmp 修改为 base_path=/home/fastdfs

    base_path=/home/fastdfs
    tracker_server=192.168.172.20:22122 #tracker_server=192.168.172.20:22122 #(多个tracker配置多行)url_have_group_name=true        #url中包含group名称store_path0=/home/fdfs_storage  #指定文件存储路径(上面配置的store路径)
    

    (7)将libfdfsclient.so拷贝至/usr/lib下

    cp /usr/lib64/libfdfsclient.so /usr/lib/
    

    (8)创建nginx/client目录

    mkdir -p /var/temp/nginx/client
    

     

    8.3 Nginx的安装

    (1)上传 nginx-1.8.0.tar.gz 到Centos服务器上;

    (2)解压 nginx-1.8.0.tar.gz 到 /usr/local目录下;

    tar -zxvf nginx-1.8.0.tar.gz -C /usr/local/
    

    (3)安装nginx的依赖库

    yum install pcre
    yum install pcre-devel
    yum install zlib
    yum install zlib-devel
    yum install openssl
    yum install openssl-devel
    

    (4)进入nginx解压的目录下:cd /usr/local/nginx-1.8.0/

    (5)加入模块命令配置

    ./configure 
    --prefix=/usr/local/nginx 
    --pid-path=/var/run/nginx/nginx.pid 
    --lock-path=/var/lock/nginx.lock 
    --error-log-path=/var/log/nginx/error.log 
    --http-log-path=/var/log/nginx/access.log 
    --with-http_gzip_static_module 
    --http-client-body-temp-path=/var/temp/nginx/client 
    --http-proxy-temp-path=/var/temp/nginx/proxy 
    --http-fastcgi-temp-path=/var/temp/nginx/fastcgi 
    --http-uwsgi-temp-path=/var/temp/nginx/uwsgi 
    --http-scgi-temp-path=/var/temp/nginx/scgi 
    --add-module=/usr/local/fastdfs-nginx-module/src 
    --with-http_ssl_module
    

      

    注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录;

    (6)编译并安装

    make && make install
    

    安装成功后查看生成的目录,如下所示:

     

    (7)拷贝配置文件到 /etc/fdfs 下;

    cd /usr/local/FastDFS/conf
    cp http.conf mime.types /etc/fdfs/
    

    (8)修改nginx配置文件

    mkdir /usr/local/nginx/logs # 创建logs目录cd /usr/local/nginx/conf/
    vim nginx.conf
    

    做如下的修改:

      

      

    说明

      (a.) server_name指定本机ip;

      (b.) location /group1/M00/:group1为nginx 服务FastDFS的分组名称,M00是FastDFS自动生成编号,对应store_path0=/home/fdfs_storage,如果FastDFS定义store_path1,这里就是M01

     

    (9)nginx的启动

    cd /usr/local/nginx/sbin/
    ./nginx 
    

    查询nginx进程

      

    (10) fastdfs 和 nginx 服务的开机自启动: http://www.cnblogs.com/yufeng218/p/8215381.html

    9、在浏览器中访问上传到fastDFS的图片

    因为Centos系统有防火墙,需要先关闭掉,才可以在浏览器中访问;

    (1)CentOS 7.0默认使用的是firewall作为防火墙;若没有启用iptables 作为防火墙,则使用以下方式关闭防火墙:

    systemctl stop firewalld.service #停止firewall
    systemctl disable firewalld.service #禁止firewall开机启动
    firewall-cmd --state #查看默认防火墙状态(关闭后显示notrunning,开启后显示running)
    

      

    (2)若已经启用iptables作为防火墙,则使用以下方式关闭:

    service iptables stop  #临时关闭防火墙
    chkconfig iptables off #永久关闭防火墙
    

    防火墙的相关链接:http://www.jb51.net/article/101576.htm

             http://www.linuxidc.com/Linux/2015-05/117473.htm

    (3)在谷歌浏览器中访问刚才上传的图片:

    刚才上传的图片地址为:http://192.168.172.20/group1/M00/00/00/wKisFFpBG9eAHaQvAAAWKd1hQR4158_big.jpg

     

    配置https访问图片

    一、步骤


        a)、安装openssl,生成ssl证书
        b)、nginx添加with-http_ssl_module模块
        c)、配置nginx支持https访问fastdfs


    二、安装openssl,生成ssl证书


    1、安装openssl

        运行命令:
        1、$ yum install openssl openssl-devel -y
        2、$ openssl version


        注:若出现错误:openssl: errorwhileloading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory
        说明库位置不对。

        解决办法:
        在root下运行命令:
        1、$ ln-s/usr/local/lib64/libssl.so.1.1 /usr/lib64/libssl.so.1.1
        2、$ ln-s/usr/local/lib64/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1
       
        openssl安装完成。

    2、生成ssl证书

        可以通过以下办法生成一个简单的证书:

      a)首先,进入你想创建证书和私钥的目录,例如:

        $ cd /usr/local/nginx/conf/ssl

      b)创建服务器私钥,命令会让你输入一个口令

        $ openssl genrsa -des3 -out server.key 1024

      c)创建签名请求的证书(CSR)

        $ openssl req -new -key server.key -out server.csr

      d)在加载SSL支持的Nginx并使用上述私钥时除去必须的口令

        $ cp server.key server.key.org
        $ openssl rsa -in server.key.org -out server.key

      e)最后标记证书使用上述私钥和CSR

        $ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt


    三、nginx添加with-http_ssl_module模块运行命令


      1、添加ssl模块

       [root@fuhai-server sbin]#./nginx-V
       nginx version:nginx/1.9.9
       built by gcc 4.4.7 20120313(Red Hat 4.4.7-17)(GCC)
       built with OpenSSL 1.0.1t 3 May 2016
       TLS SNI support enabled
       configure arguments: --prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module/src --with-pcre=/usr/local/pcre-8.39 --with-zlib=/usr/local/zlib-1.2.8 --with-openssl=/usr/local/openssl-1.0.1t --with-http_ssl_module
       如果没有--with-http_ssl_module,则需要重新编译添加ssl模块


     2、重新编译 (注意:上边编译是已经添加了加密模块,此处可忽略)
       
        [root@fuhai-server nginx-1.9.9]#./configure--prefix=/usr/local/nginx--add-module=/usr/local/fastdfs-nginx-module/src--with-pcre=/usr/local/pcre-8.39--with-zlib=/usr/local/zlib-1.2.8--with-openssl=/usr/local/openssl-1.0.1t--with-http_ssl_module

      3、编译完之后make,不要makeinstall。会在当前的objs目录生成nginx可执行文件,备份nginx安装目录的执行文件,将"objs/nginx”文件拷贝到nginx的sbin目录,重载nginx。
           
        [root@fuhai-server sbin]#cp nginx nginx_bak
        [root@fuhai-server nginx-1.9.9]#cp objs/nginx/usr/local/nginx/sbin/

    四、配置nginx支持https访问fastdfs


    1、修改Nginx配置文件,让其包含新标记的证书和私钥:

        server {
            server_name YOUR_DOMAINNAME_HERE;
            listen 443;
            ssl on;
            ssl_certificate /usr/local/nginx/conf/server.crt;
            ssl_certificate_key /usr/local/nginx/conf/server.key;
        }

    2、重载nginx

  • 相关阅读:
    257. Binary Tree Paths
    324. Wiggle Sort II
    315. Count of Smaller Numbers After Self
    350. Intersection of Two Arrays II
    295. Find Median from Data Stream
    289. Game of Life
    287. Find the Duplicate Number
    279. Perfect Squares
    384. Shuffle an Array
    E
  • 原文地址:https://www.cnblogs.com/hcs88/p/13163185.html
Copyright © 2011-2022 走看看