Nginx+Fastdfs搭建图片服务器

1.环境和工具

  • linux虚拟机为CentOS-6.5
  • Xshell远程连接工具
  • nginx-1.8.0.tar.gz
  • FastDFSV5.05.tar.gz
  • fastdfs-nginx-module_v1.16.tar.gz
  • libfastcommon-1.0.7.tar.gz

2.工具下载

  • 下载Nginx的安装包 –https://nginx.org/download/
  • 下载fastDFS的安装包 –https://sourceforge.net/projects/fastdfs/files
  • 我的资源中有fastDFS的相关包(需要积分)

3.使用Xshell 连接虚拟机上传相关包到虚拟机

  • 使用Xhell创建一个新的会话,名称任意(建议也写ip地址)、协议选择ssh、主机为你虚拟机的ip地址、点击确定
    Nginx+Fastdfs搭建图片服务器_第1张图片
  • 在Linux主机上,安装上传下载工具包rz及sz
    如果不知道你要安装包的具体名称,可以使用yum provides */name 进行查找系统自带软件包的信息;
    [root@localhost src]# yum provides */rz
    lrzsz-0.12.20-27.1.el6.i686 : The lrz and lsz modem communications programs
    Repo : base
    Filename : /usr/bin/rz
    一般会列出软件包的名称及版本,还有安装路径;查询到软件包名后,使用yum install -y 包名 进行安装。
    lrzsz包安装完成后包括上传rz、下载sz命令;只需要安装这个包即可。
    [root@localhost src]# yum install -y lrzsz
  • 使用Xshell上传Nginx+fastDFS相关包到虚拟机

4.相关依赖包的下载

  • 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
  • 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之前,先安装libevent工具包。
    yum -y install libevent

5.搭建步骤

  • 安装libfastcommonV1.0.7工具包。
    《1》解压缩tar -zxf libfastcommonV1.0.7.tar.gz
    《2》yum -y install perl
    《3》./make.sh
    《4》./make.sh install
    《5》把/usr/lib64/libfastcommon.so文件向/usr/lib/下复制一份(我装的是32位 的虚拟机)
  • 安装Tracker服务
    《1》解压缩
    《2》./make.sh
    《3》./make.sh install 安装后在/usr/bin/目录下有以fdfs开头的文件都是编译出来的。配置文件都放到/etc/fdfs文件夹
    《4》把/root/FastDFS/conf目录下的所有的配置文件都复制到/etc/fdfs下。
    《5》配置tracker服务。修改/etc/fdfs/tracker.conf文件。
    Nginx+Fastdfs搭建图片服务器_第2张图片
    《6》启动tracker。/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf
    重启使用命令:/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
  • 安装storage服务。
    《1》如果是在不同的服务器安装,上一步的1~4需要重新执行。
    《2》配置storage服务。修改/etc/fdfs/storage.conf文件。
    Nginx+Fastdfs搭建图片服务器_第3张图片
    《3》启动storage服务。/usr/bin/fdfs_storaged /etc/fdfs/storage.conf
    重启使用命令: /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
  • 测试服务
    《1》修改配置文件/etc/fdfs/client.conf
    Nginx+Fastdfs搭建图片服务器_第4张图片
    《2》测试 /usr/bin/fdfs_test /etc/fdfs/client.conf upload anti-steal.jpg
    图片路径:/etc/fdfs/
  • 搭建nginx提供http服务。
    《1》解压插件压缩包: fastdfs-nginx-module_v1.16.tar.gz
    《2》修改/root/fastdfs-nginx-module/src/config文件,把其中的local去掉。
    Nginx+Fastdfs搭建图片服务器_第5张图片
    《3》进入nginx的文件夹 对nginx重新config
    ./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=/root/fastdfs-nginx-module/src
    注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录
    《4》 make
    《5》 make install
    《6》把/root/fastdfs-nginx-module/src/mod_fastdfs.conf文件复制到/etc/fdfs目录下。编辑:
    Nginx+Fastdfs搭建图片服务器_第6张图片
    《7》nginx的配置,在nginx的配置文件中添加一个Server:cd /usr/local/nginx/config/
server {
        listen       80;
        server_name  192.168.101.3;

        location /group1/M00/{
                #root /home/FastDFS/fdfs_storage/data;
                ngx_fastdfs_module;
        }
}

《8》将libfdfsclient.so拷贝至/usr/lib下:cp /usr/lib64/libfdfsclient.so /usr/lib/
《9》/usr/local/nginx目录下启动nginx sbin/nginx
停止nginx sbin/nginx -s stop

6.若Nginx启动后,浏览器输入ip无法访问

  • 第一步:先检查网络,win机ping linux机,通了进行下一步
  • 第二步:检查端口,netstat -antl | grep 你开启的服务端口,比如你开了http,那就是80端口或者你自定义的端口。
  • 第三步:检查防火墙,service iptables stop 可以直接先关掉防火墙看是不是能访问了,如果可以,说明是防火墙屏蔽掉了。
    chkconfig iptables off (将防火墙永久关闭)

你可能感兴趣的:(linux)