在2007年,GlusterFS演變?yōu)榇笮头植际酱鎯Ψ桨负?,任何配備合適硬件的公司,單位都可以利用個做分布式的流媒體,數(shù)據(jù)分析。在2011年,Red Hat收購了GlusterFS.
為紅花崗等地區(qū)用戶提供了全套網頁設計制作服務,及紅花崗網站建設行業(yè)解決方案。主營業(yè)務為成都網站制作、成都做網站、紅花崗網站設計,以傳統(tǒng)方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
Minio是GlusterFS創(chuàng)始人之一Anand Babu Periasamy發(fā)布新的開源項目。Minio兼容Amason的S3分布式對象存儲項目,采用Golang實現(xiàn),客戶端支持Java,Python,Javacript, Golang語言。
Minio 提供對象存儲服務,兼容了 AWS S3 存儲協(xié)議,用于非結構化的數(shù)據(jù)存。非結構化對象,比如圖像,音、視頻,日志文件,備份鏡像…等等管理不方便,不定長,大小變化大、類型多,云端的訪問復雜,minio就是來解決這種場景的。非結構化的文件從數(shù)KB到5TB都能很好的支持。開源并且用 Go 語言開發(fā),有web操作界面,我們可以用它來搭建兼容S3協(xié)議的存儲云服務。
Minio可以做為云存儲的解決方案用來保存海量的圖片,視頻,文檔。由于采用Golang實現(xiàn),服務端可以工作在Windows,Linux, OS X和FreeBSD上。配置簡單,基本是復制可執(zhí)行程序,單行命令可以運行起來。
官網:
那么,如何自己搭建一個私有的S3存儲云服務呢?
官方的話是推薦用Docker來搞,我們先用普通的二進制文件來直接解決了!
######################################################################################
# mkdir /data/aws_s3
# wget??
# mv??minio /usr/local/bin/
# ?chmod ?755 ?/usr/local/bin/minio?
#?minio server ?/data/aws_s3
#############################################################
Created minio configuration file successfully at /root/.minio
Endpoint: ? ?
AccessKey: U3XLU4IMXY3IDKHU268F?
SecretKey: /6NCL6HGacviaCgRqr2qLbVOjhkkJdRpV7wz0JJD?
Region: ? ?us-east-1
SQS ARNs: ?
Browser Access:
Command-line Access:?
################################################################
$ mc config host add myminio? ?U3XLU4IMXY3IDKHU268F /6NCL6HGacviaCgRqr2qLbVOjhkkJdRpV7wz0JJD
Object API (Amazon S3 compatible):
Go:?
Java:?
Python:?
JavaScript:?
Drive Capacity: 8.3 GiB Free, 9.1 GiB Total
##############################################################
我們就成功啟動了minio的s3服務,默認端口9000,可以通過網頁訪問:
注意 :第一次打開時候需要填寫AccessKey和SecretKey才能進入,我們上面啟動服務的時候,已經看到屏幕有輸出:
AccessKey:?U3XLU4IMXY3IDKHU268F?
SecretKey:6NCL6HGacviaCgRqr2qLbVOjhkkJdRpV7wz0JJD
把這兩個Key填入,就能順利進入,進入后展開頁面如下:
這就是我們的S3云存儲的管理頁面了,看著是不是和七牛什么的提供云存儲的產品頁面挺像的,大家都是基于S3協(xié)議開發(fā)的!
上傳個文件試試:
點擊右下角的紅色小加號按鈕,彈出的菜單選擇”create bucket”則會創(chuàng)建一個桶,輸入名字”test”
點擊剛才那個紅色小加號按鈕,這次選擇”Upload file”上傳文件,給這個桶上傳了一個叫l(wèi)ogin.txt的文本文檔
此時頁面如下:
至此我們可以看到文件已經上傳,要訪問這個文件,可以點擊文件右側的三個點的按鈕,選擇分享就可以得到一個外鏈,在瀏覽器中訪問這個外鏈就可以直接訪問文件。
那么文件到底被存到哪里去了呢,我們啟動命令中其實指定了工作路徑/data/aws_s3/,所以到服務器這個目錄下看看:
# ls /data/aws_s3/?
test
# ls /data/aws_s3/test/
login.txt?
桶名稱test是一個目錄,其下就有上傳的login.txt文件。
如果想指定ip和端口,可以這樣寫:
# minio server /data/aws_s3?--address=0.0.0.0:9000
如果想讓服務在后臺運行:
#?nohup?minio server /data/aws_s3 ? --address=0.0.0.0:443?
[1] 19882
// nohup: 忽略輸入并把輸出追加到啟動命令的當前目錄下的 "nohup.out"文件
minio可以用來搭建分布式存儲系統(tǒng) GlusterFS,這樣就成了真正的云存儲了,有時間再研究下把它從現(xiàn)在的單機測試,變成一朵存儲云!
minio官網:
minio官方文檔:
minio github主頁:
1.Docker項目
網址為 。
介紹:Docker是一種操作系統(tǒng)層面的虛擬化技術,可以在操作系統(tǒng)和應用程序之間進行隔離,也可以稱之為容器。Docker可以在一臺物理服務器上快速運行一個或多個實例。例如,啟動一個Cent OS操作系統(tǒng),并在其內部命令行執(zhí)行指令后結束,整個過程就像自己在操作系統(tǒng)一樣高效。
2.golang項目
網址為 。
介紹:Go語言的早期源碼使用C語言和匯編語言寫成。從Go 1.5版本自舉后,完全使用Go語言自身進行編寫。Go語言的源碼對了解Go語言的底層調度有極大的參考意義,建議希望對Go語言有深入了解的讀者讀一讀。
3.Kubernetes項目
網址為 。
介紹:Google公司開發(fā)的構建于Docker之上的容器調度服務,用戶可以通過Kubernetes集群進行云端容器集群管理。
4.etcd項目
網址為 。
介紹:一款分布式、可靠的KV存儲系統(tǒng),可以快速進行云配置。
5.beego項目
網址為 。
介紹:beego是一個類似Python的Tornado框架,采用了RESTFul的設計思路,使用Go語言編寫的一個極輕量級、高可伸縮性和高性能的Web應用框架。
6.martini項目
網址為 。
介紹:一款快速構建模塊化的Web應用的Web框架。
7.codis項目
網址為 Labs/codis。
介紹:國產的優(yōu)秀分布式Redis解決方案。
8.delve項目
網址為 。
介紹:Go語言強大的調試器,被很多集成環(huán)境和編輯器整合。
分布式存儲架構由三個部分組成:客戶端、元數(shù)據(jù)服務器和數(shù)據(jù)服務器。客戶端負責發(fā)送讀寫請求,緩存文件元數(shù)據(jù)和文件數(shù)據(jù)。元數(shù)據(jù)服務器負責管理元數(shù)據(jù)和處理客戶端的請求,是整個系統(tǒng)的核心組件。數(shù)據(jù)服務器負責存放文件數(shù)據(jù),保證數(shù)據(jù)的可用性和完整性。該架構的好處是性能和容量能夠同時拓展,系統(tǒng)規(guī)模具有很強的伸縮性。
對象存儲最常用的方案,就是多臺服務器內置大容量硬盤,再裝上對象存儲軟件,然后再額外搞幾臺服務作為管理節(jié)點,安裝上對象存儲管理軟件。管理節(jié)點可以管理其他服務器對外提供讀寫訪問功能。
之所以出現(xiàn)了對象存儲這種東西,是為了克服塊存儲與文件存儲各自的缺點,發(fā)揚它倆各自的優(yōu)點。簡單來說塊存儲讀寫快,不利于共享,文件存儲讀寫慢,利于共享。能否弄一個讀寫快,利 于共享的出來呢。于是就有了對象存儲。
《Go 語言程序設計》(Mark Summerfield)電子書網盤下載免費在線閱讀
資源鏈接:
鏈接:
提取碼: kh78 ?
書名:Go 語言程序設計
作者:Mark Summerfield
譯者:許式偉
豆瓣評分:6.9
出版社:人民郵電出版社
出版年份:2013-8-1
頁數(shù):354
內容簡介:
國外最經典的Go語言著作,Go語言編程的先驅者Mark Summerfield的實踐經驗總結。
這是一本Go語言實戰(zhàn)指南,幫你了解Go語言,按Go語言的方式思考,以及使用Go語言來編寫高性能軟件。
作者展示了如何編寫充分利用Go語言突破性的特性和慣用法的代碼,以及Go語言在其他語言之上所做的改進,并著重強調了Go語言的關鍵創(chuàng)新。
注重實踐教學,每章都提供了多個經過精心設計的代碼示例。
由國內第一個核心服務完全采用Go語言實現(xiàn)的團隊——七牛團隊核心成員翻譯。
作者簡介:
Mark Summerfield Qtrac公司創(chuàng)始人,獨立的培訓講師、顧問、技術編輯,Go、Python、C++、Qt和PyQt方面的技術作家。他的著作包括Rapid GUI Programming with Python and Qt、C++ GUI Programming with Qt 4(與Jasmin Blanchette合著)、Programming in Python 3和Advanced Qt Programming等。
許式偉——七牛云存儲CEO,開源愛好者,發(fā)布過十余個C++開源項目,擁有超過15年的C/C++開發(fā)經驗。
呂桂華——七牛云存儲聯(lián)合創(chuàng)始人,擁有十余年的C/C++大型項目開發(fā)經驗,也曾在Java和.NET平臺上探索多年。
徐 立——七牛云存儲首席布道師,前盛大創(chuàng)新院高級研究員。
何李石——七牛云存儲布道師。
七牛云存儲技術團隊是國內第一個核心服務完全采用Go語言實現(xiàn)的團隊。