spark-instrumented-optimizer/docs
Sean Owen 547df97715 SPARK-5136 [DOCS] Improve documentation around setting up Spark IntelliJ project
This PR simply points to the IntelliJ wiki page instead of also including IntelliJ notes in the docs. The intent however is to also update the wiki page with updated tips. This is the text I propose for the IntelliJ section on the wiki. I realize it omits some of the existing instructions on the wiki, about enabling Hive, but I think those are actually optional.

------

IntelliJ supports both Maven- and SBT-based projects. It is recommended, however, to import Spark as a Maven project. Choose "Import Project..." from the File menu, and select the `pom.xml` file in the Spark root directory.

It is fine to leave all settings at their default values in the Maven import wizard, with two caveats. First, it is usually useful to enable "Import Maven projects automatically", sincchanges to the project structure will automatically update the IntelliJ project.

Second, note the step that prompts you to choose active Maven build profiles. As documented above, some build configuration require specific profiles to be enabled. The same profiles that are enabled with `-P[profile name]` above may be enabled on this screen. For example, if developing for Hadoop 2.4 with YARN support, enable profiles `yarn` and `hadoop-2.4`.

These selections can be changed later by accessing the "Maven Projects" tool window from the View menu, and expanding the Profiles section.

"Rebuild Project" can fail the first time the project is compiled, because generate source files are not automatically generated. Try clicking the  "Generate Sources and Update Folders For All Projects" button in the "Maven Projects" tool window to manually generate these sources.

Compilation may fail with an error like "scalac: bad option: -P:/home/jakub/.m2/repository/org/scalamacros/paradise_2.10.4/2.0.1/paradise_2.10.4-2.0.1.jar". If so, go to Preferences > Build, Execution, Deployment > Scala Compiler and clear the "Additional compiler options" field. It will work then although the option will come back when the project reimports.

Author: Sean Owen <sowen@cloudera.com>

Closes #3952 from srowen/SPARK-5136 and squashes the following commits:

