Äú¿ÉÒÔ¾èÖú£¬Ö§³ÖÎÒÃǵĹ«ÒæÊÂÒµ¡£

1Ôª 10Ôª 50Ôª





ÈÏÖ¤Â룺  ÑéÖ¤Âë,¿´²»Çå³þ?Çëµã»÷Ë¢ÐÂÑéÖ¤Âë ±ØÌî



  ÇóÖª ÎÄÕ ÎÄ¿â Lib ÊÓÆµ iPerson ¿Î³Ì ÈÏÖ¤ ×Éѯ ¹¤¾ß ½²×ù Modeler   Code  
»áÔ±   
 
   
 
 
     
   
 ¶©ÔÄ
  ¾èÖú
ImpalaÓëHiveµÄ±È½Ï
 
×÷Õß yakcyµÄ²©¿Í£¬»ðÁú¹ûÈí¼þ    ·¢²¼ÓÚ 2014-07-09
  2949  次浏览      27
 

1. Impala¼Ü¹¹

ImpalaÊÇClouderaÔÚÊܵ½GoogleµÄDremelÆô·¢Ï¿ª·¢µÄʵʱ½»»¥SQL´óÊý¾Ý²éѯ¹¤¾ß£¬ImpalaûÓÐÔÙʹÓûºÂýµÄHive+MapReduceÅú´¦Àí£¬¶øÊÇͨ¹ýʹÓÃÓëÉÌÓò¢ÐйØÏµÊý¾Ý¿âÖÐÀàËÆµÄ·Ö²¼Ê½²éѯÒýÇæ£¨ÓÉQuery Planner¡¢Query CoordinatorºÍQuery Exec EngineÈý²¿·Ö×é³É£©£¬¿ÉÒÔÖ±½Ó´ÓHDFS»òHBaseÖÐÓÃSELECT¡¢JOINºÍͳ¼Æº¯Êý²éѯÊý¾Ý£¬´Ó¶ø´ó´ó½µµÍÁËÑÓ³Ù¡£Æä¼Ü¹¹Èçͼ 1Ëùʾ£¬ImpalaÖ÷ÒªÓÉImpalad£¬ State StoreºÍCLI×é³É¡£

ͼ 1

Impalad: ÓëDataNodeÔËÐÐÔÚͬһ½ÚµãÉÏ£¬ÓÉImpalad½ø³Ì±íʾ£¬Ëü½ÓÊÕ¿Í»§¶ËµÄ²éѯÇëÇ󣨽ÓÊÕ²éѯÇëÇóµÄImpaladΪCoordinator£¬Coordinatorͨ¹ýJNIµ÷ÓÃjavaǰ¶Ë½âÊÍSQL²éѯÓï¾ä£¬Éú³É²éѯ¼Æ»®Ê÷£¬ÔÙͨ¹ýµ÷¶ÈÆ÷°ÑÖ´Ðмƻ®·Ö·¢¸ø¾ßÓÐÏàÓ¦Êý¾ÝµÄÆäËüImpalad½øÐÐÖ´ÐУ©£¬¶ÁдÊý¾Ý£¬²¢ÐÐÖ´Ðвéѯ£¬²¢°Ñ½á¹ûͨ¹ýÍøÂçÁ÷ʽµÄ´«ËͻظøCoordinator£¬ÓÉCoordinator·µ»Ø¸ø¿Í»§¶Ë¡£Í¬Ê±ImpaladÒ²ÓëState Store±£³ÖÁ¬½Ó£¬ÓÃÓÚÈ·¶¨ÄĸöImpaladÊǽ¡¿µºÍ¿ÉÒÔ½ÓÊÜÐµĹ¤×÷¡£ÔÚImpaladÖÐÆô¶¯Èý¸öThriftServer: beeswax_server£¨Á¬½Ó¿Í»§¶Ë£©£¬hs2_server£¨½èÓÃHiveÔªÊý¾Ý£©£¬ be_server£¨ImpaladÄÚ²¿Ê¹Ó㩺ÍÒ»¸öImpalaServer·þÎñ¡£

Impala State Store: ¸ú×Ù¼¯ÈºÖеÄImpaladµÄ½¡¿µ×´Ì¬¼°Î»ÖÃÐÅÏ¢£¬ÓÉstatestored½ø³Ì±íʾ£¬Ëüͨ¹ý´´½¨¶à¸öÏß³ÌÀ´´¦ÀíImpaladµÄ×¢²á¶©ÔĺÍÓë¸÷Impalad±£³ÖÐÄÌøÁ¬½Ó£¬¸÷Impalad¶¼»á»º´æÒ»·ÝState StoreÖеÄÐÅÏ¢£¬µ±State StoreÀëÏߺó£¨Impalad·¢ÏÖState Store´¦ÓÚÀëÏßʱ£¬»á½øÈërecoveryģʽ£¬·´¸´×¢²á£¬µ±State StoreÖØÐ¼ÓÈ뼯Ⱥºó£¬×Ô¶¯»Ö¸´Õý³££¬¸üлº´æÊý¾Ý£©ÒòΪImpaladÓÐState StoreµÄ»º´æÈÔÈ»¿ÉÒÔ¹¤×÷£¬µ«»áÒòΪÓÐЩImpaladʧЧÁË£¬¶øÒÑ»º´æÊý¾ÝÎÞ·¨¸üУ¬µ¼Ö°ÑÖ´Ðмƻ®·ÖÅ䏸ÁËʧЧµÄImpalad£¬µ¼Ö²éѯʧ°Ü¡£

CLI: Ìṩ¸øÓû§²éѯʹÓõÄÃüÁîÐй¤¾ß£¨Impala ShellʹÓÃpythonʵÏÖ£©£¬Í¬Ê±Impala»¹ÌṩÁËHue£¬JDBC£¬ ODBCʹÓýӿڡ£

2. ÓëHiveµÄ¹ØÏµ

ImpalaÓëHive¶¼Êǹ¹½¨ÔÚHadoopÖ®ÉϵÄÊý¾Ý²éѯ¹¤¾ß¸÷Óв»Í¬µÄ²àÖØÊÊÓ¦Ãæ£¬µ«´Ó¿Í»§¶ËʹÓÃÀ´¿´ImpalaÓëHiveÓкܶàµÄ¹²Í¬Ö®´¦£¬ÈçÊý¾Ý±íÔªÊý¾Ý¡¢ODBC/JDBCÇý¶¯¡¢SQLÓï·¨¡¢Áé»îµÄÎļþ¸ñʽ¡¢´æ´¢×ÊÔ´³ØµÈ¡£ImpalaÓëHiveÔÚHadoopÖеĹØÏµÈçͼ 2Ëùʾ¡£HiveÊʺÏÓÚ³¤Ê±¼äµÄÅú´¦Àí²éѯ·ÖÎö£¬¶øImpalaÊʺÏÓÚʵʱ½»»¥Ê½SQL²éѯ£¬Impala¸øÊý¾Ý·ÖÎöÈËÔ±ÌṩÁË¿ìËÙʵÑé¡¢ÑéÖ¤Ïë·¨µÄ´óÊý¾Ý·ÖÎö¹¤¾ß¡£¿ÉÒÔÏÈʹÓÃhive½øÐÐÊý¾Ýת»»´¦Àí£¬Ö®ºóʹÓÃImpalaÔÚHive´¦ÀíºóµÄ½á¹ûÊý¾Ý¼¯ÉϽøÐпìËÙµÄÊý¾Ý·ÖÎö¡£

ͼ 2

3. ImpalaµÄ²éѯ´¦Àí¹ý³Ì

Impalad·ÖΪJavaǰ¶ËÓëC++´¦Àíºó¶Ë£¬½ÓÊܿͻ§¶ËÁ¬½ÓµÄImpalad¼´×÷ΪÕâ´Î²éѯµÄCoordinator£¬Coordinatorͨ¹ýJNIµ÷ÓÃJavaǰ¶Ë¶ÔÓû§µÄ²éѯSQL½øÐзÖÎöÉú³ÉÖ´Ðмƻ®Ê÷£¬²»Í¬µÄ²Ù×÷¶ÔÓ¦²»ÓõÄPlanNode, È磺SelectNode£¬ ScanNode£¬ SortNode£¬ AggregationNode£¬ HashJoinNodeµÈµÈ¡£

