±à¼ÍƼö: |
±¾ÎÄÖ÷Òª½²ÊöÃÀÍŵãÆÀ»ùÓÚFlinkµÄʵʱÊý²Öƽ̨ʵ¼ù,ÍøÒ×»ùÓÚFlinkµÄÑÏѡʵʱÊý²Öʵ¼ù,ÖªºõµÄʵʱÊý²Öʵ¼ùÒÔ¼°¼Ü¹¹µÄÑݽø,Ï£ÍûÄܸø´ó¼Ò´øÀ´Æô·¢¡£
±¾ÎÄÀ´×ÔÉçÇø¾«Ñ¡£¬ÓÉ»ðÁú¹ûÈí¼þAlice±à¼¡¢ÍƼö¡£ |
|
Êý¾Ý²Ö¿â¸ÅÄîµÄÌá³ö¶¼Òª×·Ëݵ½ÉÏÊÀ¼ÍÁË£¬ÎÒÃÇÈÏΪÔÚ´óÊý¾ÝÔªÄê֮ǰµÄÊý²Ö¿ÉÒÔ³ÆÎª´«Í³Êý²Ö£¬¶øºóËæ×ź£Á¿Êý¾Ý²»¶ÏÔö³¤£¬ÒÔ¼°HadoopÉú̬²»¶Ï·¢Õ¹£¬Ö÷Òª»ùÓÚHive/HDFSµÄÀëÏßÊý²Ö¼Ü¹¹¿ÉÒÔÐËÆð²¢ÑÓÐøÖÁ½ñ£¬½ü¼¸ÄêËæ×ÅStorm/Spark£¨Streaming£©/FlinkµÈʵʱ´¦Àí¿ò¼ÜµÄ¸üеü´úÄËÖÁÏ໥ȡ´ú£¬¸÷³§¶¼ÔÚ×ÅÁ¦¹¹½¨×Ô¼ºµÄʵʱÊý²Ö£¬ÌرðÊǽüÁ½Äê£¬Ëæ×ÅFlinkÉùÃûȵÆð£¬ÊµÊ±Êý²Ö¸üÊÇÃûÉùÔÚÍâ²¢ÇÒ»¹ÔÚ²»¶Ï¿ìËÙ·¢Õ¹¡£
Ŀǰ´ó¶àÆóÒµµÄÊý¾ÝÌåϵ¶¼ÊÇÎ§ÈÆÊý²ÖµÄÊý¾Ýƽ̨¼Ü¹¹£¬ÌرðÊÇÔÚ×ÅÁ¦½¨ÉèʵʱÊý²Ö£¬»òÕßÔÚ½¨ÉèÀëÏßÊý²ÖÓëʵʱÊý²ÖÏàͳһµÄÊý²ÖÌåϵ¡£±¾ÎÄÎÒÃǾ«Ñ¡ÁËʵʱÊý²Ö½¨ÉèµÄµäÐÍ´ú±í£¬°üÀ¨ÃÀÍŵãÆÀ¡¢ÍøÒס¢Öªºõ¡¢OPPOµÈ¼¸¼ÒµÄʵʱÊý²Ö¼Ü¹¹£¬ËûÃǵÄÊý²Öʵ¼ù¿Ï¶¨¶ÔÎÒÃÇÓÐËù½è¼ø»òÆôµÏ¡£±ÊÕßÕâÀïÌØ±ðÍÆ¼ö²Î¿¼ËûÃǵķֲãÉè¼Æ£¬´æ´¢Óë¼ÆËãÒýÇæµÄÑ¡ÐÍ¡£
±¾ÎľٵÄËĸö´ú±í°¸Àý£º
1.ÃÀÍŵãÆÀ»ùÓÚ Flink µÄʵʱÊý²Öƽ̨ʵ¼ù
2.ÍøÒ×»ùÓÚFlinkµÄÑÏѡʵʱÊý²Öʵ¼ù
3.ÖªºõʵʱÊý²Öʵ¼ù¼°¼Ü¹¹Ñݽø
4.OPPO ʵʱÊý²Ö½ÒÃØ¼°ÀëÏßµ½ÊµÊ±µÄƽ»¬Ç¨ÒÆ
ÃÀÍŵãÆÀ»ùÓÚFlinkµÄʵʱÊý²Öƽ̨ʵ¼ù
ʵʱ¼ÆËãÆ½Ì¨¼Ü¹¹
ÏÂͼËùʾµÄÊÇÃÀÍŵãÆÀʵʱ¼ÆËãÆ½Ì¨µÄ¼Ü¹¹¡£
×îµ×²ãÊÇÊÕ¼¯²ã£¬ÕâÒ»²ã¸ºÔðÊÕ¼¯Óû§µÄʵʱÊý¾Ý£¬°üÀ¨ Binlog¡¢ºó¶Ë·þÎñÈÕÖ¾ÒÔ¼° IoT Êý¾Ý£¬¾¹ýÈÕÖ¾ÊÕ¼¯ÍŶӺÍ
DB ÊÕ¼¯ÍŶӵĴ¦Àí£¬Êý¾Ý½«»á±»ÊÕ¼¯µ½ Kafka ÖС£ÕâЩÊý¾Ý²»Ö»ÊDzÎÓëʵʱ¼ÆË㣬Ҳ»á²ÎÓëÀëÏß¼ÆËã¡£
ÊÕ¼¯²ãÖ®ÉÏÊÇ´æ´¢²ã£¬ÕâÒ»²ã³ýÁËʹÓà Kafka ×öÏûϢͨµÀÖ®Í⣬»¹»á»ùÓÚ HDFS ×ö״̬Êý¾Ý´æ´¢ÒÔ¼°»ùÓÚ
HBase ×öά¶ÈÊý¾ÝµÄ´æ´¢¡£
´æ´¢²ãÖ®ÉÏÊÇÒýÇæ²ã£¬°üÀ¨ Storm ºÍ Flink¡£ÊµÊ±¼ÆËãÆ½Ì¨»áÔÚÒýÇæ²ãΪÓû§ÌṩһЩ¿ò¼ÜµÄ·â×°ÒÔ¼°¹«¹²°üºÍ×é¼þµÄÖ§³Ö¡£
ÔÚÒýÇæ²ãÖ®ÉϾÍÊÇÆ½Ì¨²ãÁË£¬Æ½Ì¨²ã´ÓÊý¾Ý¡¢ÈÎÎñºÍ×ÊÔ´Èý¸öÊÓ½ÇÈ¥¹ÜÀí¡£
¼Ü¹¹µÄ×îÉϲãÊÇÓ¦Óò㣬°üÀ¨ÁËʵʱÊý²Ö¡¢»úÆ÷ѧϰ¡¢Êý¾Ýͬ²½ÒÔ¼°Ê¼þÇý¶¯Ó¦Óõȡ£

´Ó¹¦ÄܽǶÈÀ´¿´£¬ÃÀÍŵãÆÀµÄʵʱ¼ÆËãÆ½Ì¨Ö÷Òª°üÀ¨×÷ÒµºÍ×ÊÔ´¹ÜÀíÁ½¸ö·½ÃæµÄ¹¦ÄÜ¡£ÆäÖУ¬×÷Òµ²¿·Ö°üÀ¨×÷ÒµÅäÖá¢×÷Òµ·¢²¼ÒÔ¼°×÷ҵ״̬Èý¸ö·½ÃæµÄ¹¦ÄÜ¡£
ÔÚ×÷ÒµÅäÖ÷½Ã棬Ôò°üÀ¨×÷ÒµÉèÖá¢ÔËÐÐʱÉèÖÃÒÔ¼°ÍØÆË½á¹¹ÉèÖã»
ÔÚ×÷Òµ·¢²¼·½Ã棬Ôò°üÀ¨°æ±¾¹ÜÀí¡¢±àÒë/·¢²¼/»Ø¹öµÈ£»
×÷ҵ״̬Ôò°üÀ¨ÔËÐÐʱ״̬¡¢×Ô¶¨ÒåÖ¸±êºÍ±¨¾¯ÒÔ¼°ÃüÁî/ÔËÐÐʱÈÕÖ¾µÈ¡£
ÔÚ×ÊÔ´¹ÜÀí·½Ãæ£¬ÔòΪÓû§ÌṩÁ˶à×â»§×ÊÔ´¸ôÀëÒÔ¼°×ÊÔ´½»¸¶ºÍ²¿ÊðµÄÄÜÁ¦¡£
´«Í³Êý²ÖÄ£ÐÍ
ΪÁ˸üÓÐЧµØ×éÖ¯ºÍ¹ÜÀíÊý¾Ý£¬Êý²Ö½¨ÉèÍùÍù»á½øÐÐÊý¾Ý·Ö²ã£¬Ò»°ã×Ô϶øÉÏ·ÖΪËIJ㣺ODS£¨²Ù×÷Êý¾Ý²ã£©¡¢DWD£¨Êý¾ÝÃ÷ϸ²ã£©¡¢DWS£¨»ã×ܲ㣩ºÍÓ¦Óò㡣¼´Ê±²éѯÖ÷Ҫͨ¹ý
Presto¡¢Hive ºÍ Spark ʵÏÖ¡£

