❶ 七牛雲如何進行相同賬號不同區域數據遷移啊
你可以在七牛雲後台-對象存儲中,使用跨區域同步功能進行數據遷移,注意勾選上需要同步歷史數據就可以了。
❷ 我為什麼最終選擇了七牛雲存儲
說實話,當初在用又拍雲的時候,遇到了一些麻煩,因為我一開始不知道該怎麼操作,其操作界面不是很人性化,弄了半天才弄明白怎麼樣新建一個空間,新建空間之後,還需要用 FTP 軟體來管理這個空間的內容,在 Mac 上找到一個靠譜的FTP 管理工具並不容易,我試用了FileZilla 這個軟體,使用和配置 FTP 又花了我不少功夫。
反觀七牛則是一目瞭然,從新建空間、配置空間、上傳文件、獲取外鏈,全部都是在網頁中可以完成簡易的可視化操作:
在管理後台,無論是使用還是統計都是一目瞭然:
以我上傳一張照片並獲取外鏈供博客使用為例,比較一下又拍雲和七牛雲的流程:
又拍雲
1.打開並登錄 FTP 工具;
2.上傳圖片;
3.復制圖片名
4.在博客管理後台輸入外鏈路徑+圖片名(這一點最為麻煩,每次都需要手動輸入一長串鏈接地址)
七牛雲
1.直接在網頁管理後台上傳圖片(這個界面很友好,和 wordpress 的圖片上傳界面類似)
2.直接獲取復制完整外鏈即可(注意右側的圖片預覽功能,這個對於圖片多了之後防止誤操作很是實用)
相比之下,顯然是七牛雲在操作使用上更加簡便易行。
可視化圖片處理設置
在數據處理環節,七牛雲也比較方便,比如我的博客圖片寬度不能超過550px,否則會撐破主題,並且想加上一個@望月的水印,那麼就可以在數據處理界面進行設置。
這樣,就不用在博客後台每次添加圖片之後都去重新調整一下大小,也不用使用圖片修改軟體去添加水印之類的了。
免費的使用空間和流量
對於新用戶,七牛雲存儲免費贈送10G 的使用空間+10G/月的流量,對於小博客來說,是完全夠用了,推薦朋友還可以免費獲取空間,如果你有需要,可以通過我的推薦鏈接注冊七牛,也可以幫我增加一些免費空間和流量,謝謝。
同時,通過36Kr 的活動頁面,還可以獲取800元的代金券和85折的協議價進行續費充值。
即使是流量、存儲空間和數據請求超出,七牛的價格也相對便宜。
一鍵加速功能
除此之外,還很是喜歡七牛雲的一鍵加速網站功能,也就是鏡像存儲,源站資源(文件/圖片等)根據初次訪問自動同步到七牛雲存儲,數據平滑遷移。可使用綁定的自定義域名訪問鏡像存儲的源站資源。格式:http://綁定域名/源站資源相對路徑。
還可以配合使用七牛鏡像存儲 WordPress 插件一鍵實現 WordPress 博客靜態文件 CDN 加速。
其實,七牛雲在圖片存儲和使用方面的便捷就足夠打動我了,綜合來說,七牛雲存儲設計更加人性化、操作更加簡便,價格更加適中,無論是對於博客用戶還是開發者用戶,都是個不錯的選擇。
❸ 七牛雲的kodo-browser工具怎麼用
kodo-browser是一個windows的圖形界面化工具,就可以用了。鏈接七牛 雲存儲空間,對空間文件進行操作,支持拖拽本地文件夾上傳。
❹ 如何使用七牛Python SDK寫一個同步腳本及使
七牛雲存儲的 Python 語言版本 SDK(本文以下稱 Python-SDK)是對七牛雲存儲API協議的一層封裝,以提供一套對於 Python 開發者而言簡單易用的開發工具。Python 開發者在對接 Python-SDK 時無需理解七牛雲存儲 API 協議的細節,原則上也不需要對 HTTP 協議和原理做非常深入的了解,但如果擁有基礎的 HTTP 知識,對於出錯場景的處理可以更加高效。
最近剛搭了個markdown靜態博客,想把圖片放到雲存儲中。
經過調研覺得七牛可以滿足我個人的需求,就選它了。
要引用圖片就要先將圖片上傳到雲上。
雖然七牛網站後台可以上傳文件,但每次上傳都需要先登錄,然後選擇圖片,設置連接地址,才能上傳。
這個過程有些繁瑣,所以我便想用七牛雲提供的SDK寫個一同步工具,方便增量同步文件。
有了這個想法,就馬上行動。花了大概一個上午的時間,總算把這個工具給寫出來,並放到GitOSC和github上。
?
#!/usr/bin/env python#-*- coding:utf-8 -*-## AUTHOR = "heqingpan"# AUTHOR_EMAIL = "[email protected]"# URL = "http://git.oschina.net/hqp/qiniu_sync"import qiniufrom qiniu import Authfrom qiniu import BucketManagerimport osimport reaccess_key = ''secret_key = ''bucket_name = ''bucket_domain = ''q = Auth(access_key, secret_key)bucket = BucketManager(q)basedir=os.path.realpath(os.path.dirname(__file__))filename=__file__ignore_paths=[filename,"{0}c".format(filename)]ignore_names=[".DS_Store",".git",".gitignore"]charset="utf8"diff_time=2*60def list_all(bucket_name, bucket=None, prefix="", limit=100):rlist=[]if bucket is None:bucket = BucketManager(q)marker = Noneeof = Falsewhile eof is False:ret, eof, info = bucket.list(bucket_name, prefix=prefix, marker=marker, limit=limit)marker = ret.get('marker', None)for item in ret['items']:rlist.append(item["key"])if eof is not True:# 錯誤處理#print "error"passreturn rlistdef get_files(basedir="",fix="",rlist=None,ignore_paths=[],ignore_names=[]):if rlist is None:rlist=[]for subfile in os.listdir(basedir):temp_path=os.path.join(basedir,subfile)tp=os.path.join(fix,subfile)if tp in ignore_names:continueif tp in ignore_paths:continueif os.path.isfile(temp_path):rlist.append(tp)elif os.path.isdir(temp_path):get_files(temp_path,tp,rlist,ignore_paths,ignore_names)return rlistdef get_valid_key_files(subdir=""):basedir=subdir or basedirfiles = get_files(basedir=basedir,ignore_paths=ignore_paths,ignore_names=ignore_names)return map(lambda f:(f.replace("\","/"),f),files)def sync():qn_keys=list_all(bucket_name,bucket)qn_set=set(qn_keys)l_key_files=get_valid_key_files(basedir)k2f={}update_keys=[]u_count=500u_index=0for k,f in l_key_files:k2f[k]=fstr_k=kif isinstance(k,str):k=k.decode(charset)if k in qn_set:update_keys.append(str_k)u_index+=1if u_index > u_count:u_index-=u_countupdate_file(k2f,update_keys)update_keys=[]else:# uploapload_file(k,os.path.join(basedir,f))if update_keys:update_file(k2f,update_keys)print "sync end"def update_file(k2f,ulist):ops=qiniu.build_batch_stat(bucket_name,ulist)rets,infos = bucket.batch(ops)for i in xrange(len(ulist)):k=ulist[i]f=k2f.get(k)ret=rets[i]["data"]size=ret.get("fsize",None)put_time = int(ret.get("putTime")/10000000)local_size=os.path.getsize(f)local_time=int(os.path.getatime(f))if local_size==size:continueif put_time >= local_time - diff_time:# is newcontinue# updateupload_file(k,os.path.join(basedir,f))def upload_file(key,localfile):print "upload_file:"print keytoken = q.upload_token(bucket_name, key)mime_type = get_mime_type(localfile)params = {'x:a': 'a'}progress_handler = lambda progress, total: progressret, info = qiniu.put_file(token, key, localfile, params, mime_type, progress_handler=progress_handler)def get_mime_type(path):mime_type = "text/plain"return mime_typedef main():sync()if __name__=="__main__":main()這個同步腳本支持批量比較文件,差異增量更新、批量更新。
使用方式
安裝七牛Python SDK
?
1pip install qiniu填寫腳本文件(qiniusync.py)的配置信息
?
123access_key = ''secret_key = ''bucket_name = ''注冊後可以拿到對應的信息
將腳本文件(qiniusync.py)拷貝到待同步根目錄
運行腳本
?
1python qiniusync.py後記
寫完提交之後才發現,七牛已經提供相應的工具,我這個算是重復造輪子吧。
既然已經寫,就發出來,當做熟悉一下七牛的SDK也不錯,說不定以後還能用的上。
七牛雲存儲Python SDK使用教程
本教程旨在介紹如何使用七牛的Python SDK來快速地進行文件上傳,下載,處理,管理等工作。
安裝
首先,要使用Python的SDK必須要先安裝。七牛的Python SDK是開源的,託管在Github上面,項目地址為https://github.com/qiniu/python-sdk。
安裝的方式可以如項目的說明上所說,用 pip install qiniu 。當然也可以直接 clone 一份源代碼下來直接使用。我一般喜歡直接 clone 源代碼,這樣的話,如果要對SDK做一些改動也是十分容易的。
最新版本的Python SDK需要依賴 requests 庫,所以要提前安裝好。安裝方式當然也可以用 pip install requests 。
開發環境
Python的開發環境有很多種選擇,如果喜歡文本的方式,比如vim,emacs,sublime text等都是很好的選擇,如果你喜歡IDE,那麼最流行的莫過於 PyCharm 了。 PyCharm 的最新版本到這里下載。
Access Key和Secret Key
我們知道七牛雲存儲的許可權校驗機制基於一對密鑰,分別稱為 Access Key 和 Secret Key 。其中 Access Key 是公鑰, Secret Key 是私鑰。這一對密鑰可以從七牛的後台獲取。
小試牛刀
好了,做了上面的這些准備工作,我們就去上傳一個簡單的文件,練練手。
?
1234python#coding=utf-8__author__ = 'jemy''''本例演示了一個簡單的文件上傳。
這個例子裡面,sdk根據文件的大小選擇是Form方式上傳還是分片上傳。
?
'''import qiniuaccessKey = "<Your Access Key>"secretKey = "<Your Secret Key>"#解析結果def parseRet(retData, respInfo):if retData != None:print("Upload file success!")print("Hash: " + retData["hash"])print("Key: " + retData["key"])#檢查擴展參數for k, v in retData.items():if k[:2] == "x:":print(k + ":" + v)#檢查其他參數for k, v in retData.items():if k[:2] == "x:" or k == "hash" or k == "key":continueelse:print(k + ":" + str(v))else:print("Upload file failed!")print("Error: " + respInfo.text_body)#無key上傳,http請求中不指定key參數def upload_without_key(bucket, filePath):#生成上傳憑證auth = qiniu.Auth(accessKey, secretKey)upToken = auth.upload_token(bucket, key=None)#上傳文件retData, respInfo = qiniu.put_file(upToken, None, filePath)#解析結果parseRet(retData, respInfo)def main():bucket = "if-pbl"filePath = "/Users/jemy/Documents/jemy.png"upload_without_key(bucket, filePath)if __name__ == "__main__":main()運行結果為:
Upload file success!
Hash: Fp0XR6tM4yZmeiKXw7eZzmeyYsq8
Key: Fp0XR6tM4yZmeiKXw7eZzmeyYsq8
從上面我們可以看到,使用七牛的Python SDK上傳文件的最基本的步驟是:
1.生成上傳憑證
2.上傳文件
3.解析回復結果
❺ linux命令行有沒有可以類似同步網盤的工具
堅果雲支持linux,可以同步任意的文件。
❻ 如何利用七牛免費雲存儲平台做微信游戲
一,登錄成功後,中間和右上角點擊+新建空間
二,建立空間填寫名稱,並設置為公開訪問
三,點擊內容管理,並點擊右上角的「上傳」按鈕
四,七牛不支持直接在網頁上批量上傳,不能分目錄分組管理文件(如果需要區分文件目錄路徑,就添加文件前綴)
五,因為這些原因,如果文件較多的話,直接在七牛網頁上管理文件是很不方便的,所以建立大家用七牛的客戶端工具,在網頁的右下角。
六,沒有命令行操作經驗的,win系統建議用qrsbox。
七,下載QRSBox後,解壓文件。進入解壓後的目錄,雙擊qrsbox.exe,彈出軟體界面:
其中,access_key 和 secret_key 在七牛雲存儲平台上點擊左上角的房子圖標進入首頁,再點擊賬號設置,在左邊的菜單導航上選擇密匙(查看AccessKey/SecretKey),分別填入上圖的對應輸入框中即可。
同步源目錄:就是本地的文件路徑(例如D:\tianxing)表示同步D盤的tianxing文件夾到七牛空間上。
空間名:就是步驟二中,你創建的七牛空間。設置好後,D:\tianxing文件夾內的所有文件會自動同步到你的七牛雲空間上。
八,七牛系統分配的文件URL和其他相關設置在當前空間的空間設置上可以查看。
到此,七牛雲的使用方法就是這樣了。
❼ 怎麼辦想把七牛雲賬號的數據復制到其他不同區域
很簡單的哦,在七牛雲上先使用空間授權服務,把賬號下A空間授權給B賬號,然後開啟跨區域同步功能把數據同步過去,注意勾選上需要同步歷史數據就行了。
❽ 在七牛雲上,兩個不同的賬號下相同區域的數據遷移能實現嗎該怎麼做
能實現的,可以先使用空間授權,然後再使用 qshell 工具中的 batch 命令將一個空間中的文件批量移動到另一個空間就可以了。關於空間授權和qshell工具使用可以去七牛雲上搜索相關關鍵詞,然後查看文檔做參考。
❾ joplin + 七牛雲 筆記同步
不建議大家用堅果雲webDav,保存請求太多會出現筆記丟失的情況。看到網上有用joplin騰訊雲的,騰訊雲cos只是免費六個月。推薦大家用七牛雲。
創建空間管理:
最主要的
檢查同步配置就成功了。
❿ 想要把數據從阿里oss遷移到七牛雲存儲該怎麼辦
有個簡單的方法,可以使用kodoimport這個工具進行遷移,該工具是一個腳本命令行工具,在終端或者cmd中運行即可,具體使用方法可以在七牛雲上搜索「數據遷移工具」,然後查看相關說明。