Ö´Ðмƻ®Ê÷µÄÿ¸öÔ­×Ó²Ù×÷ÓÉÒ»¸öPlanFragment±íʾ£¬Í¨³£Ò»Ìõ²éѯÓï¾äÓɶà¸öPlan Fragment×é³É£¬ Plan Fragment 0±íʾִÐÐÊ÷µÄ¸ù£¬»ã¾Û½á¹û·µ»Ø¸øÓû§£¬Ö´ÐÐÊ÷µÄÒ¶×Ó½áµãÒ»°ãÊÇScan²Ù×÷£¬·Ö²¼Ê½²¢ÐÐÖ´ÐС£

Javaǰ¶Ë²úÉúµÄÖ´Ðмƻ®Ê÷ÒÔThriftÊý¾Ý¸ñʽ·µ»Ø¸øImpala C++ºó¶Ë£¨Coordinator£©£¨Ö´Ðмƻ®·ÖΪ¶à¸ö½×¶Î£¬Ã¿Ò»¸ö½×¶Î½Ð×öÒ»¸öPlanFragment£¬Ã¿Ò»¸öPlanFragmentÔÚÖ´ÐÐʱ¿ÉÒÔÓɶà¸öImpaladʵÀý²¢ÐÐÖ´ÐÐ(ÓÐЩPlanFragmentÖ»ÄÜÓÉÒ»¸öImpaladʵÀýÖ´ÐÐ,Èç¾ÛºÏ²Ù×÷)£¬Õû¸öÖ´Ðмƻ®ÎªÒ»Ö´Ðмƻ®Ê÷£©£¬ÓÉCoordinator¸ù¾ÝÖ´Ðмƻ®£¬Êý¾Ý´æ´¢ÐÅÏ¢£¨Impalaͨ¹ýlibhdfsÓëHDFS½øÐн»»¥¡£Í¨¹ýhdfsGetHosts·½·¨»ñµÃÎļþÊý¾Ý¿éËùÔÚ½ÚµãµÄλÖÃÐÅÏ¢£©£¬Í¨¹ýµ÷¶ÈÆ÷£¨ÏÖÔÚÖ»ÓÐsimple-scheduler, ʹÓÃround-robinËã·¨£©Coordinator::Exec¶ÔÉú³ÉµÄÖ´Ðмƻ®Ê÷·ÖÅ䏸ÏàÓ¦µÄºó¶ËÖ´ÐÐÆ÷ImpaladÖ´ÐУ¨²éѯ»áʹÓÃLLVM½øÐдúÂëÉú³É£¬±àÒ룬ִÐС£¶ÔÓÚʹÓÃLLVMÈçºÎÌá¸ßÐÔÄÜÕâÀïÓÐ˵Ã÷£©£¬Í¨¹ýµ÷ÓÃGetNext()·½·¨»ñÈ¡¼ÆËã½á¹û£¬Èç¹ûÊÇinsertÓï¾ä£¬Ôò½«¼ÆËã½á¹ûͨ¹ýlibhdfsд»ØHDFSµ±ËùÓÐÊäÈëÊý¾Ý±»ÏûºÄ¹â£¬Ö´ÐнáÊø£¬Ö®ºó×¢Ïú´Ë´Î²éѯ·þÎñ¡£

ImpalaµÄ²éѯ´¦ÀíÁ÷³Ì´ó¸ÅÈçͼ3Ëùʾ£º

ͼ 3

ÏÂÃæÒÔÒ»¸öSQL²éѯÓï¾äΪÀý·ÖÎöImpalaµÄ²éѯ´¦ÀíÁ÷³Ì¡£Èçselect sum(id), count(id), avg(id) from customer_small group by id£» ÒÔ´ËÓï¾äÉú³ÉµÄ¼Æ»®Îª£º

PLAN FRAGMENT 0
PARTITION: UNPARTITIONED

4:EXCHANGE
tuple ids: 1

PLAN FRAGMENT 1
PARTITION: HASH_PARTITIONED: <slot 1>

STREAM DATA SINK
EXCHANGE ID: 4
UNPARTITIONED

3:AGGREGATE
| output: SUM(<slot 2>), SUM(<slot 3>)
| group by: <slot 1>
| tuple ids: 1
|
2:EXCHANGE
tuple ids: 1

PLAN FRAGMENT 2
PARTITION: RANDOM

STREAM DATA SINK
EXCHANGE ID: 2
HASH_PARTITIONED: <slot 1>

1:AGGREGATE
| output: SUM(id), COUNT(id)
| group by: id
| tuple ids: 1
|
0:SCAN HDFS
table=default.customer_small #partitions=1 size=193B
tuple ids: 0

Ö´ÐÐÐмƻ®Ê÷Èçͼ 4Ëùʾ£¬ ÂÌÉ«µÄ²¿·ÖΪ¿ÉÒÔ·Ö²¼Ê½²¢ÐÐÖ´ÐУº

ͼ 4

4. ImpalaÏà¶ÔÓÚHiveËùʹÓõÄÓÅ»¯¼¼Êõ

1¡¢Ã»ÓÐʹÓÃMapReduce½øÐв¢ÐмÆË㣬ËäÈ»MapReduceÊǷdz£ºÃµÄ²¢ÐмÆËã¿ò¼Ü£¬µ«Ëü¸ü¶àµÄÃæÏòÅú´¦Àíģʽ£¬¶ø²»ÊÇÃæÏò½»»¥Ê½µÄSQLÖ´ÐС£ÓëMapReduceÏà±È£ºImpala°ÑÕû¸ö²éѯ·Ö³ÉÒ»Ö´Ðмƻ®Ê÷£¬¶ø²»ÊÇÒ»Á¬´®µÄMapReduceÈÎÎñ£¬ÔÚ·Ö·¢Ö´Ðмƻ®ºó£¬ImpalaʹÓÃÀ­Ê½»ñÈ¡Êý¾ÝµÄ·½Ê½»ñÈ¡½á¹û£¬°Ñ½á¹ûÊý¾Ý×é³É°´Ö´ÐÐÊ÷Á÷ʽ´«µÝ»ã¼¯£¬¼õÉÙµÄÁ˰ÑÖмä½á¹ûдÈë´ÅÅ̵IJ½Ö裬ÔÙ´Ó´ÅÅ̶ÁÈ¡Êý¾ÝµÄ¿ªÏú¡£ImpalaʹÓ÷þÎñµÄ·½Ê½±ÜÃâÿ´ÎÖ´Ðвéѯ¶¼ÐèÒªÆô¶¯µÄ¿ªÏú£¬¼´Ïà±ÈHiveûÁËMapReduceÆô¶¯Ê±¼ä¡£

2¡¢Ê¹ÓÃLLVM²úÉúÔËÐдúÂ룬Õë¶ÔÌØ¶¨²éѯÉú³ÉÌØ¶¨´úÂ룬ͬʱʹÓÃInlineµÄ·½Ê½¼õÉÙº¯Êýµ÷ÓõĿªÏú£¬¼Ó¿ìÖ´ÐÐЧÂÊ¡£

3¡¢³ä·ÖÀûÓÿÉÓõÄÓ²¼þÖ¸ÁSSE4.2£©¡£

4¡¢¸üºÃµÄIOµ÷¶È£¬ImpalaÖªµÀÊý¾Ý¿éËùÔڵĴÅÅÌλÖÃÄܹ»¸üºÃµÄÀûÓöà´ÅÅ̵ÄÓÅÊÆ£¬Í¬Ê±ImpalaÖ§³ÖÖ±½ÓÊý¾Ý¿é¶ÁÈ¡ºÍ±¾µØ´úÂë¼ÆËãchecksum¡£

5¡¢Í¨¹ýÑ¡ÔñºÏÊʵÄÊý¾Ý´æ´¢¸ñʽ¿ÉÒԵõ½×îºÃµÄÐÔÄÜ£¨ImpalaÖ§³Ö¶àÖÖ´æ´¢¸ñʽ£©¡£

6¡¢×î´óʹÓÃÄڴ棬Öмä½á¹û²»Ð´´ÅÅÌ£¬¼°Ê±Í¨¹ýÍøÂçÒÔstreamµÄ·½Ê½´«µÝ¡£

5. ImpalaÓëHiveµÄÒìͬ

Êý¾Ý´æ´¢£ºÊ¹ÓÃÏàͬµÄ´æ´¢Êý¾Ý³Ø¶¼Ö§³Ö°ÑÊý¾Ý´æ´¢ÓÚHDFS, HBase¡£

ÔªÊý¾Ý£ºÁ½ÕßʹÓÃÏàͬµÄÔªÊý¾Ý¡£

SQL½âÊÍ´¦Àí£º±È½ÏÏàËÆ¶¼ÊÇͨ¹ý´Ê·¨·ÖÎöÉú³ÉÖ´Ðмƻ®¡£

