python-django框架中使用FastDFS分佈式文件系統

1、安裝FastDFSpython

1-1:執行docker命令安裝docker

# 安裝tracker
docker run -dti --network=host --name tracker -v /var/fdfs/tracker:/var/fdfs youkou1/fastdfs tracker

# 安裝storage
docker run -dti --network=host --name storage -e TRACKER_SERVER=IP地址:22122 -v /var/fdfs/storage:/var/fdfs youkou1/fastdfs storage

1-2 測試是否安裝成功:執行命令 docker ps -a瀏覽器

 

TRACKER_SERVER:IP地址說明不要使用lo 和docker下的IP地址由於在安裝鏡像中配的是enp3s0下面的IP地址。bash

 

1-三、在項目中建立客戶端配置文件  fastdfs/client.conf服務器

 

client.conf配置文件內容:注意tracker_serverIP地址。測試

# 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=utils/fastdfs/logs

# 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.31.170: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
use_connection_pool = false

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

# if load FastDFS parameters from tracker server
# 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
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
storage_ids_filename = storage_ids.conf


#HTTP settings
http.tracker_server_port=80

1-4:在xhell中進入項目的虛擬環境安裝python相關包 (在虛擬環境中)ui

# 安裝相關包 
pip install fdfs_client.zip
pip install mutagen
pip install requests

1-5:若是pip install fdfs_client.zip 安裝報錯this

請執行以下命令spa

sudo apt-get install python3 python-dev python3-dev build-essential libssl-dev libffi-dev libxml2-dev libxslt1-dev zlib1g-dev python-pip

  

而後在執行安裝命令:debug

查看所安裝的包:

分析上傳步驟: 
  1) 指定圖片絕對地址 
  2) 指定圖片服務器地址;使用 Client.conf 配置文件 
  3) 加載圖片服務器,鏈接圖片服務器 
  4) 建立圖片服務器 tracker 客戶端 
  5) 從客戶端獲取 tracker 鏈接 

  6) 建立 storage 客戶端,存儲圖片

測試代碼:

from fdfs_client.client import Fdfs_client
FDFS_Client = Fdfs_client('/common/fastdfs/client.conf')
ret = FDFS_Client.upload_by_filename('/media/2018.png')
print(ret)

  若是執行不報錯,返回結果以下說明就成功了:

 

1-6 若是進行測試 如下報的是語法錯誤,這個明顯是python2的語法,我如今用的是python3,進過查詢相關資料,決定換一個不用 pip install fdfs_client.zip 

刪除   fdfs_client.zip  執行命令

 pip uninstall fdfs_client-py

  

使用pip install py3Fdfs

 再次測試: 

 

 在瀏覽器中查看:

http://192.168.31.170:8888/group1/M00/00/00/wKgfqlz5yYyAHe5nAAfh_rrm7jw601.png

注意:這裏的端口8888也是在上面安裝環境中配好的。

相關文章
相關標籤/搜索