ʵʱÊý²ÖÄ£ÐÍ
ʵʱÊý²ÖµÄ·Ö²ã·½Ê½Ò»°ãÒ²×ñÊØ´«Í³Êý¾Ý²Ö¿âÄ£ÐÍ£¬Ò²·ÖΪÁË ODS ²Ù×÷Êý¾Ý¼¯¡¢DWD Ã÷ϸ²ãºÍ DWS
»ã×ܲãÒÔ¼°Ó¦Óò㡣µ«ÊµÊ±Êý²ÖÄ£Ð͵Ĵ¦ÀíµÄ·½Ê½È´ºÍ´«Í³Êý²ÖÓÐËù²î±ð£¬ÈçÃ÷ϸ²ãºÍ»ã×ܲãµÄÊý¾ÝÒ»°ã»á·ÅÔÚ
Kafka ÉÏ£¬Î¬¶ÈÊý¾ÝÒ»°ã¿¼Âǵ½ÐÔÄÜÎÊÌâÔò»á·ÅÔÚ HBase »òÕß Tair µÈ KV ´æ´¢ÉÏ£¬¼´Ï¯²éѯÔò¿ÉÒÔʹÓÃ
Flink Íê³É¡£

׼ʵʱÊý²ÖÄ£ÐÍ
ÔÚÒÔÉÏÁ½ÖÖÊý²ÖÄ£ÐÍÖ®Í⣬ÎÒÃÇ·¢ÏÖÒµÎñ·½ÔÚʵ¼ù¹ý³ÌÖл¹ÓÐÒ»ÖÖ׼ʵʱÊý²ÖÄ£ÐÍ£¬ÆäÌØµãÊDz»ÍêÈ«»ùÓÚÁ÷È¥×ö£¬¶øÊǽ«Ã÷ϸ²ãÊý¾Ýµ¼Èëµ½
OLAP ´æ´¢ÖУ¬»ùÓÚ OLAP µÄ¼ÆËãÄÜÁ¦È¥×ö»ã×ܲ¢½øÐнøÒ»²½µÄ¼Ó¹¤¡£

ʵʱÊý²ÖºÍ´«Í³Êý²ÖµÄ¶Ô±ÈÖ÷Òª¿ÉÒÔ´ÓËĸö·½Ã濼ÂÇ£º
µÚÒ»¸öÊǷֲ㷽ʽ£¬ÀëÏßÊý²ÖΪÁË¿¼Âǵ½Ð§ÂÊÎÊÌ⣬һ°ã»á²ÉÈ¡¿Õ¼ä»»Ê±¼äµÄ·½Ê½£¬²ã¼¶»®·Ö»á±È½Ï¶à£»ÔòʵʱÊý²Ö¿¼Âǵ½ÊµÊ±ÐÔÎÊÌ⣬һ°ã·Ö²ã»á±È½ÏÉÙ£¬ÁíÍâÒ²¼õÉÙÁËÖмäÁ÷³Ì³ö´íµÄ¿ÉÄÜÐÔ¡£
µÚ¶þ¸öÊÇÊÂʵÊý¾Ý´æ´¢·½Ã棬ÀëÏßÊý²Ö»á»ùÓÚ HDFS£¬ÊµÊ±Êý²ÖÔò»á»ùÓÚÏûÏ¢¶ÓÁУ¨Èç Kafka£©¡£
µÚÈý¸öÊÇά¶ÈÊý¾Ý´æ´¢£¬ÊµÊ±Êý²Ö»á½«Êý¾Ý·ÅÔÚ KV ´æ´¢ÉÏÃæ¡£
µÚËĸöÊÇÊý¾Ý¼Ó¹¤¹ý³Ì£¬ÀëÏßÊý²ÖÒ»°ãÒÔ Hive¡¢Spark µÈÅú´¦ÀíΪÖ÷£¬¶øÊµÊ±Êý²ÖÔòÊÇ»ùÓÚʵʱ¼ÆËãÒýÇæÈç
Storm¡¢Flink µÈ£¬ÒÔÁ÷´¦ÀíΪÖ÷¡£
ÍøÒ×»ùÓÚFlinkµÄÑÏѡʵʱÊý²Öʵ¼ù
ÕûÌå¼Ü¹¹

