Centos7安装FastDFS

深藏阁楼爱情的钟 2022-12-31 13:20 275阅读 0赞

Centos下安装FastDFS

1.1 上传

  1. FastDFS_v5.08.tar.gz
  2. fastdfs-nginx-module_v1.16.tar.gz
  3. libevent-2.0.22-stable.tar.gz
  4. libfastcommon-master.zip
  5. nginx-1.10.0.tar.gz
    下载地址:https://download.csdn.net/download/qq_37740841/13981856

1.2 安装依赖

1.2.1 安装GCC依赖

GCC用来对C语言代码进行编译运行,使用yum命令安装:

  1. yum -y install gcc

1.2.2 安装unzip工具

unzip工具可以帮我们对压缩包进行解压

  1. yum install -y unzip zip

1.2.3 安装libevent

  1. yum -y install libevent

1.2.4 安装Nginx所需依赖

  1. yum -y install pcre pcre-devel zlib zlib-devel openssl openssl-devel

1.2.5 安装libfastcommon-master

这个没有yum包,只能通过编译安装:

  • 解压刚刚上传的libfastcommon-master.zip

    1. tar -xvf libfastcommon-master.zip
  • 进入解压完成的目录:

    1. cd libfastcommon-master
  • 编译并且安装:

    1. sudo ./make.sh
    2. sudo ./makesh install

到这里为止,所有依赖都已经安装完毕,接下来安装FastDFS:

1.3 安装FastDFS

1.3.1 编译安装

这里也采用编译安装,步骤与刚才的编译安装方式一样:

  • 解压

    1. tar -xvf FastDFS_v5.08.tar.gz
  • 进入目录

    1. cd FastDFS
  • 编译并安装

    1. sudo ./make.sh
    2. sudo ./make.sh install
  • 校验安装结果

1)安装完成,我们应该能在/etc/init.d/目录,通过命令ll /etc/init.d/ | grep fdfs看到FastDFS提供的启动脚本:

其中:

  • fdfs_trackerd 是tracker启动脚本
  • fdfs_storaged 是storage启动脚本

2)我们可以在 /etc/fdfs目录,通过命令查看到以下配置文件模板:

其中:

  • tarcker.conf.sample 是tracker的配置文件模板
  • storage.conf.sample 是storage的配置文件模板
  • client.conf.sample 是客户端的配置文件模板

1.3.2 启动tracker

FastDFS的tracker和storage在刚刚的安装过程中,都已经被安装了,因此我们安装这两种角色的方式是一样的。不同的是,两种需要不同的配置文件。

我们要启动tracker,就修改刚刚看到的tarcker.conf,并且启动fdfs_trackerd脚本即可。

  • 编辑tracker配置

首先我们将模板文件进行赋值和重命名:

  1. cp tracker.conf.sample tracker.conf
  2. vim tracker.conf

打开tracker.conf,修改base_path配置:

  1. base_path=/var/data/fdfs/tracker # tracker的数据和日志存放目录
  • 创建目录

刚刚配置的目录可能不存在,我们创建出来

  1. sudo mkdir -p /var/data/fdfs/tracker
  • 启动tracker

    我们可以使用 sh /etc/init.d/fdfs_trackerd 启动,不过安装过程中,fdfs已经被设置为系统服务,我们可以采用熟悉的服务启动方式:

    sudo service fdfs_trackerd start # 启动fdfs_trackerd服务,停止用stop

另外,我们可以通过以下命令,设置tracker开机启动:

  1. sudo chkconfig fdfs_trackerd on

1.3.3 启动storage

我们要启动tracker,就修改刚刚看到的tarcker.conf,并且启动fdfs_trackerd脚本即可。

  • 编辑storage配置

首先我们将模板文件进行赋值和重命名:

  1. cp storage.conf.sample storage.conf
  2. vim storage.conf

打开storage.conf,修改base_path配置:

  1. base_path=/var/data/fdfs/storage # storage的数据和日志存放目录
  2. store_path0=/var/data/fdfs/storage # storage的上传文件存放路径
  3. tracker_server=192.168.56.101:22122 # tracker的地址
  • 创建目录

刚刚配置的目录可能不存在,我们创建出来

  1. sudo mkdir -p /var/data/fdfs/storage
  • 启动storage

    我们可以使用 sh /etc/init.d/fdfs_storaged 启动,同样我们可以用服务启动方式:

    sudo service fdfs_storaged start # 启动fdfs_storaged服务,停止用stop

另外,我们可以通过以下命令,设置tracker开机启动:

  1. sudo chkconfig fdfs_storaged on

1.4 安装Nginx及FastDFS模块

1.4.1 FastDFS的Nginx模块

  • 解压

    1. tar -xvf fastdfs-nginx-module_v1.16.tar.gz
  • 配置config文件

    1. # 进入配置目录
    2. cd /var/local/fdfs/fastdfs-nginx-module/src/
    3. # 修改配置
    4. vim config
    5. # 执行下面命令(将配置中的/usr/local改为/usr):
    6. :%s+/usr/local/+/usr/+g
  • 配置mod_fastdfs.conf

    1. # 将src目录下的mod_fastdfs.conf复制到 /etc/fdfs目录:
    2. sudo cp mod_fastdfs.conf /etc/fdfs/
    3. # 编辑该文件
    4. sudo vim /etc/fdfs/mod_fastdfs.cof
  • 修改一下配置:

    1. connect_timeout=10 # 客户端访问文件连接超时时长(单位:秒)
    2. tracker_server=192.168.56.101:22122 # tracker服务IP和端口
    3. url_have_group_name=true # 访问链接前缀加上组名
    4. store_path0=/var/data/fdfs/storage # 文件存储路径
  • 复制 FastDFS的部分配置文件到/etc/fdfs目录

    1. cd /var/data/fdfs/FastDFS/conf/
    2. cp http.conf mime.types /etc/fdfs/