Ö´Ðмƻ®£º

Hive: ÒÀÀµÓÚMapReduceÖ´Ðпò¼Ü£¬Ö´Ðмƻ®·Ö³Émap->shuffle->reduce->map->shuffle->reduce¡­µÄÄ£ÐÍ¡£Èç¹ûÒ»¸öQuery»á±»±àÒë³É¶àÂÖMapReduce£¬Ôò»áÓиü¶àµÄдÖмä½á¹û¡£ÓÉÓÚMapReduceÖ´Ðпò¼Ü±¾ÉíµÄÌØµã£¬¹ý¶àµÄÖмä¹ý³Ì»áÔö¼ÓÕû¸öQueryµÄÖ´ÐÐʱ¼ä¡£

Impala: °ÑÖ´Ðмƻ®±íÏÖΪһ¿ÃÍêÕûµÄÖ´Ðмƻ®Ê÷£¬¿ÉÒÔ¸ü×ÔÈ»µØ·Ö·¢Ö´Ðмƻ®µ½¸÷¸öImpaladÖ´Ðвéѯ£¬¶ø²»ÓÃÏñHiveÄÇÑù°ÑËü×éºÏ³É¹ÜµÀÐ͵Ämap->reduceģʽ£¬ÒԴ˱£Ö¤ImpalaÓиüºÃµÄ²¢·¢ÐԺͱÜÃâ²»±ØÒªµÄÖмäsortÓëshuffle¡£

Êý¾ÝÁ÷£º

Hive: ²ÉÓÃÍÆµÄ·½Ê½£¬Ã¿Ò»¸ö¼ÆËã½Úµã¼ÆËãÍê³Éºó½«Êý¾ÝÖ÷¶¯ÍƸøºóÐø½Úµã¡£

Impala: ²ÉÓÃÀ­µÄ·½Ê½£¬ºóÐø½Úµãͨ¹ýgetNextÖ÷¶¯ÏòÇ°Ãæ½ÚµãÒªÊý¾Ý£¬ÒÔ´Ë·½Ê½Êý¾Ý¿ÉÒÔÁ÷ʽµÄ·µ»Ø¸ø¿Í»§¶Ë£¬ÇÒÖ»ÒªÓÐ1ÌõÊý¾Ý±»´¦ÀíÍ꣬¾Í¿ÉÒÔÁ¢¼´Õ¹ÏÖ³öÀ´£¬¶ø²»Óõȵ½È«²¿´¦ÀíÍê³É£¬¸ü·ûºÏSQL½»»¥Ê½²éѯʹÓá£

ÄÚ´æÊ¹Óãº

Hive: ÔÚÖ´Ðйý³ÌÖÐÈç¹ûÄÚ´æ·Å²»ÏÂËùÓÐÊý¾Ý£¬Ôò»áʹÓÃÍâ´æ£¬ÒÔ±£Ö¤QueryÄÜ˳ÐòÖ´ÐÐÍꡣÿһÂÖMapReduce½áÊø£¬Öмä½á¹ûÒ²»áдÈëHDFSÖУ¬Í¬ÑùÓÉÓÚMapReduceÖ´Ðмܹ¹µÄÌØÐÔ£¬shuffle¹ý³ÌÒ²»áÓÐд±¾µØ´ÅÅ̵IJÙ×÷¡£

Impala: ÔÚÓöµ½ÄÚ´æ·Å²»ÏÂÊý¾Ýʱ£¬µ±Ç°°æ±¾1.0.1ÊÇÖ±½Ó·µ»Ø´íÎ󣬶ø²»»áÀûÓÃÍâ´æ£¬ÒÔºó°æ±¾Ó¦¸Ã»á½øÐиĽø¡£ÕâʹÓõÃImpalaĿǰ´¦ÀíQuery»áÊܵ½Ò»¶¨µÄÏÞÖÆ£¬×îºÃ»¹ÊÇÓëHiveÅäºÏʹÓá£ImpalaÔÚ¶à¸ö½×¶ÎÖ®¼äÀûÓÃÍøÂç´«ÊäÊý¾Ý£¬ÔÚÖ´Ðйý³Ì²»»áÓÐд´ÅÅ̵IJÙ×÷£¨insert³ýÍ⣩¡£

µ÷¶È£º

Hive: ÈÎÎñµ÷¶ÈÒÀÀµÓÚHadoopµÄµ÷¶È²ßÂÔ¡£

Impala: µ÷¶ÈÓÉ×Ô¼ºÍê³É£¬Ä¿Ç°Ö»ÓÐÒ»ÖÖµ÷¶ÈÆ÷simple-schedule£¬Ëü»á¾¡Á¿Âú×ãÊý¾ÝµÄ¾Ö²¿ÐÔ£¬É¨ÃèÊý¾ÝµÄ½ø³Ì¾¡Á¿¿¿½üÊý¾Ý±¾ÉíËùÔÚµÄÎïÀí»úÆ÷¡£µ÷¶ÈÆ÷Ŀǰ»¹±È½Ï¼òµ¥£¬ÔÚSimpleScheduler::GetBackendÖпÉÒÔ¿´µ½£¬ÏÖÔÚ»¹Ã»Óп¼ÂǸºÔØ£¬ÍøÂçIO×´¿öµÈÒòËØ½øÐе÷¶È¡£µ«Ä¿Ç°ImpalaÒѾ­ÓжÔÖ´Ðйý³ÌµÄÐÔÄÜͳ¼Æ·ÖÎö£¬Ó¦¸ÃÒÔºó°æ±¾»áÀûÓÃÕâЩͳ¼ÆÐÅÏ¢½øÐе÷¶È°É¡£

ÈÝ´í£º

Hive: ÒÀÀµÓÚHadoopµÄÈÝ´íÄÜÁ¦¡£

Impala: ÔÚ²éѯ¹ý³ÌÖУ¬Ã»ÓÐÈÝ´íÂß¼­£¬Èç¹ûÔÚÖ´Ðйý³ÌÖз¢Éú¹ÊÕÏ£¬ÔòÖ±½Ó·µ»Ø´íÎó£¨ÕâÓëImpalaµÄÉè¼ÆÓйأ¬ÒòΪImpala¶¨Î»ÓÚʵʱ²éѯ£¬Ò»´Î²éѯʧ°Ü£¬ÔÙ²éÒ»´Î¾ÍºÃÁË£¬ÔÙ²éÒ»´ÎµÄ³É±¾ºÜµÍ£©¡£µ«´ÓÕûÌåÀ´¿´£¬ImpalaÊÇÄܺܺõÄÈÝ´í£¬ËùÓеÄImpaladÊǶԵȵĽṹ£¬Óû§¿ÉÒÔÏòÈκÎÒ»¸öImpaladÌá½»²éѯ£¬Èç¹ûÒ»¸öImpaladʧЧ£¬ÆäÉÏÕýÔÚÔËÐеÄËùÓÐQuery¶¼½«Ê§°Ü£¬µ«Óû§¿ÉÒÔÖØÐÂÌá½»²éѯÓÉÆäËüImpalad´úÌæÖ´ÐУ¬²»»áÓ°Ïì·þÎñ¡£¶ÔÓÚState StoreĿǰֻÓÐÒ»¸ö£¬µ«µ±State StoreʧЧ£¬Ò²²»»áÓ°Ïì·þÎñ£¬Ã¿¸öImpalad¶¼»º´æÁËState StoreµÄÐÅÏ¢£¬Ö»ÊDz»ÄÜÔÙ¸üм¯Èº×´Ì¬£¬ÓпÉÄÜ»á°ÑÖ´ÐÐÈÎÎñ·ÖÅ䏸ÒѾ­Ê§Ð§µÄImpaladÖ´ÐУ¬µ¼Ö±¾´ÎQueryʧ°Ü¡£

ÊÊÓÃÃæ£º

Hive: ¸´ÔÓµÄÅú´¦Àí²éѯÈÎÎñ£¬Êý¾Ýת»»ÈÎÎñ¡£

Impala£ºÊµÊ±Êý¾Ý·ÖÎö£¬ÒòΪ²»Ö§³ÖUDF£¬ÄÜ´¦ÀíµÄÎÊÌâÓòÓÐÒ»¶¨µÄÏÞÖÆ£¬ÓëHiveÅäºÏʹÓÃ,¶ÔHiveµÄ½á¹ûÊý¾Ý¼¯½øÐÐʵʱ·ÖÎö¡£

6. ImpalaµÄÓÅȱµã

Óŵ㣺

