mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-13 22:30:37 +08:00
commit
4f2240968a
@ -1,150 +0,0 @@
|
|||||||
Translating by qhwdw
|
|
||||||
Getting Started Analyzing Twitter Data in Apache Kafka through KSQL
|
|
||||||
============================================================
|
|
||||||
|
|
||||||
[KSQL][8] is the open source streaming SQL engine for Apache Kafka. It lets you do sophisticated stream processing on Kafka topics, easily, using a simple and interactive SQL interface. In this short article we’ll see how easy it is to get up and running with a sandbox for exploring it, using everyone’s favourite demo streaming data source: Twitter. We’ll go from ingesting the raw stream of tweets, through to filtering it with predicates in KSQL, to building aggregates such as counting the number of tweets per user per hour.
|
|
||||||
|
|
||||||
![](https://www.confluent.io/wp-content/uploads/tweet_kafka-1024x617.png)
|
|
||||||
|
|
||||||
First up, [go grab a copy of Confluent Platform][9]. I’m using the RPM but you can use [tar, zip, etc][10] if you want to. Start the Confluent stack up:
|
|
||||||
|
|
||||||
`$ confluent start`
|
|
||||||
|
|
||||||
(Here’s a [quick tutorial on the confluent CLI][11] if you’re interested!)
|
|
||||||
|
|
||||||
We’ll use Kafka Connect to pull the data from Twitter. The Twitter Connector can be found [on GitHub here][12]. To install it, simply do the following:
|
|
||||||
|
|
||||||
`# Clone the git repo
|
|
||||||
cd /home/rmoff
|
|
||||||
git clone https://github.com/jcustenborder/kafka-connect-twitter.git`
|
|
||||||
|
|
||||||
`# Compile the code
|
|
||||||
cd kafka-connect-twitter
|
|
||||||
mvn clean package`
|
|
||||||
|
|
||||||
To get Kafka Connect [to pick up the connector][13] that we’ve built, you’ll have to modify the configuration file. Since we’re using the Confluent CLI, the configuration file is actually `etc/schema-registry/connect-avro-distributed.properties`, so go modify that and add to it:
|
|
||||||
|
|
||||||
`plugin.path=/home/rmoff/kafka-connect-twitter/target/kafka-connect-twitter-0.2-SNAPSHOT.tar.gz`
|
|
||||||
|
|
||||||
Restart Kafka Connect:
|
|
||||||
`confluent stop connect
|
|
||||||
confluent start connect`
|
|
||||||
|
|
||||||
Once you’ve installed the plugin, you can easily configure it. You can use the Kafka Connect REST API directly, or create your configuration file, which is what I’ll do here. You’ll need to head over to [Twitter to grab your API keys first][14].
|
|
||||||
|
|
||||||
Assuming you’ve written this to `/home/rmoff/twitter-source.json`, you can now run:
|
|
||||||
|
|
||||||
`$ confluent load twitter_source -d /home/rmoff/twitter-source.json`
|
|
||||||
|
|
||||||
And then tweets from everyone’s favourite internet meme star start [rick]-rolling in…
|
|
||||||
|
|
||||||
Now let’s fire up KSQL! First off, download and build it:
|
|
||||||
|
|
||||||
`cd /home/rmoff `
|
|
||||||
`git clone https://github.com/confluentinc/ksql.git `
|
|
||||||
`cd /home/rmoff/ksql `
|
|
||||||
`mvn clean compile install -DskipTests`
|
|
||||||
|
|
||||||
Once it’s built, let’s run it!
|
|
||||||
|
|
||||||
`./bin/ksql-cli local --bootstrap-server localhost:9092`
|
|
||||||
|
|
||||||
Using KSQL, we can take our data that’s held in Kafka topics and query it. First, we need to tell KSQL what the schema of the data in the topic is. A twitter message is actually a pretty huge JSON object, but for brevity let’s just pick a couple of columns to start with:
|
|
||||||
|
|
||||||
`ksql> CREATE STREAM twitter_raw (CreatedAt BIGINT, Id BIGINT, Text VARCHAR) WITH (KAFKA_TOPIC='twitter_json_01', VALUE_FORMAT='JSON');`
|
|
||||||
`Message `
|
|
||||||
`----------------`
|
|
||||||
`Stream created`
|
|
||||||
|
|
||||||
With the schema defined, we can query the stream. To get KSQL to show data from the start of the topic (rather than the current point in time, which is the default), run:
|
|
||||||
|
|
||||||
`ksql> SET 'auto.offset.reset' = 'earliest'; `
|
|
||||||
`Successfully changed local property 'auto.offset.reset' from 'null' to 'earliest'`
|
|
||||||
|
|
||||||
And now let’s see the data. We’ll select just one row using the LIMIT clause:
|
|
||||||
|
|
||||||
Now let’s redefine the stream with all the contents of the tweet payload now defined and available to us:
|
|
||||||
|
|
||||||
Now we can manipulate and examine our data more closely, using normal SQL queries:
|
|
||||||
|
|
||||||
Note that there’s no LIMIT clause, so you’ll see on screen the results of the _continuous query_ . Unlike a query on a relational table that returns a definite number of results, a continuous query is running on unbounded streaming data, so it always has the potential to return more records. Hit Ctrl-C to cancel and return to the KSQL prompt. In the above query we’re doing a few things:
|
|
||||||
|
|
||||||
* TIMESTAMPTOSTRING to convert the timestamp from epoch to a human-readable format
|
|
||||||
|
|
||||||
* EXTRACTJSONFIELD to show one of the nested user fields from the source, which looks like:
|
|
||||||
|
|
||||||
* Applying predicates to what’s shown, using pattern matching against the hashtag, forced to lower case with LCASE.
|
|
||||||
|
|
||||||
For a list of supported functions, see [the KSQL documentation][15].
|
|
||||||
|
|
||||||
We can create a derived stream from this data:
|
|
||||||
|
|
||||||
and query the derived stream:
|
|
||||||
|
|
||||||
Before we finish, let’s see how to do some aggregation.
|
|
||||||
|
|
||||||
You’ll probably get a screenful of results; this is because KSQL is actually emitting the aggregation values for the given hourly window each time it updates. Since we’ve set KSQL to read all messages on the topic (`SET 'auto.offset.reset' = 'earliest';`) it’s reading all of these messages at once and calculating the aggregation updates as it goes. There’s actually a subtlety in what’s going on here that’s worth digging into. Our inbound stream of tweets is just that—a stream. But now that we are creating aggregates, we have actually created a table. A table is a snapshot of a given key’s values at a given point in time. KSQL aggregates data based on the event time of the message, and handles late arriving data by simply restating that relevant window if it updates. Confused? We hope not, but let’s see if we can illustrate this with an example. We’ll declare our aggregate as an actual table:
|
|
||||||
|
|
||||||
Looking at the columns in the table, there are two implicit ones in addition to those we asked for:
|
|
||||||
|
|
||||||
`ksql> DESCRIBE user_tweet_count;
|
|
||||||
|
|
||||||
Field | Type
|
|
||||||
-----------------------------------
|
|
||||||
ROWTIME | BIGINT
|
|
||||||
ROWKEY | VARCHAR(STRING)
|
|
||||||
USER_SCREENNAME | VARCHAR(STRING)
|
|
||||||
TWEET_COUNT | BIGINT
|
|
||||||
ksql>`
|
|
||||||
|
|
||||||
Let’s see what’s in these:
|
|
||||||
|
|
||||||
The `ROWTIME` is the window start time, the `ROWKEY` is a composite of the `GROUP BY`(`USER_SCREENNAME`) plus the window. So we can tidy this up a bit by creating an additional derived table:
|
|
||||||
|
|
||||||
Now it’s easy to query and see the data that we’re interested in:
|
|
||||||
|
|
||||||
### Conclusion
|
|
||||||
|
|
||||||
So there we have it! We’re taking data from Kafka, and easily exploring it using KSQL. Not only can we explore and transform the data, we can use KSQL to easily build stream processing from streams and tables.
|
|
||||||
|
|
||||||
![](https://www.confluent.io/wp-content/uploads/user_tweet-1024x569.png)
|
|
||||||
|
|
||||||
If you’re interested in what KSQL can do, check out:
|
|
||||||
|
|
||||||
* The [KSQL announcement blog post][1]
|
|
||||||
|
|
||||||
* [Our recent KSQL webinar][2] and [Kafka Summit keynote][3]
|
|
||||||
|
|
||||||
* The [clickstream demo][4] that’s available as part of [KSQL’s GitHub repo][5]
|
|
||||||
|
|
||||||
* A [presentation that I did recently][6] showing how KSQL can underpin a streaming ETL based platform.
|
|
||||||
|
|
||||||
Remember that KSQL is currently in developer preview. Feel free to raise any issues on the KSQL github repo, or come along to the #ksql channel on our [community Slack group][16].
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
via: https://www.confluent.io/blog/using-ksql-to-analyse-query-and-transform-data-in-kafka
|
|
||||||
|
|
||||||
作者:[Robin Moffatt ][a]
|
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
||||||
|
|
||||||
[a]:https://www.confluent.io/blog/author/robin/
|
|
||||||
[1]:https://www.confluent.io/blog/ksql-open-source-streaming-sql-for-apache-kafka/
|
|
||||||
[2]:https://www.confluent.io/online-talk/ksql-streaming-sql-for-apache-kafka/
|
|
||||||
[3]:https://www.confluent.io/kafka-summit-sf17/Databases-and-Stream-Processing-1
|
|
||||||
[4]:https://www.youtube.com/watch?v=A45uRzJiv7I
|
|
||||||
[5]:https://github.com/confluentinc/ksql
|
|
||||||
[6]:https://speakerdeck.com/rmoff/look-ma-no-code-building-streaming-data-pipelines-with-apache-kafka
|
|
||||||
[7]:https://www.confluent.io/blog/author/robin/
|
|
||||||
[8]:https://github.com/confluentinc/ksql/
|
|
||||||
[9]:https://www.confluent.io/download/
|
|
||||||
[10]:https://docs.confluent.io/current/installation.html?
|
|
||||||
[11]:https://www.youtube.com/watch?v=ZKqBptBHZTg
|
|
||||||
[12]:https://github.com/jcustenborder/kafka-connect-twitter
|
|
||||||
[13]:https://docs.confluent.io/current/connect/userguide.html#connect-installing-plugins
|
|
||||||
[14]:https://apps.twitter.com/
|
|
||||||
[15]:https://github.com/confluentinc/ksql/blob/0.1.x/docs/syntax-reference.md
|
|
||||||
[16]:https://slackpass.io/confluentcommunity
|
|
@ -0,0 +1,149 @@
|
|||||||
|
在 Apache Kafka 中通过 KSQL 分析 Twitter 数据入门
|
||||||
|
============================================================
|
||||||
|
|
||||||
|
[KSQL][8] 是 Apache Kafka 中的开源的流式 SQL 引擎。它可以让你在 Kafka 主题(topics)上,使用一个简单的并且是交互式的SQL接口,很容易地做一些复杂的流处理。在这个短文中,我们将看到怎么去很容易地配置并运行在一个沙箱中去探索它,使用大家都喜欢的一个演示数据库源: Twitter。我们将去从 teewts 的行流中获取,通过使用 KSQL 中的条件去过滤它。去构建一个合计,如统计 tweets 每个用户每小时的数量。
|
||||||
|
|
||||||
|
![](https://www.confluent.io/wp-content/uploads/tweet_kafka-1024x617.png)
|
||||||
|
|
||||||
|
首先, [抓取一个汇总平台的拷贝][9]。我使用的是 RPM 但是,如果你想去使用的话,你也可以使用 [tar, zip, etc][10] 。启动 Confluent:
|
||||||
|
|
||||||
|
`$ confluent start`
|
||||||
|
|
||||||
|
(如果你感兴趣,这是一个 [在Confluent CLI 上的快速教程][11] )
|
||||||
|
|
||||||
|
我们将使用 Kafka 连接去从 Twitter 上拖数据。 Twitter 连接器可以在 [on GitHub here][12]上找到。去安装它,像下面这样操作:
|
||||||
|
|
||||||
|
`# Clone the git repo
|
||||||
|
cd /home/rmoff
|
||||||
|
git clone https://github.com/jcustenborder/kafka-connect-twitter.git`
|
||||||
|
|
||||||
|
`# Compile the code
|
||||||
|
cd kafka-connect-twitter
|
||||||
|
mvn clean package`
|
||||||
|
|
||||||
|
从我们建立的 [连接器][13] 上建立连接, 你要去修改配置文件.自从我们使用 Confluent CLI, 真实的配置文件是 `etc/schema-registry/connect-avro-distributed.properties`, 因此去修改它并增加如下内容:
|
||||||
|
|
||||||
|
`plugin.path=/home/rmoff/kafka-connect-twitter/target/kafka-connect-twitter-0.2-SNAPSHOT.tar.gz`
|
||||||
|
|
||||||
|
重启动 Kafka 连接:
|
||||||
|
`confluent stop connect
|
||||||
|
confluent start connect`
|
||||||
|
|
||||||
|
一旦你安装了插件,你可以很容易地去配置它。你可以直接使用 Kafka Connect REST API ,或者创建你的配置文件,这就是我要在这里做的。如果你需要全部的方法查看 [Twitter to grab your API keys first][14]。
|
||||||
|
|
||||||
|
假设你写这些到 `/home/rmoff/twitter-source.json`,你可以现在运行:
|
||||||
|
|
||||||
|
`$ confluent load twitter_source -d /home/rmoff/twitter-source.json`
|
||||||
|
|
||||||
|
然后 tweets 从大家都喜欢的网络明星 [rick]-rolling in…开始
|
||||||
|
|
||||||
|
现在我们从 KSQL 开始 ! 马上去下载并构建它:
|
||||||
|
|
||||||
|
`cd /home/rmoff `
|
||||||
|
`git clone https://github.com/confluentinc/ksql.git `
|
||||||
|
`cd /home/rmoff/ksql `
|
||||||
|
`mvn clean compile install -DskipTests`
|
||||||
|
|
||||||
|
构建完成后,让我们来运行它:
|
||||||
|
|
||||||
|
`./bin/ksql-cli local --bootstrap-server localhost:9092`
|
||||||
|
|
||||||
|
使用 KSQL, 我们可以让我们的数据保留在 Kafka 话题上并可以查询它。首先,我们需要去告诉 KSQL 主题上的数据模式(schema)是什么,一个 twitter 消息是一个真实的非常好的巨大的 JSON 对象, 但是,为了简洁,我们只好选出几个行去开始它:
|
||||||
|
|
||||||
|
`ksql> CREATE STREAM twitter_raw (CreatedAt BIGINT, Id BIGINT, Text VARCHAR) WITH (KAFKA_TOPIC='twitter_json_01', VALUE_FORMAT='JSON');`
|
||||||
|
`Message `
|
||||||
|
`----------------`
|
||||||
|
`Stream created`
|
||||||
|
|
||||||
|
在定义的模式中,我们可以查询这些流。使用 KSQL 去展示从开始的主题中取得的数据 (而不是当前时间点,它是缺省的),运行:
|
||||||
|
|
||||||
|
`ksql> SET 'auto.offset.reset' = 'earliest'; `
|
||||||
|
`Successfully changed local property 'auto.offset.reset' from 'null' to 'earliest'`
|
||||||
|
|
||||||
|
现在,让我们看看这些数据,我们将使用 LIMIT 从句仅检索一行:
|
||||||
|
|
||||||
|
现在,让我们使用刚才定义的可用的 tweet 负荷的全部内容重新定义流:
|
||||||
|
|
||||||
|
现在,我们可以操作和检查更多的最近的数据,使用一般的 SQL 查询:
|
||||||
|
|
||||||
|
注意这里没有 LIMIT 从句,因此,你将在屏幕上看到 _continuous query_ 的结果。不像关系表中返回一个确定数量结果的查询,一个运行在无限的流式数据上的持续查询, 因此,它总是可能返回更多的记录。点击 Ctrl-C 去中断燕返回到 KSQL 提示符。在以上的查询中我们做了一些事情:
|
||||||
|
|
||||||
|
* TIMESTAMPTOSTRING 去转换时间戳从 epoch 到人类可读格式。(译者注: epoch 指的是一个特定的时间 1970-01-01 00:00:00 UTC)
|
||||||
|
|
||||||
|
* EXTRACTJSONFIELD 去展示源中嵌套的用户域中的一个,它看起来像:
|
||||||
|
|
||||||
|
* 应用谓语去展示内容,对#(hashtag)使用模式匹配, 使用 LCASE 去强制小写字母。(译者注:hashtag,twitter中用来标注线索主题的标签)
|
||||||
|
|
||||||
|
关于支持的功能列表,查看 [the KSQL documentation][15]。
|
||||||
|
|
||||||
|
我们可以创建一个从这个数据中得到的流:
|
||||||
|
|
||||||
|
并且查询这个得到的流:
|
||||||
|
|
||||||
|
在我们完成之前,让我们去看一下怎么去做一些聚合。
|
||||||
|
|
||||||
|
你将可能得到满屏幕的结果;这是因为 KSQL 在每次给定的时间窗口更新时实际发出聚合值。自从我们设置 KSQL 去读取在主题 (`SET 'auto.offset.reset' = 'earliest';`) 上的全部消息,它是一次性读取这些所有的消息并计算聚合更新。这里有一个微妙之处值得去深入研究。我们的入站 tweets 流正好就是一个流。但是,现有它不能创建聚合,我们实际上是创建了一个表。一个表是在给定时间点的给定键的值的一个快照。 KSQL 聚合数据基于消息事件的时间,并且如果它更新了,通过简单的相关窗口重申去操作后面到达的数据。困惑了吗? 我希望没有,但是,让我们看一下,如果我们可以用这个例子去说明。 我们将申明我们的聚合作为一个真实的表:
|
||||||
|
|
||||||
|
看表中的列,这里除了我们要求的外,还有两个隐含列:
|
||||||
|
|
||||||
|
`ksql> DESCRIBE user_tweet_count;
|
||||||
|
|
||||||
|
Field | Type
|
||||||
|
-----------------------------------
|
||||||
|
ROWTIME | BIGINT
|
||||||
|
ROWKEY | VARCHAR(STRING)
|
||||||
|
USER_SCREENNAME | VARCHAR(STRING)
|
||||||
|
TWEET_COUNT | BIGINT
|
||||||
|
ksql>`
|
||||||
|
|
||||||
|
我们看一下这些是什么:
|
||||||
|
|
||||||
|
`ROWTIME` 是窗口开始时间, `ROWKEY` 是 `GROUP BY`(`USER_SCREENNAME`) 加上窗口的组合。因此,我们可以通过创建另外一个衍生的表来整理一下:
|
||||||
|
|
||||||
|
现在它更易于查询和查看我们感兴趣的数据:
|
||||||
|
|
||||||
|
### 结论
|
||||||
|
|
||||||
|
所以我们有了它! 我们可以从 Kafka 中取得数据, 并且很容易使用 KSQL 去探索它。 而不仅是去浏览和转换数据,我们可以很容易地使用 KSQL 从流和表中建立流处理。
|
||||||
|
|
||||||
|
![](https://www.confluent.io/wp-content/uploads/user_tweet-1024x569.png)
|
||||||
|
|
||||||
|
如果你对 KSQL 能够做什么感兴趣,去查看:
|
||||||
|
|
||||||
|
* [KSQL announcement blog post][1]
|
||||||
|
|
||||||
|
* [Our recent KSQL webinar][2] 和 [Kafka Summit keynote][3]
|
||||||
|
|
||||||
|
* [clickstream demo][4] 它可用于 [KSQL’s GitHub repo][5] 的一部分
|
||||||
|
|
||||||
|
* [presentation that I did recently][6] 展示了 KSQL 如何去支持基于流的 ETL 平台
|
||||||
|
|
||||||
|
记住,KSQL 现在正处于开发者预览版中。 欢迎在 KSQL github repo 上提出任何问题, 或者去我们的 [community Slack group][16] 的 #KSQL通道。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://www.confluent.io/blog/using-ksql-to-analyse-query-and-transform-data-in-kafka
|
||||||
|
|
||||||
|
作者:[Robin Moffatt ][a]
|
||||||
|
译者:[qhwdw](https://github.com/qhwdw)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:https://www.confluent.io/blog/author/robin/
|
||||||
|
[1]:https://www.confluent.io/blog/ksql-open-source-streaming-sql-for-apache-kafka/
|
||||||
|
[2]:https://www.confluent.io/online-talk/ksql-streaming-sql-for-apache-kafka/
|
||||||
|
[3]:https://www.confluent.io/kafka-summit-sf17/Databases-and-Stream-Processing-1
|
||||||
|
[4]:https://www.youtube.com/watch?v=A45uRzJiv7I
|
||||||
|
[5]:https://github.com/confluentinc/ksql
|
||||||
|
[6]:https://speakerdeck.com/rmoff/look-ma-no-code-building-streaming-data-pipelines-with-apache-kafka
|
||||||
|
[7]:https://www.confluent.io/blog/author/robin/
|
||||||
|
[8]:https://github.com/confluentinc/ksql/
|
||||||
|
[9]:https://www.confluent.io/download/
|
||||||
|
[10]:https://docs.confluent.io/current/installation.html?
|
||||||
|
[11]:https://www.youtube.com/watch?v=ZKqBptBHZTg
|
||||||
|
[12]:https://github.com/jcustenborder/kafka-connect-twitter
|
||||||
|
[13]:https://docs.confluent.io/current/connect/userguide.html#connect-installing-plugins
|
||||||
|
[14]:https://apps.twitter.com/
|
||||||
|
[15]:https://github.com/confluentinc/ksql/blob/0.1.x/docs/syntax-reference.md
|
||||||
|
[16]:https://slackpass.io/confluentcommunity
|
Loading…
Reference in New Issue
Block a user