1.4.2 安装Nginx

  • 解压

    1. tar -xvf nginx-1.10.0.tar.gz
  • 配置

    1. sudo ./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/var/local/fdfs/fastdfs-nginx-module/src
  • 编译安装

    1. sudo make && sudo make install
  • 配置nginx整合fastdfs-module模块

    我们需要修改nginx配置文件,在/opt/nginx/config/nginx.conf文件中:

    1. sudo vim /opt/nginx/conf/nginx.conf

    将文件中,原来的server 80{ ...} 部分代码替换为如下代码:

    1. server {
    2. listen 80;
    3. server_name image.taotao.com;
    4. # 监听域名中带有group的,交给FastDFS模块处理
    5. location ~/group([0-9])/ {
    6. ngx_fastdfs_module;
    7. }
    8. location / {
    9. root html;
    10. index index.html index.htm;
    11. }
    12. error_page 500 502 503 504 /50x.html;
    13. location = /50x.html {
    14. root html;
    15. }
    16. }
  • 启动

    1. nginx # 启动
    2. nginx -s stop # 停止
    3. nginx -s reload # 重新加载配置
  • 设置nginx开机启动

    创建一个开机启动的脚本:

    1. vim /etc/init.d/nginx

    添加以下内容:

    1. #!/bin/sh
    2. #
    3. # nginx - this script starts and stops the nginx daemon
    4. #
    5. # chkconfig: - 85 15
    6. # description: NGINX is an HTTP(S) server, HTTP(S) reverse \
    7. # proxy and IMAP/POP3 proxy server
    8. # processname: nginx
    9. # config: /etc/nginx/nginx.conf
    10. # config: /etc/sysconfig/nginx
    11. # pidfile: /var/run/nginx.pid
    12. # Source function library.
    13. . /etc/rc.d/init.d/functions
    14. # Source networking configuration.
    15. . /etc/sysconfig/network
    16. # Check that networking is up.
    17. [ "$NETWORKING" = "no" ] && exit 0
    18. nginx="/usr/bin/nginx"
    19. prog=$(basename $nginx)
    20. NGINX_CONF_FILE="/opt/nginx/conf/nginx.conf"
    21. [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
    22. lockfile=/var/lock/subsys/nginx
    23. make_dirs() {
    24. # make required directories
    25. user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
    26. if [ -n "$user" ]; then
    27. if [ -z "`grep $user /etc/passwd`" ]; then
    28. useradd -M -s /bin/nologin $user
    29. fi
    30. options=`$nginx -V 2>&1 | grep 'configure arguments:'`
    31. for opt in $options; do
    32. if [ `echo $opt | grep '.*-temp-path'` ]; then
    33. value=`echo $opt | cut -d "=" -f 2`
    34. if [ ! -d "$value" ]; then
    35. # echo "creating" $value
    36. mkdir -p $value && chown -R $user $value
    37. fi
    38. fi
    39. done
    40. fi
    41. }
    42. start() {
    43. [ -x $nginx ] || exit 5
    44. [ -f $NGINX_CONF_FILE ] || exit 6
    45. make_dirs
    46. echo -n $"Starting $prog: "
    47. daemon $nginx -c $NGINX_CONF_FILE
    48. retval=$?
    49. echo
    50. [ $retval -eq 0 ] && touch $lockfile
    51. return $retval
    52. }
    53. stop() {
    54. echo -n $"Stopping $prog: "
    55. killproc $prog -QUIT
    56. retval=$?
    57. echo
    58. [ $retval -eq 0 ] && rm -f $lockfile
    59. return $retval
    60. }
    61. restart() {
    62. configtest || return $?
    63. stop
    64. sleep 1
    65. start
    66. }
    67. reload() {
    68. configtest || return $?
    69. echo -n $"Reloading $prog: "
    70. killproc $nginx -HUP
    71. RETVAL=$?
    72. echo
    73. }
    74. force_reload() {
    75. restart
    76. }
    77. configtest() {
    78. $nginx -t -c $NGINX_CONF_FILE
    79. }
    80. rh_status() {
    81. status $prog
    82. }
    83. rh_status_q() {
    84. rh_status >/dev/null 2>&1
    85. }
    86. case "$1" in
    87. start)
    88. rh_status_q && exit 0
    89. $1
    90. ;;
    91. stop)
    92. rh_status_q || exit 0
    93. $1
    94. ;;
    95. restart|configtest)
    96. $1
    97. ;;
    98. reload)
    99. rh_status_q || exit 7
    100. $1
    101. ;;
    102. force-reload)
    103. force_reload
    104. ;;
    105. status)
    106. rh_status
    107. ;;
    108. condrestart|try-restart)
    109. rh_status_q || exit 0
    110. ;;
    111. *)
    112. echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
    113. exit 2
    114. esac
  • 修改文件权限,并加入服务列表

    1. # 修改权限
    2. chmod 777 /etc/init.d/nginx
    3. # 添加到服务列表
    4. chkconfig --add /etc/init.d/nginx
  • 设置开机启动

    1. chkconfig nginx on

发表评论

表情:
评论列表 (有 0 条评论,275人围观)

还没有评论,来说两句吧...

相关阅读