ʵʱÊý²ÖÕûÌå¿ò¼ÜÒÀ¾ÝÊý¾ÝµÄÁ÷Ïò·ÖΪ²»Í¬µÄ²ã´Î£¬½ÓÈë²ã»áÒÀ¾Ý¸÷ÖÖÊý¾Ý½ÓÈ빤¾ßÊÕ¼¯¸÷¸öÒµÎñϵͳµÄÊý¾Ý£¬ÈçÂòµãµÄÒµÎñÊý¾Ý»òÕßÒµÎñºǫ́µÄ²¢¹º·Åµ½ÏûÏ¢¶ÓÁÐÀïÃæ¡£ÏûÏ¢¶ÓÁеÄÊý¾Ý¼ÈÊÇÀëÏßÊý²ÖµÄÔʼÊý¾Ý£¬Ò²ÊÇʵʱ¼ÆËãµÄÔʼÊý¾Ý£¬ÕâÑù¿ÉÒÔ±£Ö¤ÊµÊ±ºÍÀëÏßµÄÔʼÊý¾ÝÊÇͳһµÄ¡£ÓÐÁËÔ´Êý¾Ý£¬ÔÚ¼ÆËã²ã¾¹ýFLink+ʵʱ¼ÆËãÒýÇæ×öһЩ¼Ó¹¤´¦Àí£¬È»ºóÂ䵨µ½´æ´¢²ãÖв»Í¬´æ´¢½éÖʵ±ÖС£²»Í¬µÄ´æ´¢½éÖÊÊÇÒÀ¾Ý²»Í¬µÄÓ¦Óó¡¾°À´Ñ¡Ôñ¡£¿ò¼ÜÖл¹ÓÐFLinkºÍKafkaµÄ½»»¥£¬ÔÚÊý¾ÝÉϽøÐÐÒ»¸ö·Ö²ãÉè¼Æ£¬¼ÆËãÒýÇæ´ÓKafkaÖÐÀÌÈ¡Êý¾Ý×öһЩ¼Ó¹¤È»ºó·Å»ØKafka¡£ÔÚ´æ´¢²ã¼Ó¹¤ºÃµÄÊý¾Ý»áͨ¹ý·þÎñ²ãµÄÁ½¸ö·þÎñ£ºÍ³Ò»²éѯ¡¢Ö¸±ê¹ÜÀí£¬Í³Ò»²éѯÊÇͨ¹ýÒµÎñ·½µ÷È¡Êý¾Ý½Ó¿ÚµÄÒ»¸ö·þÎñ£¬Ö¸±ê¹ÜÀíÊǶÔÊý¾ÝÖ¸±êµÄ¶¨ÒåºÍ¹ÜÀí¹¤×÷¡£Í¨¹ý·þÎñ²ãÓ¦Óõ½²»Í¬µÄÊý¾ÝÓ¦Óã¬Êý¾ÝÓ¦ÓÿÉÄÜÊÇÎÒÃǵÄÕýʽ²úÆ·»òÕßÖ±½ÓµÄÒµÎñϵͳ¡£ºóÃæ»á´ÓÊý¾ÝµÄ·Ö²ãÉè¼ÆºÍ¾ßÌåµÄʵÏÖÁ½¸ö·½Ãæ½éÉÜ¡£
ÕûÌåÉè¼Æ

ÉÏÃæÊǶÔÊý¾ÝµÄÕûÌåÉè¼Æ£¬Ö÷Òª²Î¿¼ÁËÀëÏßÊý²ÖµÄÉè¼Æ·½°¸£¬Ò²²Î¿¼ÁËÒµ½çͬÐеÄһЩ×ö·¨¡£½«Êý¾Ý·ÖΪËĸö²ã´Î£º
Ê×ÏÈÊÇODS²ã£¬¼´²Ù×÷Êý¾Ý²ã£¬Í¨¹ýÊý¾Ý²É¼¯¹¤¾ßÊÕ¼¯¸÷¸öÒµÎñÔ´Êý¾Ý£»DWD²ã£¬Ã÷ϸÊý¾Ý²ãÊǰ´Ö÷ÌâÓòÀ´»®·Ö£¬Í¨¹ýά¶È½¨Ä£·½Ê½À´×éÖ¯¸÷¸öÒµÎñ¹ý³ÌµÄÃ÷ϸÊý¾Ý¡£Öмä»áÓÐÒ»¸öDIM²ã£¬Î¬¶ÈÊý¾Ý²ãÖ÷Òª×öһЩ²éѯºÍ¹ØÁªµÄ²Ù×÷¡£×îÉϲãÊÇDM²ã£¬Í¨¹ýDWD²ãÊý¾Ý×öһЩָ±ê¼Ó¹¤£¬Ö÷ÒªÃæÏòһЩ·ÖÎöºÍÓ¦Óûã×ܵÄÖ¸±ê»òÕßÊÇ×ö¶àά·ÖÎöµÄÃ÷ϸÊý¾Ý¡£
¼¼ÊõʵÏÖ