f3baa66 [Sean Owen] Point to new IJ / Eclipse wiki link
016b7df [Sean Owen] Point to IntelliJ wiki page instead of also including IntelliJ notes in the docs
2015-01-09 09:35:46 -08:00
..
_layouts [SPARK-4806] Streaming doc update for 1.2 2014-12-11 06:21:23 -08:00
_plugins [SPARK-4501][Core] - Create build/mvn to automatically download maven/zinc/scalac 2014-12-27 13:26:38 -08:00
css [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
img [SPARK-4575] [mllib] [docs] spark.ml pipelines doc + bug fixes 2014-12-04 17:00:06 +08:00
js [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
_config.yml Bumping version to 1.3.0-SNAPSHOT. 2014-11-18 21:24:18 -08:00
api.md [SPARK-1439, SPARK-1440] Generate unified Scaladoc across projects and Javadocs 2014-04-21 21:57:40 -07:00
bagel-programming-guide.md SPARK-2363. Clean MLlib's sample data files 2014-07-13 19:27:43 -07:00
building-spark.md SPARK-5136 [DOCS] Improve documentation around setting up Spark IntelliJ project 2015-01-09 09:35:46 -08:00
cluster-overview.md [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
configuration.md [SPARK-5093] Set spark.network.timeout to 120s consistently. 2015-01-05 15:19:53 -08:00
contributing-to-spark.md Work in progress: 2013-09-08 00:29:11 -07:00
ec2-scripts.md [SPARK-3405] add subnet-id and vpc-id options to spark_ec2.py 2014-12-16 12:13:21 -08:00
graphx-programming-guide.md [Doc][GraphX] Remove Motivation section and did some minor update. 2014-11-21 00:29:02 -08:00
hadoop-third-party-distributions.md [SPARK-4501][Core] - Create build/mvn to automatically download maven/zinc/scalac 2014-12-27 13:26:38 -08:00
hardware-provisioning.md Change port from 3030 to 4040 2013-09-11 10:01:38 -07:00
index.md SPARK-971 [DOCS] Link to Confluence wiki from project website / documentation 2014-11-09 17:40:48 -08:00
java-programming-guide.md [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
job-scheduling.md [SPARK-4915][YARN] Fix classname to be specified for external shuffle service. 2014-12-22 11:28:05 -08:00
ml-guide.md [FIX][DOC] Fix broken links in ml-guide.md 2014-12-04 20:16:35 +08:00
mllib-classification-regression.md SPARK-2830 [MLlib]: re-organize mllib documentation 2014-08-12 17:15:21 -07:00
mllib-clustering.md Streaming KMeans [MLLIB][SPARK-3254] 2014-10-31 22:30:12 -07:00
mllib-collaborative-filtering.md SPARK-1307 [DOCS] Don't use term 'standalone' to refer to a Spark Application 2014-10-14 21:37:51 -07:00
mllib-data-types.md [SPARK-2830][MLLIB] doc update for 1.1 2014-08-27 01:19:48 -07:00
mllib-decision-tree.md [SPARK-4580] [SPARK-4610] [mllib] [docs] Documentation for tree ensembles + DecisionTree API fix 2014-12-04 09:57:50 +08:00
mllib-dimensionality-reduction.md SPARK-1307 [DOCS] Don't use term 'standalone' to refer to a Spark Application 2014-10-14 21:37:51 -07:00
mllib-ensembles.md [SPARK-4580] [SPARK-4610] [mllib] [docs] Documentation for tree ensembles + DecisionTree API fix 2014-12-04 09:57:50 +08:00
mllib-feature-extraction.md [SPARK-3838][examples][mllib][python] Word2Vec example in python 2014-10-31 18:33:19 -07:00
mllib-guide.md [SPARK-4575] [mllib] [docs] spark.ml pipelines doc + bug fixes 2014-12-04 17:00:06 +08:00
mllib-linear-methods.md [SPARK-4711] [mllib] [docs] Programming guide advice on choosing optimizer 2014-12-04 08:58:03 +08:00
mllib-naive-bayes.md fixed MLlib Naive-Bayes java example bug 2014-11-04 09:53:43 -08:00
mllib-optimization.md [SPARK-4711] [mllib] [docs] Programming guide advice on choosing optimizer 2014-12-04 08:58:03 +08:00
mllib-statistics.md [SPARK-3964] [MLlib] [PySpark] add Hypothesis test Python API 2014-11-04 21:35:52 -08:00
monitoring.md [SPARK-4546] Improve HistoryServer first time user experience 2014-11-25 15:48:02 -08:00
programming-guide.md Documentation: add description for repartitionAndSortWithinPartitions 2014-12-01 08:45:34 -08:00
python-programming-guide.md [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
quick-start.md SPARK-4170 [CORE] Closure problems when running Scala app that "extends App" 2014-11-27 09:03:17 -08:00
README.md [SPARK-4501][Core] - Create build/mvn to automatically download maven/zinc/scalac 2014-12-27 13:26:38 -08:00
running-on-mesos.md Add mesos specific configurations into doc 2014-12-18 12:15:53 -08:00
running-on-yarn.md [SPARK-2165][YARN]add support for setting maxAppAttempts in the ApplicationSubmissionContext 2015-01-07 08:14:39 -06:00
scala-programming-guide.md [SPARK-1566] consolidate programming guide, and general doc updates 2014-05-30 00:34:33 -07:00
security.md [SPARK-2938] Support SASL authentication in NettyBlockTransferService 2014-11-04 16:15:38 -08:00
spark-standalone.md [SPARK-4771][Docs] Document standalone cluster supervise mode 2014-12-10 12:41:36 -08:00
sql-programming-guide.md [SPARK-4930][SQL][DOCS]Update SQL programming guide, CACHE TABLE is eager 2014-12-30 12:18:55 -08:00
storage-openstack-swift.md [SPARK-938][doc] Add OpenStack Swift support 2014-09-07 20:56:04 -07:00
streaming-custom-receivers.md [SPARK-4806] Streaming doc update for 1.2 2014-12-11 06:21:23 -08:00
streaming-flume-integration.md [SPARK-4806] Streaming doc update for 1.2 2014-12-11 06:21:23 -08:00
streaming-kafka-integration.md [SPARK-5058] Updated broken links 2015-01-03 19:46:08 -08:00
streaming-kinesis-integration.md SPARK-3069 [DOCS] Build instructions in README are outdated 2014-09-16 09:18:03 -07:00
streaming-programming-guide.md [SPARK-4608][Streaming] Reorganize StreamingContext implicit to improve API convenience 2014-12-25 19:46:05 -08:00
submitting-applications.md [Docs] Minor typo fixes 2014-12-22 22:54:32 -08:00
tuning.md change signature of example to match released code 2014-12-19 18:30:09 -08:00

Welcome to the Spark documentation!

This readme will walk you through navigating and building the Spark documentation, which is included here with the Spark source code. You can also find documentation specific to release versions of Spark at http://spark.apache.org/documentation.html.

Read on to learn more about viewing documentation in plain text (i.e., markdown) or building the documentation yourself. Why build it yourself? So that you have the docs that corresponds to whichever version of Spark you currently have checked out of revision control.

Generating the Documentation HTML

We include the Spark documentation as part of the source (as opposed to using a hosted wiki, such as the github wiki, as the definitive documentation) to enable the documentation to evolve along with the source code and be captured by revision control (currently git). This way the code automatically includes the version of the documentation that is relevant regardless of which version or release you have checked out or downloaded.

In this directory you will find textfiles formatted using Markdown, with an ".md" suffix. You can read those text files directly if you want. Start with index.md.

The markdown code can be compiled to HTML using the Jekyll tool. Jekyll and a few dependencies must be installed for this to work. We recommend installing via the Ruby Gem dependency manager. Since the exact HTML output varies between versions of Jekyll and its dependencies, we list specific versions here in some cases:

$ sudo gem install jekyll
$ sudo gem install jekyll-redirect-from

Execute jekyll from the docs/ directory. Compiling the site with Jekyll will create a directory called _site containing index.html as well as the rest of the compiled files.

You can modify the default Jekyll build as follows:

# Skip generating API docs (which takes a while)
$ SKIP_API=1 jekyll build
# Serve content locally on port 4000
$ jekyll serve --watch
# Build the site with extra features used on the live page
$ PRODUCTION=1 jekyll build

Pygments

We also use pygments (http://pygments.org) for syntax highlighting in documentation markdown pages, so you will also need to install that (it requires Python) by running sudo pip install Pygments.

To mark a block of code in your markdown to be syntax highlighted by jekyll during the compile phase, use the following sytax:

{% highlight scala %}
// Your scala code goes here, you can replace scala with many other
// supported languages too.
{% endhighlight %}

Sphinx

We use Sphinx to generate Python API docs, so you will need to install it by running sudo pip install sphinx.

API Docs (Scaladoc and Sphinx)

You can build just the Spark scaladoc by running build/sbt doc from the SPARK_PROJECT_ROOT directory.

Similarly, you can build just the PySpark docs by running make html from the SPARK_PROJECT_ROOT/python/docs directory. Documentation is only generated for classes that are listed as public in __init__.py.

When you run jekyll in the docs directory, it will also copy over the scaladoc for the various Spark subprojects into the docs directory (and then also into the _site directory). We use a jekyll plugin to run build/sbt doc before building the site so if you haven't run it (recently) it may take some time as it generates all of the scaladoc. The jekyll plugin also generates the PySpark docs Sphinx.

NOTE: To skip the step of building and copying over the Scala and Python API docs, run SKIP_API=1 jekyll.