swift上傳
A. Taylor swift的歌曲上傳酷狗怎麼不能聽,誰知道怎麼解決
請留意歌曲的格式
B. 用swift做cinder的備份驅動,配置文件怎麼寫
cinder是塊存儲,用來給虛擬機掛擴展硬碟,就是將cinder創建出來的卷,掛到虛擬機里。cinder是OpenStack到F版,將之前在Nova中的部分持久性塊存儲功能(Nova-Volume)分離了出來,獨立為新的組件Cinder
swift是一個系統,可以上傳和下載,裡面一般存儲的是不經常修改的內容,比如用於存儲 VM 鏡像、備份和歸檔以及較小的文件,例如照片和電子郵件消息。更傾向於系統的管理
C. 在openstack中swift和cinder中的區別
swift是object storage(對象存儲),將object(可以理解為文件)存儲到bucket(可以理解為文件夾)里,你可以用swift創建container,然後上傳文件,例如視頻,照片,這些文件會被replication到不同伺服器上以保證可靠性,swift可以不依靠虛擬機工作。所謂的雲存儲,OpenStack就是用swift實現的,類似於Amazon AWS S3(Simple Storage Service).
cinder是block storage(塊存儲),你可以把cinder當做優盤管理程序來理解。你可以用cinder創建volume,然後將它接到(attach)虛擬機上去,這個volume就像虛擬機的一個存儲分區一樣工作。如果你把這個虛擬機terminate了,這個volume和里邊的數據依然還在,你還可以把它接到其他虛擬機上繼續使用里邊的數據。cinder創建的volume必須被接到虛擬機上才能工作。類似於Amazon AWS EBS(Elastic Block Storage).
D. 如何在 Swift 中使用 Alamofire 進行網路編程
Alamofire是AFNetworking的作者編寫的在Swift中使用的網路類庫,使用起來邏輯清晰明了,也很容易上手.
當然AFNetworking在Swift中依然是可以使用的,不過我不推薦那麼做.
安裝Alamofire
可以通過Cocoapods的方式進行安裝,podfile配置如下:
platform :ios, '8.0'
use_frameworks!
target '你的工程名稱' do
pod 'Alamofire', '~> 3.3.0'
end
然後到終端執行pod install就可以了,使用之前先import一下import Alamofire
基本使用,請求數據
普通數據請求
//我把請求放在了button的點擊事件裡面
@IBAction func onBtnClick(sender: UIButton) {
//這里我使用一個查詢手機號碼歸屬地的介面為例,
Alamofire.request(.GET,, requestURL,parameters: ["phone":phoneNumber],encoding: .URL,headers: ["apix-key":apiKey]).responseJSON { (response) in
//是否請求成功
// if response.result.isSuccess{}
if let jsonValue = response.result.value {
print(jsonValue)
}
}
}
Alamofire.request(Method, URLString, parameters, encoding, headers)
//這是一個完整的Alamofire.Request的初始化方法,其中:
//Method,請求方式,如:.GET .POST .DELETE等
//URLString,請求介面
//parameters,請求參數,字典類型,如果是GET方法請求數據,傳入的參數將會被轉換為key1=value1&key2=value2的形式
//encoding,編碼方式,Alamofire提供一個枚舉來表示請求所用編碼,如.URL,.JSON,那麼GET方式請求數據一般使用.URL編碼方式
//headers,請求頭,對應於在NSURLRequest中的屬性allHTTPHeaderFields
這里是一個普通的GET請求,傳入的參數Alamofire自動以key=value&kay2=value2的形式拼接,如果請求是POST或者需要把請求參數已JSON的形=形式傳輸的話,encoding參數傳入.JSON即可
responseJSON閉包中我們得到的參數是一個結構體,裡面分別包含了此次請求的request對象,返回數據,請求結果等.
響應結果控制
Alamofire.request()返回的是一個Request對象,Request對象的參數都是本次請求中附帶的參數,responseJSON是對返回結果的控制,針對返回結果為JSON數據的情況,Alamofire中還提供了處理其他返回結果地方法:
response()
responseData()//二進制數據
responseString(encoding: NSStringEncoding)//字元串結果
responseJSON(options:NSJSONReadingOptions)//JSON數據
responsePropertyList(options: NSPropertyListReadOptions)//屬性列表
///響應方式應該試伺服器返回結果而定,如果伺服器給你的是JSON數據那麼就用responseJSON,如果是其他數據那麼也使用對應的
使用validate()驗證是否請求成功
Alamofire.request(.GET, requestURL,parameters:["phone":phoneNumber],encoding: .URL,headers: ["apix-key":apiKey]).validate().responseJSON { (response) in
//是否請求成功
switch response.result{
case .Success:
print("數據請求成功")
case .Failure(let error):
print(error)
}
}
validate()將確認響應的狀態編碼控制在可接受的范圍200-299內,如果驗證失敗,那麼在響應的處理方法內部將會出現一個錯誤.
上傳數據
一個簡單地上傳文件的小栗子
let fileURL = NSBundle.mainBundle().URLForResource("1", withExtension: "jpg")
Alamofire.upload(.POST, uploadURL, file: fileURL!)
//這里的前面兩個參數分別是連接方式,請求介面,第三個參數就是需要上傳的文件的本地URL
當然也可以使用NSData的形式上傳:
Alamofire.upload(.POST, uploadURL, data: "upload Data".dataUsingEncoding(NSUTF8StringEncoding)!)
其他的還有使用MultipartFormData等,這里就不做介紹了.
上傳附件時監測進度
Alamofire.upload(.POST, uploadURL, data: "upload Data".dataUsingEncoding(NSUTF8StringEncoding)!).progress { (written, totalWritten, totalNeedsToWrite) in
print("written bytes \(written) totalWritten \(totalWritten) totalBytes\(totalNeedsToWrite)")
///每次上傳一部分數據就會回調此閉包.
}
同樣的,不管是上傳還是請求數據或是下載文件,我們都可以得到伺服器的響應,所以上傳也是可以使用response系列方法的:
Alamofire.upload(.POST, uploadURL, data: "upload Data test ".dataUsingEncoding(NSUTF8StringEncoding)!).progress { (written, totalWritten, totalNeedsToWrite) in
print("written bytes \(written) totalWritten \(totalWritten) totalBytes\(totalNeedsToWrite)")
}.responseJSON { (response) in
print(response)//伺服器對本次數據上傳的響應
}
有上傳就有下載,Alamofire提供Alamofire.download()方法來執行下載操作:
///本例中所下載的文件是在網上隨便找的一張圖片
Alamofire.download(.GET, "http://pic.to8to.com/attch/day_160218/20160218_.png") { (URL, response) -> NSURL in
var path = (.DocumentDirectory, .UserDomainMask, true)[0]
path += "/\(response.suggestedFilename!)"
return NSURL.fileURLWithPath(path)
}
download方法接受一個閉包,此閉包在文件下載完成後調用,我們需要在閉包中返迴文件下載完畢之後,保存此文件的資源路徑,你也可以單獨拆分一個函數,然後傳入函數名即可
如果覺得這樣比較麻煩或者沒有必要在閉包中那些代碼,我們可以使用默認的資源路徑:
///這里使用的是系統的Document路徑
let destina = Alamofire.Request.suggestedDownloadDestination(directory: .DocumentDirectory, domain: .UserDomainMask)
Alamofire.download(.GET, "http://pic.to8to.com/attch/day_160218/20160218_.png",destination: destina)
同樣的,下載文件也可以檢測下載進度
//在此實現檢測下載進度邏輯
}
如果需要實現斷點續傳來下載文件的話,實現起來也是比較簡單,首先,Alamofire提供了對應的download方法:
Alamofire.download(resumeData: NSData() , destination: destina)
第一個參數應該傳入已經下載得到的數據,就可以在已經下載數據的基礎上繼續下載,那麼我們需要做的事就只有在下載出現錯誤或者暫停的時候把已下載數據保存起來就可以了,大致的實現思路就是這樣,我這里就不作演示了.
E. 比較cinder和swift的區別
cinder是塊存儲,用來給虛擬機掛擴展硬碟,就是將cinder創建出來的卷,掛到虛擬機里。cinder是OpenStack到F版,將之前在Nova中的部分持久性塊存儲功能(Nova-Volume)分離了出來,獨立為新的組件Cinder
swift是一個系統,可以上傳和下載,裡面一般存儲的是不經常修改的內容,比如用於存儲 VM
鏡像、備份和歸檔以及較小的文件,例如照片和電子郵件消息。更傾向於系統的管理
塊存儲具有安全可靠、高並發大吞吐量、低時延、規格豐富、簡單易用的特點,適用於文件系統、資料庫或者其他需要原始塊設備的系統軟體或應用。
上面其實很多感覺不是太直觀,個人認為cinder可以理解為個人電腦的移動硬碟,它可以隨意格式化,隨時存取。
對於swift可以作為網盤,相信對於雲技術的同學來說,網盤應該是不陌生的,如果把一些經常用的內容,放到網盤中是非常不方便的。
F. 如何用Tsung向OpenStack Swift上傳壓縮文件
當你開始使用OpenStack,基本上都是從一個已搭建好的環境入手,別人(operator)會告訴你horizon登錄的租戶名、用戶名和密碼。 但畢竟horizon不會封裝OpenStack的所有特性,當你已經玩膩了頁面上那些功能時,你想嘗試更多更豐富的功能,那麼恭喜你...
G. swift和cinder的區別
你好
關於cinder和swift的區別:
cinder與swift各自的用途是什麼?
cinder是塊存儲,用來給虛擬機掛擴展硬碟,就是將cinder創建出來的卷,掛到虛擬機里。cinder是OpenStack到F版,將之前在Nova中的部分持久性塊存儲功能(Nova-Volume)分離了出來,獨立為新的組件Cinder
swift是一個系統,可以上傳和下載,裡面一般存儲的是不經常修改的內容,比如用於存儲 VM 鏡像、備份和歸檔以及較小的文件,例如照片和電子郵件消息。更傾向於系統的管理
塊存儲具有安全可靠、高並發大吞吐量、低時延、規格豐富、簡單易用的特點,適用於文件系統、資料庫或者其他需要原始塊設備的系統軟體或應用。
上面其實很多感覺不是太直觀,個人認為cinder可以理解為個人電腦的移動硬碟,它可以隨意格式化,隨時存取。
對於swift可以作為網盤,相信對於雲技術的同學來說,網盤應該是不陌生的,如果把一些經常用的內容,放到網盤中是非常不方便的。
Swift 還是 Cinder?何時使用以及使用哪一種?
那麼,應該使用哪一種對象存儲:Swift 還是 Cinder?答案取決於您的應用程序。如果需要運行商用或遺留應用程序,那麼很少需要進行這種選擇。這些應用程序不可能被編碼來利用 Swift API,但您可以輕松掛載一個 Cinder 磁碟,它表現得就像是直接將存儲附加到大多數應用程序。
當然,您還可以對新應用程序使用 Cinder,但是不會從 Swift 自動附帶的彈性和冗餘中獲益。如果編程人員面對這樣的挑戰,那麼 Swift 的分布式可擴展架構是一個值得考慮的特性。
單點故障
Swift 架構是分布式的,可防止所有單點故障和進行水平擴展。
cinder存在單點故障還未解決
更多內容,以下來自ibm資料庫:
塊存儲 (Cinder)
Cinder 是 OpenStack Block Storage 的項目名稱;它為來賓虛擬機 (VM) 提供了持久塊存儲。對於可擴展的文件系統、最大性能、與企業存儲服務的集成以及需要訪問原生塊級存儲的應用程序而言,塊存儲通常是必需的。
系統可以暴露並連接設備,隨後管理伺服器的創建、附加到伺服器和從伺服器分離。應用程序編程介面 (API) 也有助於加強快照管理,這種管理可以備份大量塊存儲。
對象存儲 (Swift)
Swift 是兩種產品中較為成熟的一個:自 OpenStack 成立以來一直是一個核心項目。Swift 的功能類似於一個分布式、可訪問 API 的存儲平台,可直接將它集成到應用程序中,或者用於存儲 VM 鏡像、備份和歸檔以及較小的文件,例如照片和電子郵件消息。
Object Store 有兩個主要的概念:對象和容器。
對象就是主要存儲實體。對象中包括與 OpenStack Object Storage 系統中存儲的文件相關的內容和所有可選元數據。數據保存為未壓縮、未加密的格式,包含對象名稱、對象的容器以及鍵值對形式的所有元數據。對象分布在整個數據中心的多個磁碟中,Swift 可以藉此確保數據的復制和完整性。分布式操作可以利用低成本的商用硬體,同時增強可擴展性、冗餘性和持久性。
容器類似於 Windows® 文件夾,容器是用於存儲一組文件的一個存儲室。容器無法被嵌套,但一個租戶可以供創建無限數量的容器。對象必須存儲在容器中,所以您必須至少擁有一個容器來使用對象存儲。
與傳統的文件伺服器不同,Swift 是橫跨多個系統進行分布的。它會自動存儲每個對象的冗餘副本,從而最大程度地提高可用性和可擴展性。對象版本控制提供了防止數據意外丟失或覆蓋的額外保護
希望對你有幫助
H. 如何在Swift 中使用AFNetworking
在工程中隨便創建一個類,選擇語言OC,我們會發現工程中會多出來一個SwiftStudy-Bridging-Header.h文件,刪除創建的oc類,在這里引入
/**
RequestClient.sharedInstance.requestSerializer=AFJSONRequestSerializer()
RequestClient.sharedInstance.responseSerializer=AFJSONResponseSerializer()
RequestClient.sharedInstance.requestSerializer.setValue("application/json,text/html",forHTTPHeaderField:"Accept")
RequestClient.sharedInstance.requestSerializer.setValue("application/json;charset=utf-8",forHTTPHeaderField:"Content-Type")
*/