Spring Cloud Data Flow provides over 70 prebuilt streaming applications that you can use right away to implement common streaming use cases. In this guide, we use two of these applications to construct a simple data pipeline that produces data sent from an external HTTP request and consumes that data by logging the payload to the terminal.
Instructions for registering these prebuilt applications with Data Flow are provided in the Installation guide.
You can create streams by using a Domain Specific Language (DSL) through the shell or the dashboard as well as programmatically in Java. The dashboard also lets you drag and drop applications onto a palate and connect them visually. The dashboard is bi-directional, so visual actions update the DSL and edits to the DSL update the view of the stream.
The DSL is modeled after the Unix pipes and filter syntax.
As an example, a stream DSL defined as
http | log represents an
http application sending the data it received from a HTTP post to the messaging middleware.
log application receives the message with that data from the messaging middleware and logs it to the terminal.
Each name in the DSL is associated with an application through the application registration process.
The applications are connected through a
| symbol that represents the messaging middleware that acts as the 'pipe' between the applications.
To create a stream:
- In the menu, click Streams.
Click the Create Stream(s) button.
The screen changes to the following image:
- In the text area, type
http | log.
- Click Create Stream.
http-ingestfor the stream name, as shown in the following image:
Click the Create the stream button.
The Definitions page appears.
Now that you have defined a stream, you can deploy it. To do so:
Click the play (deploy) button next to the "
http-ingest" definition that you created in the previous section.
The UI shows the available properties that can be applied to the apps in the "
http-ingest" stream. This example shown in the following image uses the defaults:
If you use the local Data Flow Server, add the following deployment property to set the port to avoid a port collision.
Click the Deploy Stream button.
The UI returns to the Definitions page.
The stream is now in "
deploying" status, and its status becomes "
deployed" when it has finished deploying. You may need to refresh your browser to see the updated status.
Once your application is deployed, you can verify its output. How to do so depends on where you run your application:
This section details how to verify output when your application runs on a local server.
Once the stream is deployed and running, you can now post some data. You can use the following curl command to do so:
curl http://localhost:9000 -H "Content-type: text/plain" -d "Happy streaming"
Once a stream is deployed, you can view its logs. To do so:
- Click Runtime in the menu.
- Click "
- Copy the path in the "
stdout" text box on the dashboard
In another console window, type the following, replacing
/path/from/stdout/textbox/in/dashboardwith the value you copied in the previous step:
$ docker exec -it skipper tail -f /path/from/stdout/textbox/in/dashboard
The output of the log sink appears in the new window. You will see output as shown below. When you have seen enough output from sending http requests, press Ctrl+C to end the
log-sink : Happy streaming
This section details how to verify output when your application runs on Cloud Foundry.
Once the stream is deployed and running in Cloud Foundry, you can now post some data. You can use the following curl command to do so:
curl http://http-ingest-314-log-v1.cfapps.io -H "Content-type: text/plain" -d "Happy streaming"
Now you can list the running applications again and see your applications in the list, as the following example shows:
$ cf apps [1h] ✭ Getting apps in org ORG / space SPACE as [email protected] name requested state instances memory disk urls http-ingest-314-log-v1 started 1/1 1G 1G http-ingest-314-log-v1.cfapps.io http-ingest-314-http-v1 started 1/1 1G 1G http-ingest-314-http-v1.cfapps.io skipper-server started 1/1 1G 1G skipper-server.cfapps.io dataflow-server started 1/1 1G 1G dataflow-server.cfapps.io
Now you can verify the logs, as the following example shows:
cf logs http-ingest-314-log-v1 ... ... 2017-11-20T15:39:43.76-0800 [APP/PROC/WEB/0] OUT 2017-11-20 23:39:43.761 INFO 12 --- [ http-ingest-314.ingest-314-1] log-sink : Happy streaming
This section details how to verify output when your application runs on Kubernetes.
Once the stream is deployed and running in Kubernetes, you can now post some data. You can use the following curl command to do so:
curl http://<EXTERNAL_IP_OF_http-ingest-log-v1-0-2k4r8_SERVICE> -H "Content-type: text/plain" -d "Happy streaming"
kubectl get pods NAME READY STATUS RESTARTS AGE http-ingest-log-v1-0-2k4r8 1/1 Running 0 2m http-ingest-http-v1-qhdqq 1/1 Running 0 2m mysql-777890292-z0dsw 1/1 Running 0 49m rabbitmq-317767540-2qzrr 1/1 Running 0 49m scdf-server-2734071167-bjd3g 1/1 Running 0 12m skipper-2408247821-50z31 1/1 Running 0 15m
Now you can verify the logs.
kubectl logs -f http-ingest-log-v1-0-2k4r8 ... ... 2017-10-30 22:59:04.966 INFO 1 --- [ http-ingest.http.http-ingest-1] log-sink : Happy streaming
Now you can delete the stream you created. To do so:
- Click Streams in the menu.
- Click the down chevron on the "
- Click Destroy Stream.
- When prompted for confirmation, click Destroy Stream Definition(s).
You can find this information in the Continuous Delivery guide.
You can find this information in the Stream Monitoring guide.