È»ºó½éÉÜϼ¼ÊõʵÏÖ·½ÃæµÄ¿¼Á¿£¬Ö÷Òª·ÖΪ¼ÆËãºÍ´æ´¢¡£¶ÔÓÚ¼ÆËã·½Ãæ£¬Óкܶàʵʱ¼ÆËãÒýÇæ£¬ÓÐFlink¡¢Storm¡¢Spark
Streaming£¬FlinkÏà¶ÔÓÚStormµÄÓÅÊÆ¾ÍÊÇÖ§³ÖSQL£¬Ïà¶ÔÓÚSpark StreamingÓÖÓÐÒ»¸öÏà¶ÔºÃµÄÐÔÄܱíÏÖ¡£Í¬Ê±FlinkÔÚÖ§³ÖºÃµÄÓ¦ÓúÍÐÔÄÜ·½Ã滹ÓбȽϺõÄÓïÒåÖ§³ÖºÍ±È½ÏºÃµÄÈÝ´í»úÖÆ£¬Òò´Ë¹¹½¨ÊµÊ±Êý²ÖFlinkÊÇÒ»¸ö±È½ÏºÃµÄʵʱ¼ÆËãÒýÇæÑ¡Ôñ¡£
¼¼ÊõʵÏÖÖÐFlinkµÄ¾ßÌå×÷Óãº
Flink×÷ΪʵʱµÄ¼ÆËãÒýÇæ£¬²»Í¬µÄÊý¾Ý²ã£¨ods->dwd->dm£©Ö®¼ä£¬²»Í¬µÄ´æ´¢ÒýÇæ£¨kafka->db£©¶¼ÊÇͨ¹ýFlink
job´®ÁªµÄ£¬Ïà¹ØµÄetlºÍ¹ØÁª¡¢¾ÛºÏµÈ²Ù×÷Ò²ÊÇÔÚFlinkÖÐÍê³É¡£

¶ÔÓÚ´æ´¢²ã»áÒÀ¾Ý²»Í¬µÄÊý¾Ý²ãµÄÌØµãÑ¡Ôñ²»Í¬µÄ´æ´¢½éÖÊ£¬ODS²ãºÍDWD²ã¶¼ÊÇ´æ´¢µÄһЩʵʱÊý¾Ý£¬Ñ¡ÔñµÄÊÇKafka½øÐд洢£¬ÔÚDWD²ã»á¹ØÁªÒ»Ð©ÀúÊ·Ã÷ϸÊý¾Ý£¬»á½«Æä·Åµ½RedisÀïÃæ¡£ÔÚDIM²ãÖ÷Òª×öһЩ¸ß²¢·¢Î¬¶ÈµÄ²éѯ¹ØÁª£¬Ò»°ã½«Æä´æ·ÅÔÚHBaseÀïÃæ£¬¶ÔÓÚDIM²ã±È¼Û¸´ÔÓ£¬ÐèÒª×ۺϿ¼ÂǶÔÓÚÊý¾ÝÂ䵨µÄÒªÇóÒÔ¼°¾ßÌåµÄ²éѯÒýÇæÀ´Ñ¡Ôñ²»Í¬µÄ´æ´¢·½Ê½¡£¶ÔÓÚ³£¼ûµÄÖ¸±ê»ã×ÜÄ£ÐÍÖ±½Ó·ÅÔÚMySQLÀïÃæ£¬Î¬¶È±È½Ï¶àµÄ¡¢Ð´Èë¸üбȽϴóµÄÄ£ÐÍ»á·ÅÔÚHBaseÀïÃæ£¬»¹ÓÐÃ÷ϸÊý¾ÝÐèÒª×öһЩ¶àά·ÖÎö»òÕß¹ØÁª»á½«Æä´æ´¢ÔÚGreenplumÀïÃæ£¬»¹ÓÐÒ»ÖÖÊÇά¶È±È½Ï¶à¡¢ÐèÒª×öÅÅÐò¡¢²éѯҪÇó±È½Ï¸ßµÄ£¬Èç»î¶¯ÆÚ¼äÓû§µÄÏúÊÛÁбíµÈ´óÁбíÖ±½Ó´æ´¢ÔÚRedisÀïÃæ¡£
ÖªºõʵʱÊý²Ö¼Ü¹¹Êµ¼ùÓëÑݽø
±¾ÎÄÖ÷Òª½²ÊöÖªºõµÄʵʱÊý²Öʵ¼ùÒÔ¼°¼Ü¹¹µÄÑݽø£¬Õâ°üÀ¨ÒÔϼ¸¸ö·½Ã棺
ʵʱÊý²Ö 1.0 °æ±¾£¬Ö÷Ì⣺ETL Â߼ʵʱ»¯£¬¼¼Êõ·½°¸£ºSpark Streaming¡£
ʵʱÊý²Ö 2.0 °æ±¾£¬Ö÷Ì⣺Êý¾Ý·Ö²ã£¬Ö¸±ê¼ÆËãʵʱ»¯£¬¼¼Êõ·½°¸£ºFlink Streaming¡£
ʵʱÊý²ÖδÀ´Õ¹Íû£ºStreaming SQL ƽ̨»¯£¬ÔªÐÅÏ¢¹ÜÀíϵͳ»¯£¬½á¹ûÑéÊÕ×Ô¶¯»¯¡£

