數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理_第1頁
數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理_第2頁
數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理_第3頁
數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理_第4頁
數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理_第5頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

數(shù)據(jù)分析工具:Presto:Presto架構(gòu)與工作原理1Presto概述1.1Presto的歷史與發(fā)展Presto是一款開源的分布式SQL查詢引擎,由Facebook在2012年開發(fā)并首次使用,隨后在2013年11月作為開源項目發(fā)布。它的設(shè)計初衷是為了處理大規(guī)模的數(shù)據(jù)查詢,能夠在不同的數(shù)據(jù)源之間進行高效的數(shù)據(jù)分析。Presto的出現(xiàn),解決了傳統(tǒng)數(shù)據(jù)倉庫和大數(shù)據(jù)處理框架(如Hadoop和Spark)在查詢性能和數(shù)據(jù)源靈活性上的局限性。1.1.1發(fā)展歷程2012年:Facebook內(nèi)部開始使用Presto,以解決其數(shù)據(jù)查詢的性能瓶頸。2013年11月:Facebook將Presto開源,吸引了眾多企業(yè)和開發(fā)者的關(guān)注。2015年:Presto項目從Facebook分離出來,成立了Presto基金會,進一步推動了Presto的發(fā)展和社區(qū)的壯大。2019年:PrestoSQL項目從Presto基金會中分離,旨在提供一個更加穩(wěn)定和兼容的SQL查詢引擎版本。1.2Presto的特點與優(yōu)勢Presto以其獨特的架構(gòu)和高效的數(shù)據(jù)處理能力,在大數(shù)據(jù)分析領(lǐng)域占據(jù)了一席之地。以下是Presto的幾個顯著特點和優(yōu)勢:1.2.1特點分布式查詢引擎:Presto能夠并行處理大規(guī)模數(shù)據(jù)集,通過將查詢?nèi)蝿?wù)分解到多個節(jié)點上執(zhí)行,大大提高了查詢速度。多數(shù)據(jù)源支持:Presto可以查詢多種數(shù)據(jù)源,包括HadoopHDFS、Hive、Cassandra、MongoDB、AmazonS3、RDBMS等,這使得數(shù)據(jù)分析師能夠在不同的數(shù)據(jù)存儲之間無縫切換,進行統(tǒng)一的數(shù)據(jù)分析。低延遲查詢:Presto能夠在幾秒鐘內(nèi)返回查詢結(jié)果,即使是在PB級別的數(shù)據(jù)集上,這使得它非常適合實時分析和交互式查詢場景。1.2.2優(yōu)勢高性能:Presto采用了先進的查詢優(yōu)化技術(shù),如動態(tài)規(guī)劃、并行執(zhí)行和內(nèi)存管理,能夠在短時間內(nèi)處理大量數(shù)據(jù)。靈活性:Presto的插件架構(gòu)允許用戶輕松地添加新的數(shù)據(jù)源和數(shù)據(jù)格式,這極大地擴展了其應(yīng)用范圍。易于使用:Presto支持標(biāo)準的SQL語法,使得數(shù)據(jù)分析師和數(shù)據(jù)科學(xué)家能夠快速上手,無需學(xué)習(xí)復(fù)雜的API或編程語言。1.2.3示例:PrestoSQL查詢假設(shè)我們有一個存儲在Hive中的數(shù)據(jù)表sales,包含product_id、sale_date和amount等字段。下面是一個使用Presto查詢特定產(chǎn)品在特定日期范圍內(nèi)的總銷售額的例子:--連接到Presto并選擇Hive作為數(shù)據(jù)源

Presto>USEhive;

--查詢產(chǎn)品ID為12345在2022年1月1日至2022年1月31日的總銷售額

Presto>SELECTSUM(amount)

FROMsales

WHEREproduct_id=12345

