访问阿里云首页面:https://www.aliyun.com/
data:image/s3,"s3://crabby-images/c4b24/c4b24ff71fed197f791d4d57de476f0da7ae8a76" alt=""
data:image/s3,"s3://crabby-images/f7f24/f7f246742b0a489cfe10b1bc8e6d004a3d52e1b7" alt=""
data:image/s3,"s3://crabby-images/82c2a/82c2a51ee546b4bc87990daccf2c45a0dda7d8de" alt=""
选择"按量付费"
data:image/s3,"s3://crabby-images/57b5b/57b5b301c367feb1db743bf60942cf8661400e2b" alt=""
通过选择区域,看哪个区域有虚拟交换机。
data:image/s3,"s3://crabby-images/0d72c/0d72c2ee77647bc06649945caca39ceb444c17b3" alt=""
data:image/s3,"s3://crabby-images/ceb40/ceb406f6ceddc4ffb2ec52fd4989c45ca00c608f" alt=""
查看创建的工作空间,当工作空间状态为运行中时,点击控制台。
data:image/s3,"s3://crabby-images/c42ae/c42aeb22dad65c0aad640a773ece0be20b0215ea" alt=""
data:image/s3,"s3://crabby-images/9f6b0/9f6b0b761722f7d779f53876eae938a32d07c814" alt=""
开通完成后,会有一个控制台:
data:image/s3,"s3://crabby-images/e8158/e81580c4b3759be08c58a41d16af155210b28705" alt=""
可以选择SQL开发或者作业运维运行自己的Flink程序。
java
package com.bigdata.day06;
import org.apache.flink.api.common.RuntimeExecutionMode;
import org.apache.flink.api.common.functions.MapFunction;
import org.apache.flink.api.java.tuple.Tuple2;
import org.apache.flink.streaming.api.datastream.DataStreamSource;
import org.apache.flink.streaming.api.datastream.SingleOutputStreamOperator;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.functions.source.SourceFunction;
import java.util.Random;
/**
* @基本功能:
* @program:FlinkDemo
* @author: 闫哥
* @create:2023-11-24 14:34:50
**/
public class _03TestAliyun {
public static void main(String[] args) throws Exception {
//1. env-准备环境
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
env.setRuntimeMode(RuntimeExecutionMode.AUTOMATIC);
//2. source-加载数据
DataStreamSource<String> dataStreamSource = env.addSource(new SourceFunction<String>() {
@Override
public void run(SourceContext<String> ctx) throws Exception {
String[] words = {"hello", "world", "bigdata"};
Random random = new Random();
while (true) {
String word = words[random.nextInt(words.length)];
int num = random.nextInt(10);
ctx.collect(word + "," + num);
Thread.sleep(500);
}
}
@Override
public void cancel() {
}
});
//3. transformation-数据处理转换
//2. source-加载数据
SingleOutputStreamOperator<Tuple2<String, Integer>> mapStream = dataStreamSource.map(new MapFunction<String, Tuple2<String, Integer>>() {
@Override
public Tuple2<String, Integer> map(String s) throws Exception {
String[] arr = s.split(",");
return Tuple2.of(arr[0], Integer.valueOf(arr[1]));
}
});
//3. transformation-数据处理转换
SingleOutputStreamOperator<Tuple2<String, Integer>> result = mapStream.keyBy(0).sum(1);
result.print();
//4. sink-数据输出
//5. execute-执行
env.execute();
}
}
作业运维在本地IDEA开发,将jar包上传。
data:image/s3,"s3://crabby-images/baa6e/baa6e07c7399c7afeb56d8acc531f7d26c4e3750" alt=""
data:image/s3,"s3://crabby-images/a4003/a400311155c10ee273819466b32cc0a01e984ec3" alt=""
data:image/s3,"s3://crabby-images/e91bf/e91bfe10948f29cb66ddfceba129531532f4e5c7" alt=""
data:image/s3,"s3://crabby-images/b8866/b88665dff00b557ee3415b290b2efa261ae96e40" alt=""
可以通过 UI 界面查看效果:
data:image/s3,"s3://crabby-images/d74ba/d74ba8253f66e90893967b02d90675deac67de57" alt=""
有些程序,是需要环境的,假如数据需要依赖我们虚拟机的环境,是没办法在flink上运行的,因为flink访问不到虚拟机的服务,可以写死一些数据,比如自定义数据源,或者写死一些数据,进行测试。
第一次可以无状态启动:
data:image/s3,"s3://crabby-images/668f9/668f98c0edfbafb69f08dd6ffca693093195c39d" alt=""
查看Flink自带的UI界面:
data:image/s3,"s3://crabby-images/a3560/a356090a252a987edfb265cf0e024e07b7a59724" alt=""
创建快照:
data:image/s3,"s3://crabby-images/fe3d7/fe3d74e8cf3ebaff51d0486495260a59c27df961" alt=""
停止后重启,可以从某个快照进行重启:
data:image/s3,"s3://crabby-images/1099d/1099d4c7e17ba0faa4ea51ba7114edf97a20e19b" alt=""
查看运行结果:
data:image/s3,"s3://crabby-images/7a5cc/7a5ccbc8a3134110e0cf988f91b1aab67c47b1bf" alt=""
以下是帮助文档: