Flink-1.9流计算开发:一、最初的开始HELLO WORLD

Flink-1.9流计算开发:一、最初的开始HELLO WORLD

首先我们需要需要了解的一个概念是Apache Flink支持处理流式计算(stream)和批量计算(batch),但是在目前版本中这两种计算方式各自拥有自己独立的API,本系列文章只讨论流式计算(stream)。

学习本系列的必要条件是已安装Maven 3.0.4+,java8。

通过maven创建开发模板

    $ mvn archetype:generate                               \
      -DarchetypeGroupId=org.apache.flink              \
      -DarchetypeArtifactId=flink-quickstart-java      \
      -DarchetypeVersion=1.9.0

安装过程中需要填写对应的信息,如下图

将项目导入IDE

导入后的项目,目录结构如下图所示:

导入项目后将projects facets修改为java8:

如果项目缺少Maven Dependencies,则在项目的.classpath文件中添加如下配置:

<classpathentry exported="true" kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
	<attributes>
		<attribute name="maven.pomderived" value="true"/>
		<attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/>
    </attributes>
</classpathentry>

编写HELLO WORLD

修改pom.xml文件中的log包的作用域,删掉。
打开StreamingJob.java文件,编写如下代码:

public class StreamingJob {
	private static final Logger LOG = LoggerFactory.getLogger(StreamingJob.class);
	public static void main(String[] args) throws Exception {
		// set up the streaming execution environment
		final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
		DataStreamSource<String> dataSource = env.fromElements(new String("hello world!"));
		dataSource.addSink(new SinkFunction<String>() {
			@Override
			public void invoke(String value) throws Exception {
				LOG.info("输出数据:"+value);
			}
		});
		// execute program
		env.execute("Flink Streaming Java API Skeleton");
	}
}

运行此程序得到执行结果如下:

11:38:50,863 INFO  jar.StreamingJob                                              - 输出数据:hello world!

参考文章:

  1. Project Template for Java
  2. eclipse中maven项目不显示Maven Dependencies依赖

作者:cosmozhu --90后的老父亲,专注于保护地球的程序员
个人网站:http://www.cosmozhu.fun
欢迎转载,转载时请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值