ANDsale_dateBETWEEN'2022-01-01'AND'2022-01-31';在這個例子中,我們首先選擇了Hive作為數(shù)據(jù)源,然后使用SQL語句查詢了特定產(chǎn)品在特定日期范圍內(nèi)的銷售總額。Presto能夠快速地處理這個查詢,并返回結(jié)果。Presto的這些特點和優(yōu)勢使其成為大數(shù)據(jù)分析領(lǐng)域中一個非常有吸引力的選擇,無論是對于需要處理大規(guī)模數(shù)據(jù)的公司,還是對于希望進行實時數(shù)據(jù)分析的個人用戶,Presto都能提供強大的支持。2Presto架構(gòu)詳解2.1Presto的組件介紹Presto是一個開源的分布式SQL查詢引擎,設(shè)計用于處理大規(guī)模數(shù)據(jù)集,支持多種數(shù)據(jù)源。其架構(gòu)主要由以下幾個關(guān)鍵組件構(gòu)成:2.1.1Coordinator功能:協(xié)調(diào)器負責(zé)接收客戶端的查詢請求,解析SQL語句,生成執(zhí)行計劃,并將計劃分發(fā)給各個Worker節(jié)點。組件:包括QueryManager和Scheduler。QueryManager:管理查詢的生命周期,包括查詢的提交、執(zhí)行和取消。Scheduler:負責(zé)調(diào)度查詢計劃,確定哪些Worker節(jié)點將執(zhí)行哪些任務(wù)。2.1.2Worker功能:Worker節(jié)點執(zhí)行由Coordinator分發(fā)的查詢?nèi)蝿?wù),處理數(shù)據(jù)并返回結(jié)果。組件:包括TaskManager和ExecutionEngine。TaskManager:管理Worker節(jié)點上的任務(wù)執(zhí)行。ExecutionEngine:實際執(zhí)行查詢計劃,處理數(shù)據(jù)。2.1.3Connector功能:Connector是Presto與不同數(shù)據(jù)源之間的橋梁,支持如Hive、Cassandra、MySQL等多種數(shù)據(jù)源。組件:包括Metadata和SplitManager。Metadata:提供數(shù)據(jù)源的元數(shù)據(jù)信息,如表結(jié)構(gòu)、列信息等。SplitManager:負責(zé)將數(shù)據(jù)源的數(shù)據(jù)切分為多個Split,以便Worker節(jié)點并行處理。2.2查詢處理流程Presto的查詢處理流程可以分為以下幾個步驟:客戶端提交查詢:客戶端通過HTTP接口向Coordinator提交SQL查詢。解析與優(yōu)化:Coordinator解析SQL語句,生成邏輯查詢計劃,然后進行優(yōu)化,生成物理查詢計劃。計劃調(diào)度:Coordinator將物理查詢計劃分發(fā)給Worker節(jié)點,由Scheduler確定每個Worker節(jié)點執(zhí)行的任務(wù)。任務(wù)執(zhí)行:Worker節(jié)點上的TaskManager接收任務(wù),由ExecutionEngine執(zhí)行。結(jié)果匯總:Worker節(jié)點將處理結(jié)果返回給Coordinator,Coordinator匯總結(jié)果并返回給客戶端。2.2.1示例代碼假設(shè)我們有一個Hive數(shù)據(jù)源,下面是一個使用Presto查詢Hive數(shù)據(jù)的示例:--連接到Presto并選擇Hive數(shù)據(jù)源

Presto>USEhive;

--查詢Hive中的數(shù)據(jù)

Presto>SELECT*FROMdefault.salesLIMIT10;2.3分布式執(zhí)行機制Presto的分布式執(zhí)行機制是其能夠高效處理大規(guī)模數(shù)據(jù)的關(guān)鍵。它通過以下方式實現(xiàn):數(shù)據(jù)切分:Connector的SplitManager將數(shù)據(jù)源的數(shù)據(jù)切分為多個Split,每個Split可以由一個Worker節(jié)點處理。并行處理:Worker節(jié)點并行處理分配給它們的Split,加速查詢執(zhí)行。結(jié)果聚合:Worker節(jié)點將處理結(jié)果返回給Coordinator,Coordinator進行結(jié)果的聚合和排序,最終返回給客戶端。2.3.1示例代碼下面是一個展示Presto如何處理分布式數(shù)據(jù)的示例查詢:--假設(shè)我們有多個數(shù)據(jù)源,如Hive和Cassandra