ʵʱÊý²Ö 1.0
µÚÒ»²¿·ÖÊÇÊý¾Ý²É¼¯£¬ÓÉÈý¶Ë SDK ²É¼¯Êý¾Ý²¢Í¨¹ý Log Collector Server ·¢Ë͵½
Kafka¡£µÚ¶þ²¿·ÖÊÇÊý¾Ý ETL£¬Ñ¡ÔñÁË Spark Streaming ×÷ΪʵʱÊý¾ÝµÄ´¦Àí¿ò¼Ü£¬Ö÷ÒªÍê³É¶ÔÔʼÊý¾ÝµÄÇåÏ´ºÍ¼Ó¹¤²¢·ÖʵʱºÍÀëÏßµ¼Èë
Druid¡£µÚÈý²¿·ÖÊÇÊý¾Ý¿ÉÊÓ»¯£¬ÓÉ Druid ¸ºÔð¼ÆËãÖ¸±ê²¢Í¨¹ý Web Server ÅäºÏǰ¶ËÍê³ÉÊý¾Ý¿ÉÊÓ»¯¡£
1.0 °æ±¾µÄʵʱÊý²ÖÓÐÒÔϼ¸¸ö²»×㣺
ËùÓеÄÁ÷Á¿Êý¾Ý´æ·ÅÔÚͬһ¸ö Kafka Topic ÖУ¬Èç¹ûÏÂÓÎÿ¸öÒµÎñÏß¶¼ÒªÏû·Ñ£¬Õâ»áµ¼ÖÂÈ«Á¿Êý¾Ý±»Ïû·Ñ¶à´Î£¬Kafka
³öÁ÷Á¿Ì«¸ßÎÞ·¨Âú×ã¸ÃÐèÇó¡£
ËùÓеÄÖ¸±ê¼ÆËãÈ«²¿ÓÉ Druid ³Ðµ££¬Druid ͬʱ¼æ¹ËʵʱÊý¾ÝÔ´ºÍÀëÏßÊý¾ÝÔ´µÄ²éѯ£¬Ëæ×ÅÊý¾ÝÁ¿µÄ±©ÕÇ
Druid Îȶ¨ÐÔ¼±¾çϽµ£¬Õâµ¼Ö¸÷¸öÒµÎñµÄºËÐı¨±í²»ÄÜÎȶ¨²ú³ö¡£
ÓÉÓÚÿ¸öÒµÎñʹÓÃͬһ¸öÁ÷Á¿Êý¾ÝÔ´ÅäÖñ¨±í£¬µ¼Ö²éѯЧÂʵÍÏ£¬Í¬Ê±ÎÞ·¨¶ÔÒµÎñ×öÊý¾Ý¸ôÀëºÍ³É±¾¼ÆËã¡£
Ëæ×ÅÊý¾ÝÁ¿µÄ±©ÕÇ£¬Druid ÖеÄÁ÷Á¿Êý¾ÝÔ´¾³£²éѯ³¬Ê±Í¬Ê±¸÷ÒµÎñÏû·ÑʵʱÊý¾ÝµÄÐèÇóÒ²¿ªÊ¼Ôö¶à£¬Èç¹û¼ÌÐøÑØÓÃʵʱÊý²Ö
1.0 ¼Ü¹¹£¬ÐèÒª¸¶³ö´óÁ¿µÄ¶îÍâ³É±¾¡£ÓÚÊÇ£¬ÔÚʵʱÊý²Ö 1.0 µÄ»ù´¡ÉÏ£¬ÎÒÃǽ¨Á¢ÆðÁËʵʱÊý²Ö 2.0£¬ÊáÀí³öÁËеļܹ¹Éè¼Æ²¢¿ªÊ¼×ÅÊÖ½¨Á¢ÊµÊ±Êý²ÖÌåϵ£¬Ðµļܹ¹ÈçÏÂͼËùʾ¡£

