云計算架構(gòu)主要可分為四層,其中有三層是橫向的,分別是顯示層、中間件層和基礎設施層,通過這三層技術能夠提供非常豐富的云計算能力和友好的用戶界面,還有一層是縱向的,稱為管理層,是為了更好地管理和維護橫向的三層而存在的。下面介紹每個層次的作用和屬于這個層次的主要技術。
為懷安等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及懷安網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站制作、做網(wǎng)站、懷安網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
顯示層
這層主要是用于以友好的方式展現(xiàn)用戶所需的內(nèi)容,并會利用到下面中間件層提供的多種服務,主要有五種技術:
HTML:標準的Web頁面技術,現(xiàn)在主要以HTML4為主,但是將要推出的HTML5會在很多方面推動Web頁面的發(fā)展,比如視頻和本地存儲等方面。
JavaScript:一種用于Web頁面的動態(tài)語言,通過JavaScript,能夠極大地豐富Web頁面的功能,最流行的JS框架有jQuery和Prototype。
CSS:主要用于控制Web頁面的外觀,而且能使頁面的內(nèi)容與其表現(xiàn)形式之間進行優(yōu)雅地分離。
Flash:業(yè)界最常用的RIA(Rich Internet Applications)技術,能夠在現(xiàn)階段提供HTML等技術所無法提供的基于Web的富應用,而且在用戶體驗方面,非常不錯。
Silverlight:來自業(yè)界巨擎微軟的RIA技術,雖然其現(xiàn)在市場占有率稍遜于Flash,但由于其可以使用C#來進行編程,所以對開發(fā)者非常友好。
在顯示層,大多數(shù)云計算產(chǎn)品都比較傾向HTML,、JavaScript和CSS這對黃金組合,但是Flash和Silverlight等RIA技 術也有一定的用武之地,比如VMware vCloud就采用了基于Flash的Flex技術,而微軟的云計算產(chǎn)品肯定會在今后使用到Silverlight。
中間件層
這層是承上啟下的,它在下面的基礎設施層所提供資源的基礎上提供了多種服務,比如緩存服務和REST服務等,而且這些服務即可用于支撐顯示層,也可以直接讓用戶調(diào)用,并主要有五種技術:
REST:通過REST技術,能夠非常方便和優(yōu)雅地將中間件層所支撐的部分服務提供給調(diào)用者。
多租戶:就是能讓一個單獨的應用實例可以為多個組織服務,而且保持良好的隔離性和安全性,并且通過這種技術,能有效地降低應用的購置和維護成本。
并行處理:為了處理海量的數(shù)據(jù),需要利用龐大的X86集群進行規(guī)模巨大的并行處理,Google的MapReduce是這方面的代表之作。
應用服務器:在原有的應用服務器的基礎上為云計算做了一定程度的優(yōu)化,比如用于Google App Engine的Jetty應用服務器。
分布式緩存:通過分布式緩存技術,不僅能有效地降低對后臺服務器的壓力,而且還能加快相應的反應速度,最著名的分布式緩存例子莫過于Memcached。
對于很多PaaS平臺,比如用于部署Ruby應用的Heroku云平臺,應用服務器和分布式緩存都是必備的,同時REST技術也常用于對外的接口, 多租戶技術則主要用于SaaS應用的后臺,比如用于支撐Salesforce的Sales Cloud等應用的Force.com多租戶內(nèi)核,而并行處理技術常被作為單獨的服務推出,比如Amazon的Elastic MapReduce。
基礎設施層
這層作用是為給上面的中間件層或者用戶準備其所需的計算和存儲等資源,主要有四種技術:
虛擬化:也可以理解它為基礎設施層的“多租戶”,因為通過虛擬化技術,能夠在一個物理服務器上生成多個虛擬 機,并且能在這些虛擬機之間能實現(xiàn)全面的隔離,這樣不僅能減低服務器的購置成本,而且還能同時降低服務器的運維成本,成熟的X86虛擬化技術有 VMware的ESX和開源的Xen。
分布式存儲:為了承載海量的數(shù)據(jù),同時也要保證這些數(shù)據(jù)的可管理性,所以需要一整套分布式的存儲系統(tǒng),在這方面,Google的GFS是典范之作。
關系型數(shù)據(jù)庫:基本是在原有的關系型數(shù)據(jù)庫的基礎上做了擴展和管理等方面的優(yōu)化,使其在云中更適應。
NoSQL:為了滿足一些關系數(shù)據(jù)庫所無法滿足的目標,比如支撐海量的數(shù)據(jù)等,一些公司特地設計一批不是基于關系模型的數(shù)據(jù)庫,比如Google的BigTable和Facebook的Cassandra等。
現(xiàn)在大多數(shù)的IaaS服務都是基于Xen的,比如Amazon的EC2等,但VMware也推出了基于ESX技術的vCloud,同時業(yè)界也有幾個 基于關系型數(shù)據(jù)庫的云服務,比如Amazon的RDS(Relational Database Service)和Windows Azure SDS(SQL Data Services)等。關于分布式存儲和NoSQL,它們已經(jīng)被廣泛用于云平臺的后端,比如Google App Engine的Datastore就是基于BigTable和GFS這兩個技術之上的,而Amazon則推出基于NoSQL技術的Simple DB。
管理層
這層是為橫向的三層服務的,并給這三層提供多種管理和維護等方面的技術,主要有下面這六個方面:
帳號管理:通過良好的帳號管理技術,能夠在安全的條件下方便用戶地登錄,并方便管理員對帳號的管理。
SLA監(jiān)控:對各個層次運行的虛擬機,服務和應用等進行性能方面的監(jiān)控,以使它們都能在滿足預先設定的SLA(Service Level Agreement)的情況下運行。
計費管理:也就是對每個用戶所消耗的資源等進行統(tǒng)計,來準確地向用戶索取費用。
安全管理:對數(shù)據(jù),應用和帳號等IT資源采取全面地保護,使其免受犯罪分子和惡意程序的侵害。
負載均衡:通過將流量分發(fā)給一個應用或者服務的多個實例來應對突發(fā)情況。 運維管理:主要是使運維操作盡可能地專業(yè)和自動化 ,從而降低云計算中心成本。
負載均衡:通過將流量分發(fā)給一個應用或者服務的多個實例來應對突發(fā)情況。
運維管理:主要是使運維操作盡可能地專業(yè)和自動化,從而降低云計算中心的運維成本。
現(xiàn)在的云計算產(chǎn)品在帳號管理,計費管理和負載均衡這三個方面大都表現(xiàn)地不錯,在這方面最突出的例子就是Amazon 的EC2,但可惜的是,大多數(shù)產(chǎn)品在SLA監(jiān)控,安全管理和運維管理等方面還有所欠缺。
舉例
接下來,將以Salesforce的Sales Cloud和Google的App Engine這兩個著名的云計算產(chǎn)品為例,來幫助大家理解本文所提到的云計算架構(gòu):
Salesforce Sales Cloud
也就是之前的Salesforce CRM(客戶關系管理),屬于云計算中的SaaS層,主要是通過在云中部署可定制化的CRM應用,來讓企業(yè)用戶在很低初始投入的情況下使用上CRM,并且 可根據(jù)自身的流程來進行靈活地定制,而且只需接入網(wǎng)絡就能使用。在技術層面上大致的架構(gòu):
采用的主要技術:
顯示層:基于HTML、JavaScript和CSS這對黃金組合。
中間件層:在此層,Salesforce引入了多租戶內(nèi)核和為支撐此內(nèi)核運行而經(jīng)過定制的應用服務器。
基礎設施層:雖然在后端還是使用在企業(yè)環(huán)境中很常見的Oracle數(shù)據(jù)庫,但是其為了支撐上層的多租戶內(nèi)核做了很多的優(yōu)化。
管理層:在安全管理方面,Salesforce提供了多層保護,并支持SSL加密等技術,除此之外,其還在帳號管理、計費管理和負載均衡這三方面有不錯地支持。
Google App Engine
App Engine屬于云計算中的PaaS層,其主要提供一個平臺,來讓用戶在Google強大的基礎設施上部署和運行應用程序,同時App Engine會根據(jù)應用所承受的負載來對應用所需的資源進行調(diào)整,并免去用戶對應用和服務器等的維護工作,而且支持Java和Python這兩種語言。由 于App Engine屬于PaaS平臺,所以關于顯示層的技術選擇由應用的自身需要而定,與App Engine無關,關于App Engine在技術層面上大致的架構(gòu)。
采用的主要技術:
中間件層:既有經(jīng)過定制化的應用服務器,比如上面已經(jīng)提到過的Jetty,也提供基于Memcached的分布式緩存服務。
基礎設施層: 在分布式存儲GFS的基礎上提供了NoSQL數(shù)據(jù)庫BigTable來對應用的數(shù)據(jù)進行持久化。
管理層:由于App Engine是基于Google強大的分布式基礎設施,使其在運維管理技術方面非常出色,同時其計費管理能做到非常細粒度的API級計費,而且App Engine在帳號管理和負載均衡這兩方面都有非常好地支持。
以上內(nèi)容分析源自OFweek物聯(lián)網(wǎng),希望對大家有幫助。
這里是我用的代碼,估計對你有用:
'On Error Resume Next
Dim fileadd As String
CommonDialog1.ShowOpen
CommonDialog1.Filter = "xls文件(*.xls)|*.xls" '選擇你要的文件
fileadd = CommonDialog1.FileName
If fileadd = "" Then Exit Sub
Set xlApp = CreateObject("Excel.Application") '創(chuàng)建EXCEL對象
Set xlBook = xlApp.Workbooks.Open(fileadd) '打開已經(jīng)存在的EXCEL工件簿文件
xlApp.Visible = False ' = True '設置EXCEL對象可見(或不可見)
Set xlSheet = xlBook.Worksheets(1) '設置活動工作表
For R = 1 To 99999 '行循環(huán)
If LTrim(RTrim(xlBook.Worksheets(1).Cells(R, 1))) "" Then
sybw.Adodc3.Refresh
sybw.Adodc3.Recordset.Find "ShiGongBuWei_Name='" LTrim(RTrim(xlBook.Worksheets(1).Cells(R, 1))) "'"
If sybw.Adodc3.Recordset.EOF Then
sybw.Adodc3.Recordset.AddNew
sybw.Adodc3.Recordset!ShiGongBuWei_Name = LTrim(RTrim(xlBook.Worksheets(1).Cells(R, 1)))
sybw.Adodc3.Recordset!FenXiangGongCheng_ID = bb
sybw.Adodc3.Recordset.Update
sybw.Adodc3.Refresh
' Call log(MM_Users_NameTrue, "增加了施工部位", MM_Companys_ID)
Else
' MsgBox " 施工部位重復! ", vbOKOnly, "用戶信息"
End If
Else
R = 99999 + 1
End If
Next R
xlApp.DisplayAlerts = False '不進行安全提示 '
Set xlSheet = Nothing '
Set xlBook = Nothing '
xlApp.Quit '
Set xlApp = Nothing
VB.NET中有控件可以真接接點擊屬性進行連接配置.
SqlConnect數(shù)據(jù)連接控件.點擊ConnectionString屬性進行配置就可以了.
VB.NET中沒有RecordSet了.取而代之的是DataSet.
在VB.net中可以先用SqlConnection對像來連接數(shù)據(jù)庫再用SqlDataAdapter對像來讀取數(shù)據(jù)并填充到DataSet里.然后就可以進行數(shù)據(jù)綁定了.
例:
dim
conn
as
SqlConnection
dim
da
as
SqlDataAdapter
dim
ds
as
Dataset
set
conn
=
new
SqlConnection
conn.ConnectionString="server=serverIP;database=databasename;uid=userid;pwd=password";
conn.open
da
=
new
SqlDataAdapter
(,conn)
da.fill(ds)
可以做一個類庫,用xml調(diào)用
using
System.Data.Sqlcolint;
using
System.Xml;
咨詢通過讀取xml文件連接sqlserver數(shù)據(jù)庫的問題
懸賞分:20
-
提問時間2007-11-6
16:34
我的問題:
1。連接數(shù)據(jù)庫方式是個類庫(做成dll文件)
2。連接數(shù)據(jù)庫的登錄名密碼等字符串是從config.xml中讀取
3。是從類庫中讀取還是從別的地方讀取config.xml?因為在類庫中有個連接數(shù)據(jù)庫的語句。
4。如果連接數(shù)據(jù)庫的密碼錯誤,會自動提示連接錯誤,然后彈出個小窗口,修改config.xml中的數(shù)據(jù)庫密碼等,然后保存。這個步驟在哪里寫?
===================================================================================================================
我的部分代碼:
1。連接數(shù)據(jù)庫的類庫:
Imports
System.data.sqlclient
Public
Class
DB
'sCon為連接字符串
Private
sCon
As
String
=
"User
ID=sa;Initial
Catalog=dbname;Data
Source=(local)
"
Public
Function
GetDataTable(ByVal
strSql
As
String)
As
DataTable
Dim
myDt
As
New
DataTable
Dim
sqlConn
As
SqlConnection
=
New
SqlConnection(sCon)
Dim
myCmd
As
SqlCommand
=
New
SqlCommand(strSql,
sqlConn)
Dim
myDa
As
New
SqlDataAdapter(strSql,
sqlConn)
Try
myDa.Fill(myDt)
Catch
er
As
Exception
Finally
sqlConn.Close()
End
Try
Return
myDt
End
Function
End
Class
public
Void
ReaderXML(string
URL)//URL是XML文件的路徑
{
DataSet
ds
=
new
DataSet();
ds.ReaderXml("URL");
//下面就是把這個數(shù)據(jù)集存到數(shù)據(jù)庫里面
}