Presto>SELECT*FROMhive.salesJOINductsONduct_id=products.idLIMIT10;在這個查詢中,Presto會將Hive和Cassandra的數(shù)據(jù)源切分為多個Split,然后分配給不同的Worker節(jié)點進行并行處理。最后,Coordinator會匯總所有Worker節(jié)點的處理結(jié)果,返回給客戶端。通過上述組件和流程的介紹,我們可以看到Presto如何通過其獨特的架構(gòu)設(shè)計,實現(xiàn)對大規(guī)模數(shù)據(jù)集的高效查詢和處理。3Presto的工作原理3.1SQL查詢解析Presto在接收到SQL查詢后,首先會進行查詢解析。這一過程包括了語法分析和語義分析,確保SQL語句的正確性和可行性。語法分析器會檢查SQL語句是否符合SQL標(biāo)準語法,而語義分析則進一步檢查查詢的邏輯是否正確,例如表和列是否存在,權(quán)限是否足夠等。3.1.1示例代碼#假設(shè)我們使用Python的Presto客戶端來執(zhí)行SQL查詢

fromprestodb.dbapiimportconnect

#連接Presto

conn=connect(

host='localhost',

port=8080,

user='user',

catalog='hive',

schema='default'

)

#創(chuàng)建游標(biāo)

cur=conn.cursor()

#執(zhí)行SQL查詢

query="""

SELECTcolumn1,column2

FROMtable_name

WHEREcolumn1>100

"""

cur.execute(query)

#獲取查詢結(jié)果

results=cur.fetchall()

forrowinresults:

print(row)在上述代碼中,我們通過Python的Presto客戶端連接到Presto服務(wù)器,并執(zhí)行一個簡單的SQL查詢。查詢解析確保了column1和column2是table_name中存在的列,且用戶有權(quán)限訪問hive目錄下的default模式。3.2數(shù)據(jù)源插件與連接器Presto的設(shè)計允許它連接到多種數(shù)據(jù)源,這得益于其插件和連接器架構(gòu)。數(shù)據(jù)源插件(如Hive、Cassandra、MySQL等)提供了與特定數(shù)據(jù)存儲系統(tǒng)交互的接口,而連接器則實現(xiàn)了這些插件與Presto核心的連接,使得Presto能夠讀取和處理來自不同數(shù)據(jù)源的數(shù)據(jù)。3.2.1示例代碼#使用Presto連接到Hive數(shù)據(jù)源

conn=connect(

host='localhost',

port=8080,

user='user',

catalog='hive',

schema='default'

)

#執(zhí)行SQL查詢,從Hive中讀取數(shù)據(jù)

query="""

SELECT*FROMhive_table

"""

cur=conn.cursor()

cur.execute(query)

#獲取查詢結(jié)果

results=cur.fetchall()

forrowinresults:

print(row)此代碼示例展示了如何使用Presto連接到Hive數(shù)據(jù)源,并執(zhí)行SQL查詢來讀取數(shù)據(jù)。hive_table是Hive中的一個表,通過Presto的Hive插件和連接器,我們可以直接使用SQL語句來訪問和分析Hive中的數(shù)據(jù)。3.3數(shù)據(jù)讀取與處理Presto在讀取數(shù)據(jù)時,會根據(jù)查詢的需要從多個數(shù)據(jù)源中并行讀取數(shù)據(jù)。數(shù)據(jù)處理則通過執(zhí)行計劃(ExecutionPlan)進行,該計劃由查詢優(yōu)化器生成,以最有效的方式執(zhí)行查詢。Presto支持多種數(shù)據(jù)處理操作,包括但不限于聚合、排序、連接等。3.3.1示例代碼#使用Presto執(zhí)行一個涉及數(shù)據(jù)處理的SQL查詢

conn=connect(

host='localhost',

port=8080,

user='user',

catalog='hive',

schema='default'

)

#執(zhí)行SQL查詢,包括聚合操作

query="""

SELECTcolumn1,AVG(column2)

FROMhive_table

GROUPBYcolumn1

"""

cur=conn.cursor()

cur.execute(query)

#獲取查詢結(jié)果

results=cur.fetchall()

forrowinresults:

print(row)在這個示例中,我們使用Presto執(zhí)行了一個SQL查詢,該查詢不僅從hive_table中讀取數(shù)據(jù),還進行了數(shù)據(jù)處理,具體是按column1進行分組,并計算column2的平均值。Presto的執(zhí)行計劃會優(yōu)化這一過程,確保數(shù)據(jù)讀取和處理的效率。通過上述模塊的詳細解析,我們可以看到Presto如何通過SQL查詢解析、數(shù)據(jù)源插件與連接器、以及數(shù)據(jù)讀取與處理這三個關(guān)鍵步驟,實現(xiàn)了高效的數(shù)據(jù)分析能力。4Presto的性能優(yōu)化4.1查詢優(yōu)化策略Presto通過多種策略優(yōu)化查詢性能,確保高效的數(shù)據(jù)處理。其中,查詢優(yōu)化是關(guān)鍵環(huán)節(jié),它包括:4.1.1謂詞下推(PredicatePushdown)謂詞下推是一種將查詢條件盡可能下推到數(shù)據(jù)源的技術(shù),減少數(shù)據(jù)掃描量。例如,如果查詢條件是SELECT*FROMtableWHEREid>100,Presto會將id>100的條件直接傳遞給數(shù)據(jù)源,數(shù)據(jù)源在讀取數(shù)據(jù)時就只返回滿足條件的記錄,從而減少網(wǎng)絡(luò)傳輸和處理的數(shù)據(jù)量。4.1.2連接優(yōu)化(JoinOptimization)Presto支持多種連接算法,包括嵌套循環(huán)連接、哈希連接和廣播連接。它會根據(jù)數(shù)據(jù)大小和分布自動選擇最合適的連接策略。例如,對于小表,Presto可能會選擇廣播連接,將小表的數(shù)據(jù)廣播到所有處理大表數(shù)據(jù)的節(jié)點,以減少數(shù)據(jù)的shuffle操作。4.1.3分區(qū)裁剪(PartitionPruning)Presto能夠根據(jù)查詢條件裁剪不必要的數(shù)據(jù)分區(qū),只處理與查詢相關(guān)的分區(qū)。例如,如果數(shù)據(jù)按日期分區(qū),查詢條件為WHEREdate='2023-01-01',Presto會只掃描2023年1月1日的分區(qū),而不是整個數(shù)據(jù)集。4.2資源管理與調(diào)度4.2.1資源分配Presto采用動態(tài)資源分配策略,根據(jù)查詢的資源需求和集群的資源可用性動態(tài)調(diào)整資源。每個查詢都有一個資源使用計劃,Presto會根據(jù)這個計劃分配CPU、內(nèi)存和網(wǎng)絡(luò)資源。4.2.2調(diào)度策略Presto的調(diào)度策略確保高優(yōu)先級的查詢能夠優(yōu)先獲得資源。它使用一個優(yōu)先級隊列,高優(yōu)先級的查詢會被優(yōu)先調(diào)度執(zhí)行。此外,Presto還支持查詢的搶占,即高優(yōu)先級的查詢可以中斷低優(yōu)先級的查詢,以獲取更多的資源。4.2.3資源隔離Presto通過資源組實現(xiàn)資源隔離,確保不同用戶或應(yīng)用的查詢不會互相影響。每個資源組都有自己的資源配額,Presto會根據(jù)配額限制查詢的資源使用。4.3故障恢復(fù)機制4.3.1查詢重試Presto支持查詢重試機制,當(dāng)某個查詢節(jié)點發(fā)生故障時,Presto會自動將查詢?nèi)蝿?wù)重新分配到其他健康的節(jié)點上執(zhí)行,以確保查詢的完成。4.3.2數(shù)據(jù)冗余Presto依賴于數(shù)據(jù)源的數(shù)據(jù)冗余策略。例如,HDFS通常會為每個文件保存多個副本,以確保數(shù)據(jù)的高可用性。當(dāng)某個節(jié)點上的數(shù)據(jù)不可用時,Presto可以從其他節(jié)點讀取數(shù)據(jù)。4.3.3狀態(tài)持久化Presto將查詢的中間狀態(tài)持久化到磁盤,即使在節(jié)點故障的情況下,也可以從磁盤恢復(fù)狀態(tài),繼續(xù)執(zhí)行查詢。這通過狀態(tài)存儲機制實現(xiàn),確保了查詢的可靠性和一致性。4.3.4示例代碼假設(shè)我們有一個Presto查詢,需要從Hive表中讀取數(shù)據(jù),并應(yīng)用謂詞下推和分區(qū)裁剪:--PrestoSQL查詢示例