Ïà±ÈʵʱÊý²Ö 1.0 ÒÔ Spark Streaming ×÷ΪÖ÷ҪʵÏÖ¼¼Êõ£¬ÔÚʵʱÊý²Ö 2.0 ÖУ¬ÎÒÃǽ«
Flink ×÷Ϊָ±ê»ã×ܲãµÄÖ÷Òª¼ÆËã¿ò¼Ü¡£Flink Ïà±È Spark Streaming ÓиüÃ÷ÏÔµÄÓÅÊÆ£¬Ö÷ÒªÌåÏÖÔÚ£ºµÍÑÓ³Ù¡¢Exactly-once
ÓïÒåÖ§³Ö¡¢Streaming SQL Ö§³Ö¡¢×´Ì¬¹ÜÀí¡¢·á¸»µÄʱ¼äÀàÐͺʹ°¿Ú¼ÆËã¡¢CEP Ö§³ÖµÈ¡£
´ÓʵʱÊý²Ö 1.0 µ½ 2.0£¬²»¹ÜÊÇÊý¾Ý¼Ü¹¹»¹ÊǼ¼Êõ·½°¸£¬ÎÒÃÇÔÚÉî¶ÈºÍ¹ã¶ÈÉ϶¼ÓÐÁ˸ü¶àµÄ»ýÀÛ¡£Ëæ×Ź«Ë¾ÒµÎñµÄ¿ìËÙ·¢Õ¹ÒÔ¼°Ð¼¼ÊõµÄµ®Éú£¬ÊµÊ±Êý²ÖÒ²»á²»¶ÏµÄµü´úÓÅ»¯¡£¶ÌÆÚ¿ÉÔ¤¼ûµÄÎÒÃÇ»á´ÓÒÔÏ·½Ãæ½øÒ»²½ÌáÉýʵʱÊý²ÖµÄ·þÎñÄÜÁ¦£º
Streaming SQL ƽ̨»¯¡£Ä¿Ç° Streaming SQL ÈÎÎñÊÇÒÔ´úÂ뿪·¢ maven
´ò°üµÄ·½Ê½Ìá½»ÈÎÎñ£¬¿ª·¢³É±¾¸ß£¬ºóÆÚËæ×Å Streaming SQL ƽ̨µÄÉÏÏߣ¬ÊµÊ±Êý²ÖµÄ¿ª·¢·½Ê½Ò²»áÓÉ
Jar °üת±äΪ SQL Îļþ¡£
ʵʱÊý¾ÝÔªÐÅÏ¢¹ÜÀíϵͳ»¯¡£¶ÔÊý²ÖÔªÐÅÏ¢µÄ¹ÜÀí¿ÉÒÔ´ó·ù¶È½µµÍʹÓÃÊý¾ÝµÄ³É±¾£¬ÀëÏßÊý²ÖµÄÔªÐÅÏ¢¹ÜÀíÒѾ»ù±¾ÍêÉÆ£¬ÊµÊ±Êý²ÖµÄÔªÐÅÏ¢¹ÜÀí²Å¸Õ¸Õ¿ªÊ¼¡£
ʵʱÊý²Ö½á¹ûÑéÊÕ×Ô¶¯»¯¡£¶Ôʵʱ½á¹ûµÄÑéÊÕÖ»ÄܽèÖúÓëÀëÏßÊý¾ÝÖ¸±ê¶Ô±ÈµÄ·½Ê½£¬ÒÔ
Hive ºÍ Kafka Êý¾ÝԴΪÀý£¬·Ö±ðÖ´ÐÐ Hive SQL ºÍ Flink SQL£¬Í³¼Æ½á¹û²¢¶Ô±ÈÊÇ·ñÒ»ÖÂʵÏÖʵʱ½á¹ûÑéÊÕµÄ×Ô¶¯»¯¡£
OPPO ʵʱÊý²Ö½ÒÃØ£º´Ó¶¥²ãÉè¼ÆÊµÏÖÀëÏßÓëʵʱµÄƽ»¬Ç¨ÒÆ
ÒÔÊý²ÖΪÖÐÐĵÄÊý¾Ý¼Ü¹¹
ÔÚ¹ýÈ¥¼¸ÄêµÄʱ¼äÀïÃæ£¬OPPO ÄÚ²¿µÄÕâÌ×ÒÔÊý²ÖΪºËÐĵÄÊý¾Ý¼Ü¹¹ÒѾÖ𽥿ªÊ¼³ÉÊìÁË¡£

ÀëÏßµ½ÊµÊ±Êý²ÖµÄƽ»¬Ç¨ÒÆ
OPPO Ï£ÍûËùÉè¼Æ³öÀ´µÄʵʱÊý²ÖÄܹ»ÊµÏÖ´ÓÀëÏßµ½ÊµÊ±µÄƽ»¬Ç¨ÒÆ£¬Ö®Ç°´ó¼ÒÈçºÎʹÓúͿª·¢ÀëÏßÊý²Ö£¬Èç½ñµ½ÁËʵʱÊý²ÖҲϣÍû´ó¼ÒÈçºÎ¿ª·¢ºÍʹÓá£Í¨³£¶øÑÔ£¬µ±Éè¼ÆÒ»¿î²úÆ·»òÕ߯½Ì¨µÄʱºò£¬¿ÉÒÔ»®·ÖΪÁ½²ã£¬¼´µ×²ãʵÏÖºÍÉϲã³éÏó¡£¶ÔÓڵײãʵÏÖ¶øÑÔ£¬¿ÉÄÜ»áÓв»Í¬µÄ¼¼Êõ£¬´Ó
Hive µ½ Flink£¬´Ó HDFS µ½ Kafka¡£¶øÔÚÉϲã³éÏó¶øÑÔ£¬ÔòÏ£Íû¶ÔÓÚÓû§¶øÑÔÊÇ͸Ã÷µÄ¡£