Ö§³ÖSQL²éѯ£¬¿ìËÙ²éѯ´óÊý¾Ý¡£

¿ÉÒÔ¶ÔÒÑÓÐÊý¾Ý½øÐвéѯ£¬¼õÉÙÊý¾ÝµÄ¼ÓÔØ£¬×ª»»¡£

¶àÖÖ´æ´¢¸ñʽ¿ÉÒÔÑ¡Ôñ£¨Parquet, Text, Avro, RCFile, SequeenceFile£©¡£

¿ÉÒÔÓëHiveÅäºÏʹÓá£

ȱµã£º

²»Ö§³ÖÓû§¶¨Ò庯ÊýUDF¡£

²»Ö§³ÖtextÓòµÄÈ«ÎÄËÑË÷¡£

²»Ö§³ÖTransforms¡£

²»Ö§³Ö²éѯÆÚµÄÈÝ´í¡£

¶ÔÄÚ´æÒªÇó¸ß¡£

 

   
2949 ´Îä¯ÀÀ       27
 
Ïà¹ØÎÄÕÂ

ÔÆ¼ÆËãµÄ¼Ü¹¹
¶ÔÔÆ¼ÆËã·þÎñÄ£ÐÍ
ÔÆ¼ÆËãºËÐļ¼ÊõÆÊÎö
Á˽âÔÆ¼ÆËãµÄ©¶´
 
Ïà¹ØÎĵµ

ÔÆ¼ÆËã¼ò½é
ÔÆ¼ÆËã¼ò½éÓëÔÆ°²È«
ÏÂÒ»´úÍøÂç¼ÆËã--ÔÆ¼ÆËã
ÈídzÎöÔÆ¼ÆËã
 
Ïà¹Ø¿Î³Ì

ÔÆ¼ÆËãÔ­ÀíÓëÓ¦ÓÃ
ÔÆ¼ÆËãÓ¦ÓÃÓ뿪·¢
CMMIÌåϵÓëʵ¼ù
»ùÓÚCMMI±ê×¼µÄÈí¼þÖÊÁ¿±£Ö¤
×îл¼Æ»®
DeepSeekÔÚÈí¼þ²âÊÔÓ¦ÓÃʵ¼ù 4-12[ÔÚÏß]
DeepSeek´óÄ£ÐÍÓ¦Óÿª·¢Êµ¼ù 4-19[ÔÚÏß]
UAF¼Ü¹¹ÌåϵÓëʵ¼ù 4-11[±±¾©]
AIÖÇÄÜ»¯Èí¼þ²âÊÔ·½·¨Óëʵ¼ù 5-23[ÉϺ£]
»ùÓÚ UML ºÍEA½øÐзÖÎöÉè¼Æ 4-26[±±¾©]
ÒµÎñ¼Ü¹¹Éè¼ÆÓ뽨ģ 4-18[±±¾©]

ר¼ÒÊӽǿ´ITÓë¼Ü¹¹
Èí¼þ¼Ü¹¹Éè¼Æ
ÃæÏò·þÎñÌåϵ¼Ü¹¹ºÍÒµÎñ×é¼þµÄ˼¿¼
ÈËÈËÍøÒÆ¶¯¿ª·¢¼Ü¹¹
¼Ü¹¹¸¯»¯Ö®ÃÕ
̸ƽ̨¼´·þÎñPaaS
Ïà¹ØÅàѵ¿Î³Ì

ÔÆ¼ÆËãÔ­ÀíÓëÓ¦ÓÃ
Windows Azure ÔÆ¼ÆËãÓ¦ÓÃ

ĦÍÐÂÞÀ­ ÔÆÆ½Ì¨µÄ¹¹½¨ÓëÓ¦ÓÃ
ͨÓù«Ë¾GE DockerÔ­ÀíÓëʵ¼ù
ijÑз¢ÖÐÐÄ Openstackʵ¼ù
ÖªÃûµç×Ó¹«Ë¾ ÔÆÆ½Ì¨¼Ü¹¹ÓëÓ¦ÓÃ
ijµçÁ¦ÐÐÒµ »ùÓÚÔÆÆ½Ì¨¹¹½¨ÔÆ·þÎñ
ÔÆ¼ÆËãÓëWindows AzureÅàѵ
±±¾© ÔÆ¼ÆËãÔ­ÀíÓëÓ¦ÓÃ