SELECT*FROMhive.default.sales

WHEREsale_date='2023-01-01'ANDproduct_id>1000;在這個查詢中,sale_date='2023-01-01'用于分區(qū)裁剪,product_id>1000用于謂詞下推。Presto會將這些條件直接傳遞給Hive,Hive在讀取數(shù)據(jù)時會只處理與查詢條件相關(guān)的數(shù)據(jù)分區(qū)和記錄,從而極大地提高了查詢效率。4.3.5數(shù)據(jù)樣例假設(shè)hive.default.sales表的數(shù)據(jù)如下:sale_dateproduct_idquantityprice2023-01-01100151002023-01-01100231502023-01-02100322002023-01-0110041250對于上述查詢,Presto只會返回前3行數(shù)據(jù),因為它們滿足sale_date='2023-01-01'和product_id>1000的條件。4.3.6結(jié)論Presto通過查詢優(yōu)化策略、資源管理與調(diào)度以及故障恢復(fù)機制,提供了高效、可靠的數(shù)據(jù)分析能力。這些機制確保了Presto能夠在大規(guī)模數(shù)據(jù)集上執(zhí)行復(fù)雜查詢,同時保持高可用性和性能。5Presto在企業(yè)中的應(yīng)用5.1大數(shù)據(jù)分析案例在企業(yè)環(huán)境中,Presto因其高效、可擴展的特性,被廣泛應(yīng)用于大數(shù)據(jù)分析。例如,一家電子商務(wù)公司可能需要分析其用戶行為數(shù)據(jù),以優(yōu)化產(chǎn)品推薦算法。這些數(shù)據(jù)可能存儲在Hadoop的HDFS中,或者在AmazonS3上。Presto能夠直接查詢這些數(shù)據(jù)源,而無需將數(shù)據(jù)移動到其他系統(tǒng)中,這大大提高了數(shù)據(jù)處理的效率和速度。5.1.1示例:用戶行為分析假設(shè)我們有以下用戶行為數(shù)據(jù),存儲在HDFS中:--創(chuàng)建用戶行為表

CREATETABLEuser_behavior(

user_idBIGINT,

product_idBIGINT,

actionVARCHAR,

timestampTIMESTAMP

)WITH(

format='PARQUET'

);我們可以使用Presto來查詢過去一周內(nèi),用戶對特定產(chǎn)品的點擊次數(shù):--查詢過去一周內(nèi),用戶對產(chǎn)品ID為123的點擊次數(shù)

SELECTCOUNT(*)

FROMuser_behavior

WHEREaction='click'

ANDproduct_id=123

ANDtimestamp>=DATE_SUB(CURRENT_DATE,INTERVAL'7'DAY);5.2實時查詢場景Presto不僅適用于批處理分析,也適用于實時查詢場景。例如,一個在線廣告平臺可能需要實時監(jiān)控廣告點擊率,以調(diào)整廣告投放策略。Presto能夠處理這種實時查詢需求,同時保持高并發(fā)和低延遲。5.2.1示例:實時廣告點擊率監(jiān)控假設(shè)我們有以下實時廣告點擊數(shù)據(jù),存儲在Kafka中,并通過Presto的Kafkaconnector進行訪問:--創(chuàng)建實時廣告點擊表

CREATETABLEreal_time_ad_clicks(

ad_idBIGINT,

clickBOOLEAN,

timestampTIMESTAMP

)WITH(

connector='kafka',

topic='ad_clicks',

format='AVRO'

);我們可以使用Presto來查詢過去一小時內(nèi),特定廣告的點擊率:--查詢過去一小時內(nèi),廣告ID為456的點擊率

SELECTAVG(click)ASclick_rate

FROMreal_time_ad_clicks

WHEREad_id=456

ANDtimestamp>=DATE_SUB(CURRENT_TIMESTAMP,INTERVAL'1'HOUR);5.3跨數(shù)據(jù)源查詢示例Presto的一個獨特優(yōu)勢是能夠跨多個數(shù)據(jù)源進行查詢,這在企業(yè)環(huán)境中非常有用。例如,一個公司可能需要從其關(guān)系型數(shù)據(jù)庫和Hadoop集群中同時獲取數(shù)據(jù),以進行綜合分析。Presto能夠無縫地處理這種跨數(shù)據(jù)源查詢,提供統(tǒng)一的數(shù)據(jù)視圖。5.3.1示例:跨數(shù)據(jù)源查詢假設(shè)我們有以下兩個數(shù)據(jù)源:一個關(guān)系型數(shù)據(jù)庫(MySQL)中的用戶信息表,和Hadoop集群中的用戶行為數(shù)據(jù)表。MySQL中的用戶信息表--創(chuàng)建用戶信息表

CREATETABLEuser_info(

user_idBIGINT,

nameVARCHAR,

emailVARCHAR

);Hadoop集群中的用戶行為數(shù)據(jù)表--創(chuàng)建用戶行為表

CREATETABLEuser_behavior(

user_idBIGINT,

product_idBIGINT,

actionVARCHAR,

timestampTIMESTAMP

)WITH(

format='PARQUET'

);我們可以使用Presto來查詢特定用戶在過去一個月內(nèi)對所有產(chǎn)品的購買次數(shù):--查詢用戶ID為789的用戶在過去一個月內(nèi)對所有產(chǎn)品的購買次數(shù)

SELECT,COUNT(b.action)ASpurchase_count

FROMuser_infou

JOINuser_behaviorbONu.user_id=b.user_id

WHEREu.user_id=789

ANDb.action='purchase'

ANDb.timestamp>=DATE_SUB(CURRENT_DATE,INTERVAL'1'MONTH);通過上述查詢,我們可以看到Presto如何在不同的數(shù)據(jù)源之間進行數(shù)據(jù)關(guān)聯(lián),提供全面的分析結(jié)果。這種能力使得Presto成為企業(yè)級數(shù)據(jù)分析的首選工具,因為它能夠處理各種數(shù)據(jù)源,提供一致的查詢體驗,同時保持高性能和可擴展性。6Presto的未來趨勢6.1Presto的社區(qū)與生態(tài)Presto,作為一款開源的分布式SQL查詢引擎,其社區(qū)與生態(tài)的活躍度直接影響著其未來的發(fā)展方向和速度。Presto社區(qū)由來自全球的開發(fā)者、數(shù)據(jù)工程師和數(shù)據(jù)科學(xué)家組成,他們共同貢獻代碼、修復(fù)bug、分享最佳實踐和使用案例。社區(qū)的活躍不僅體現(xiàn)在GitHub上的代碼提交和問題討論,還包括定期的線上和線下會議、研討會和工作坊,以及豐富的文檔和教程資源。6.1.1社區(qū)貢獻代碼貢獻:社區(qū)成員可以提交代碼改進或新增功能,通過PullRequest流程進行代碼審查和合并。文檔完善:提供詳細的文檔和教程,幫助新用戶快速上手和深入理解Presto的使用和原理。問題解答:在社區(qū)論壇或郵件列表中,成員們可以提問和解答關(guān)于Presto使用中的各種問題。6.1.2生態(tài)系統(tǒng)Presto的生態(tài)系統(tǒng)包括了各種數(shù)據(jù)源插件、工具集成和商業(yè)支持服務(wù)。這些插件和集成使得Presto能夠查詢和處理來自不同數(shù)據(jù)源的數(shù)據(jù),如Hadoop、Cassandra、MongoDB、AmazonS3等。商業(yè)支持服務(wù)則為大型企業(yè)提供專業(yè)的技術(shù)支持和定制化服務(wù),確保Presto在企業(yè)級應(yīng)用中的穩(wěn)定性和性能。6.2新特性展望隨著大數(shù)據(jù)和云計算技術(shù)的不斷發(fā)展,Pres

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論