damccorm commented on code in PR #32563:
URL: https://github.com/apache/beam/pull/32563#discussion_r1779004781


##########
website/www/site/content/en/documentation/runners/prism.md:
##########
@@ -0,0 +1,103 @@
+---
+type: runners
+title: "Prism Runner"
+aliases: /learn/runners/prism/
+---
+<!--
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+-->
+
+# Overview
+
+The Apache Beam Prism Runner can be used to execute Beam pipelines locally 
using [Beam Portability](/roadmap/portability/).
+
+The Prism runner is suitable for small scale local testing and provides:
+
+* A statically compiled, single binary for simple deployment without 
additional configuration.
+* A web UI when executing in stand alone mode.
+* A direct implementation of Beam execution semantics.
+* A streaming-first runtime that supports batch processing and data streaming 
programs.
+* Fast, in-memory execution for to simplify SDK, Transform, and Pipeline 
development.
+* Cross Language Transform support.
+
+Written in [Go](https://go.dev), it is the default runner for the [Go 
SDK](/roadmap/go-sdk/), but can be used in other SDKs as well (see below).
+
+# Capabilities
+
+While Prism already supports a great deal of Beam features, it doesn't yet 
support everything.
+Prism is under active development to close these gaps.
+
+With the exception of timer issues, use of unsupported features should fail 
the pipeline at job submission time.
+
+In the [2.59.0 release](/blog/beam-2.59.0/), Prism passes most runner 
validations tests with the exceptions of pipelines using the following features:
+
+OrderedListState, OnWindowExpiry (eg. GroupIntoBatches), CustomWindows, 
MergingWindowFns, Trigger and WindowingStrategy associated features, Bundle 
Finalization, Looping Timers, and some Coder related issues such as with Python 
combiner packing, and Java Schema transforms, and heterogenous flatten coders.
+Processing Time timers do not yet have real time support.
+
+
+See the [Roadmap](/roadmap/prism-runner/) for how to find current progress.
+Specific feature support information will soon migrate to the [Runner 
Capability Matrix](/documentation/runners/capability-matrix/).
+
+# Using the Prism Runner
+
+{{< language-switcher go java py >}}
+
+<span class="language-go">Prism is the default runner for the Go SDK and is 
used automatically. Set the runner with the flag `--runner=PrismRunner`. </span>
+<span class="language-java">Set the runner to `PrismRunner`. </span>
+<span class="language-py">Set the runner to `PrismRunner`. </span>
+
+For other SDKs, Prism is included as an asset on [Beam Github 
Releases](https://github.com/apache/beam/releases/tag/v{{< param release_latest 
>}}) for download and stand alone use.
+
+Here are some resources with information about how to test your pipelines.
+<ul>
+  <li><a href="/documentation/pipelines/test-your-pipeline/">Test Your 
Pipeline</a></li>
+  <li>The <a 
href="/get-started/wordcount-example/#testing-your-pipeline-with-asserts">Apache
 Beam WordCount Walkthrough</a> contains an example of logging and testing a 
pipeline with asserts.
+  <!-- Java specific links -->
+  <li class="language-java"><a 
href="/blog/2016/10/20/test-stream.html">Testing Unbounded Pipelines in Apache 
Beam</a> talks about the use of Java classes <a 
href="https://beam.apache.org/releases/javadoc/{{< param release_latest 
>}}/index.html?org/apache/beam/sdk/testing/PAssert.html">PAssert</a> and <a 
href="https://beam.apache.org/releases/javadoc/{{< param release_latest 
>}}/index.html?org/apache/beam/sdk/testing/TestStream.html">TestStream</a> to 
test your pipelines.</li>
+</ul>
+
+### Specify your dependency
+
+<span class="language-java">When using Java, you must specify your dependency 
on the Direct Runner in your `pom.xml`.</span>
+{{< highlight java >}}
+<dependency>
+   <groupId>org.apache.beam</groupId>
+   <artifactId>beam-runners-prism-java</artifactId>
+   <version>{{< param release_latest >}}</version>
+   <scope>runtime</scope>
+</dependency>
+{{< /highlight >}}
+
+<span class="language-py">This section is not applicable to the Beam SDK for 
Python. Prism is built in.</span>
+<span class="language-go">This section is not applicable to the Beam SDK for 
Go. Prism is built in.</span>
+
+Except for the Go SDK, Prism is included as an asset on [Beam Github 
Releases](https://github.com/apache/beam/releases/tag/v{{< param release_latest 
>}}) for automatic download, startup, and shutdown on SDKs.
+The binary is cached locally for subsequent executions.
+
+## Pipeline options for the Prism Runner
+
+Prism aims to have minimal configuration required, and does not currently 
present user pipeline options.
+
+## Running Prism Standalone
+
+Prism can be executed as a stand alone binary and will present a basic UI for 
listing jobs, and job status.

Review Comment:
   I might explicitly call out that this requires having go installed on your 
machine. I think that is reasonable, but people may wonder if the go command 
below is correct for java/python pipelines



##########
website/www/site/content/en/roadmap/prism-runner.md:
##########
@@ -0,0 +1,35 @@
+---
+title: "Prism Runner Roadmap"
+---
+<!--
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+-->
+
+# Apache Beam Prism Runner Roadmap
+
+The goal for the Prism runner is to provide a good default onboarding 
experience for Apache Beam.
+
+* Prism should be able to execute any Beam pipeline that can execute on a 
local machine.
+* Prism should be fast to start and execute pipelines.
+* Prism should be able to assist with the local testing and debugging of 
pipelines.
+* Prism may develop into a robust, production ready runner for pipelines that 
can execute locally.
+
+The detailed roadmap lives in an [umbrella tracking issue in 
Github](https://github.com/apache/beam/issues/29650).
+
+Here are available resources:
+
+ - [Runner documentation](/documentation/runners/prism)
+ - Issues: 
[prism](https://github.com/apache/beam/issues?q=is%3Aopen+is%3Aissue+label%3Aprism)
+ - CLI [Code](https://github.com/apache/beam/tree/master/sdks/go/cmd/prism), 
CLI Binaries are available as assets on [Github 
Releases](https://github.com/apache/beam/releases/tag/v{{< param release_latest 
>}}).
+ - Core 
[Code](https://github.com/apache/beam/tree/master/sdks/go/pkg/beam/runners/prism)
+ - [Prism Internals Deep 
Dive](https://github.com/apache/beam/blob/master/sdks/go/pkg/beam/runners/prism/internal/README.md)

Review Comment:
   We should add your talks here when they're published on youtube



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to