ʵʱÊý²ÖµÄ²ã¼¶»®·Ö
ÈçÏÂͼËùʾµÄÊÇ OPPO ʵʱÊý²ÖµÄ·Ö²ã½á¹¹£¬´Ó½ÓÈë²ã¹ýÀ´Ö®ºó£¬ËùÓеÄÊý¾Ý¶¼ÊÇ»áÓà Kafka À´Ö§³ÅµÄ£¬Êý¾Ý½ÓÈë½øÀ´·Åµ½
Kafka ÀïÃæÊµÏÖ ODS ²ã£¬È»ºóʹÓà Flink SQL ʵÏÖÊý¾ÝµÄÇåÏ´£¬È»ºó¾Í±äµ½ÁË DWD
²ã£¬ÖмäʹÓà Flink SQL ʵÏÖһЩ¾ÛºÏ²Ù×÷£¬¾Íµ½ÁË ADS ²ã£¬×îºó¸ù¾Ý²»Í¬µÄÒµÎñʹÓó¡¾°ÔÙµ¼Èëµ½ESµÈϵͳÖÐÈ¥¡£µ±È»£¬ÆäÖеÄһЩά¶È²ãλÓÚ
MySQL »òÕß Hive ÖС£

SQLһͳÌìϵÄÊý¾Ý¼Ü¹¹
¶ÔÓÚÊý²ÖÁìÓòµÄ½üÆÚ·¢Õ¹¶øÑÔ£¬ÆäÖкÜÓÐÒâ˼µÄÒ»µãÊÇ£ºÎÞÂÛÊÇÀëÏß»¹ÊÇʵʱµÄÊý¾Ý¼Ü¹¹£¬¶¼ÂýÂýÑݽø³ÉÁË SQL
һͳÌìϵļܹ¹¡£ÎÞÂÛÊÇÀëÏß»¹ÊÇʵʱÊÇÊý¾Ý²Ö¿â£¬ÎÞÂÛÊǽÓÈ룬²éѯ¡¢¿ª·¢»¹ÊÇÒµÎñϵͳ¶¼ÊÇÔÚÉÏÃæÐ´ SQL
µÄ·½Ê½¡£

дÔÚ×îºóµÄ»°
×ܽáÏ£¬ÊµÊ±Êý²ÖÖ÷ÒªÓÐÁ½¸öÒªµã¡£Ê×ÏÈÊÇ·Ö²ãÉè¼ÆÉÏ£¬Ò»°ãÒ²ÊDzο¼ÀëÏßÊý²ÖµÄÉè¼Æ£¬Í¨³£»á·ÖΪODS²Ù×÷Êý¾Ý²ã¡¢DWDÃ÷ϸ²ã¡¢DWS»ã×ܲãÒÔ¼°ADSÓ¦Óò㣬¿ÉÄÜ»¹»á·Ö³öÒ»²ãDIMά¶ÈÊý¾Ý²ã¡£ÁíÍâ·Ö²ãÉè¼ÆÉÏÒ²Óв»Í¬µÄ˼·£¬±ÈÈç¿ÉÒÔ½«DWSºÍADS¹éΪDMÊý¾Ý¼¯ÊÐ²ã£¬ÍøÒ×ÑÏÑ¡¾ÍÊÇÕâÑùÉè¼ÆµÄ¡£
¼¼ÊõÑ¡ÐÍÉÏ£¬ÀëÏßÊý²ÖÒ»°ãÒÀÍÐHDFS»òHive¹¹½¨£¬Ñ¡ÔñMR»òSpark¼ÆËãÒýÇæ£»ÊµÊ±Êý²Ö´æ´¢²ã¸ü¶àÊÇÑ¡ÔñKafkaµÈÏûÏ¢ÒýÇæ£¬Í¨³£Ã÷ϸ²ãºÍ»ã×ܲ㶼·ÅÔÚKafka£¬¼ÆËã²ãÔò¶àÊÇÑ¡ÔñFlink/Spark
Streaming/Storm£¬Õâ·½ÃæFlink¸üÓÐÓÅÊÆ£¬ÉçÇøÒ²¸üÇãÏòÓÚÑ¡ÔñFlink¡£ |