Repository: incubator-zeppelin
Updated Branches:
  refs/heads/master a4db1688c -> e3e61832b


ZEPPELIN-338 Add documentation for Ignite Interpreter

[ZEPPELIN-338](https://issues.apache.org/jira/browse/ZEPPELIN-338?jql=project%20%3D%20ZEPPELIN%20AND%20text%20~%20%22ignite%22)
 Add documentation for Ignite Interpreter

Since the last PR that I opened few days ago has some problems, so I create new 
one.
I read all comments in the last one and edited below files.

Author: Ryu Ah young <[email protected]>

This patch had conflicts when merged, resolved by
Committer: Lee moon soo <[email protected]>

Closes #359 from 
AhyoungRyu/ZEPPELIN-338-Add-documentation-for-Ignite-Interpreter and squashes 
the following commits:

6ae854d [Ryu Ah young] edit 'next' to 'binary'
3e0509d [Ryu Ah young] edit next to future
1acf2ee [Ryu Ah young] add explanation about Zeppelin binary release to check 
ignite version
814d8fa [Ryu Ah young] add explanation about Zeppelin binary release to check 
ignite version
8689915 [Ryu Ah young] ZEPPELIN-338 Add documentation for Ignite Interpreter


Project: http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/repo
Commit: 
http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/commit/e3e61832
Tree: http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/tree/e3e61832
Diff: http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/diff/e3e61832

Branch: refs/heads/master
Commit: e3e61832bcaa3fcce5b1096a20180631c2a8d6e8
Parents: a4db168
Author: Ryu Ah young <[email protected]>
Authored: Mon Oct 26 10:31:32 2015 +0900
Committer: Lee moon soo <[email protected]>
Committed: Sat Nov 7 09:35:05 2015 +0900

----------------------------------------------------------------------
 .../img/docs-img/ignite-interpreter-binding.png | Bin 0 -> 79676 bytes
 .../img/docs-img/ignite-interpreter-setting.png | Bin 0 -> 63120 bytes
 .../zeppelin/img/docs-img/ignite-logo.png       | Bin 0 -> 287178 bytes
 .../img/docs-img/ignite-scala-example.png       | Bin 0 -> 198682 bytes
 .../img/docs-img/ignite-sql-example.png         | Bin 0 -> 51647 bytes
 docs/docs/index.md                              |   2 +-
 docs/docs/interpreter/ignite.md                 | 116 +++++++++++++++++++
 7 files changed, 117 insertions(+), 1 deletion(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-binding.png
----------------------------------------------------------------------
diff --git 
a/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-binding.png 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-binding.png
new file mode 100644
index 0000000..d9e10d5
Binary files /dev/null and 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-binding.png differ

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-setting.png
----------------------------------------------------------------------
diff --git 
a/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-setting.png 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-setting.png
new file mode 100644
index 0000000..06674bf
Binary files /dev/null and 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-interpreter-setting.png differ

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/assets/themes/zeppelin/img/docs-img/ignite-logo.png
----------------------------------------------------------------------
diff --git a/docs/assets/themes/zeppelin/img/docs-img/ignite-logo.png 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-logo.png
new file mode 100644
index 0000000..97a63e8
Binary files /dev/null and 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-logo.png differ

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/assets/themes/zeppelin/img/docs-img/ignite-scala-example.png
----------------------------------------------------------------------
diff --git a/docs/assets/themes/zeppelin/img/docs-img/ignite-scala-example.png 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-scala-example.png
new file mode 100644
index 0000000..f2410a4
Binary files /dev/null and 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-scala-example.png differ

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/assets/themes/zeppelin/img/docs-img/ignite-sql-example.png
----------------------------------------------------------------------
diff --git a/docs/assets/themes/zeppelin/img/docs-img/ignite-sql-example.png 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-sql-example.png
new file mode 100644
index 0000000..eb05067
Binary files /dev/null and 
b/docs/assets/themes/zeppelin/img/docs-img/ignite-sql-example.png differ

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/docs/index.md
----------------------------------------------------------------------
diff --git a/docs/docs/index.md b/docs/docs/index.md
index 8edc871..6a0d341 100644
--- a/docs/docs/index.md
+++ b/docs/docs/index.md
@@ -21,7 +21,7 @@ group: nav-right
 
 * [flink](./interpreter/flink.html)
 * [hive](../docs/pleasecontribute.html)
-* [ignite](../docs/pleasecontribute.html)
+* [ignite](./interpreter/ignite.html)
 * [lens](./interpreter/lens.html)
 * [md](../docs/pleasecontribute.html)
 * [sh](../docs/pleasecontribute.html)

http://git-wip-us.apache.org/repos/asf/incubator-zeppelin/blob/e3e61832/docs/docs/interpreter/ignite.md
----------------------------------------------------------------------
diff --git a/docs/docs/interpreter/ignite.md b/docs/docs/interpreter/ignite.md
new file mode 100644
index 0000000..02fc587
--- /dev/null
+++ b/docs/docs/interpreter/ignite.md
@@ -0,0 +1,116 @@
+---
+layout: page
+title: "Ignite Interpreter"
+description: "Ignite user guide"
+group: manual
+---
+{% include JB/setup %}
+
+## Ignite Interpreter for Apache Zeppelin
+
+### Overview
+[Apache Ignite](https://ignite.apache.org/) In-Memory Data Fabric is a 
high-performance, integrated and distributed in-memory platform for computing 
and transacting on large-scale data sets in real-time, orders of magnitude 
faster than possible with traditional disk-based or flash technologies.
+
+![Apache Ignite](/assets/themes/zeppelin/img/docs-img/ignite-logo.png)
+
+You can use Zeppelin to retrieve distributed data from cache using Ignite SQL 
interpreter. Moreover, Ignite interpreter allows you to execute any Scala code 
in cases when SQL doesn't fit to your requirements. For example, you can 
populate data into your caches or execute distributed computations.
+
+### Installing and Running Ignite example
+In order to use Ignite interpreters, you may install Apache Ignite in some 
simple steps:
+
+  1. Download Ignite [source 
release](https://ignite.apache.org/download.html#sources) or [binary 
release](https://ignite.apache.org/download.html#binaries) whatever you want. 
But you must download Ignite as the same version of Zeppelin's. If it is not, 
you can't use scala code on Zeppelin. You can find ignite version in Zepplin at 
the pom.xml which is placed under `path/to/your-Zeppelin/ignite/pom.xml` ( Of 
course, in Zeppelin source release ). Please check `ignite.version` 
.<br>Currently, Zeppelin provides ignite only in Zeppelin source release. So, 
if you download Zeppelin binary release( 
`zeppelin-0.5.0-incubating-bin-spark-xxx-hadoop-xx` ), you can not use ignite 
interpreter on Zeppelin. We are planning to include ignite in a future binary 
release.
+  
+  2. Examples are shipped as a separate Maven project, so to start running you 
simply need to import provided 
<dest_dir>/apache-ignite-fabric-1.2.0-incubating-bin/pom.xml file into your 
favourite IDE, such as Eclipse. 
+
+   * In case of Eclipse, Eclipse -> File -> Import -> Existing Maven Projects
+   * Set examples directory path to Eclipse and select the pom.xml.
+   * Then start `org.apache.ignite.examples.ExampleNodeStartup` (or whatever 
you want) to run at least one or more ignite node. When you run example code, 
you may notice that the number of node is increase one by one. 
+  
+  > **Tip. If you want to run Ignite examples on the cli not IDE, you can 
export executable Jar file from IDE. Then run it by using below command.**
+      
+  ``` 
+  $ nohup java -jar </path/to/your Jar file name> 
+  ```
+    
+### Configuring Ignite Interpreter 
+At the "Interpreters" menu, you may edit Ignite interpreter or create new one. 
Zeppelin provides these properties for Ignite.
+
+ <table class="table-configuration">
+  <tr>
+      <th>Property Name</th>
+      <th>value</th>
+      <th>Description</th>
+  </tr>
+  <tr>
+      <td>ignite.addresses</td>
+      <td>127.0.0.1:47500..47509</td>
+      <td>Coma separated list of Ignite cluster hosts. See [Ignite Cluster 
Configuration](https://apacheignite.readme.io/v1.2/docs/cluster-config) section 
for more details.</td>
+  </tr>
+  <tr>
+      <td>ignite.clientMode</td>
+      <td>true</td>
+      <td>You can connect to the Ignite cluster as client or server node. See 
[Ignite Clients vs. 
Servers](https://apacheignite.readme.io/v1.2/docs/clients-vs-servers) section 
for details. Use true or false values in order to connect in client or server 
mode respectively.</td>
+  </tr>
+  <tr>
+      <td>ignite.config.url</td>
+      <td></td>
+      <td>Configuration URL. Overrides all other settings.</td>
+   </tr
+   <tr>
+      <td>ignite.jdbc.url</td>
+      <td>jdbc:ignite:cfg://default-ignite-jdbc.xml</td>
+      <td>Ignite JDBC connection URL.</td>
+   </tr>
+   <tr>
+      <td>ignite.peerClassLoadingEnabled</td>
+      <td>true</td>
+      <td>Enables peer-class-loading. See [Zero 
Deployment](https://apacheignite.readme.io/v1.2/docs/zero-deployment) section 
for details. Use true or false values in order to enable or disable P2P class 
loading respectively.</td>
+  </tr>
+ </table>
+
+![Configuration of Ignite 
Interpreter](/assets/themes/zeppelin/img/docs-img/ignite-interpreter-setting.png)
+
+### Interpreter Binding for Zeppelin Notebook
+After configuring Ignite interpreter, create your own notebook. Then you can 
bind interpreters like below image.
+
+![Binding 
Interpreters](/assets/themes/zeppelin/img/docs-img/ignite-interpreter-binding.png)
+
+For more interpreter binding information see 
[here](http://zeppelin.incubator.apache.org/docs/manual/interpreters.html).
+
+### How to use Ignite SQL interpreter
+In order to execute SQL query, use ` %ignite.ignitesql ` prefix. <br>
+Supposing you are running 
`org.apache.ignite.examples.streaming.wordcount.StreamWords`, then you can use 
"words" cache( Of course you have to specify this cache name to the Ignite 
interpreter setting section `ignite.jdbc.url` of Zeppelin ). 
+For example, you can select top 10 words in the words cache using the 
following query
+
+  ``` 
+  %ignite.ignitesql 
+  select _val, count(_val) as cnt from String group by _val order by cnt desc 
limit 10 
+  ``` 
+  
+  ![IgniteSql on 
Zeppelin](/assets/themes/zeppelin/img/docs-img/ignite-sql-example.png)
+  
+As long as your Ignite version and Zeppelin Ignite version is same, you can 
also use scala code. Please check the Zeppelin Ignite version before you 
download your own Ignite. 
+
+  ```
+  %ignite
+  import org.apache.ignite._
+  import org.apache.ignite.cache.affinity._
+  import org.apache.ignite.cache.query._
+  import org.apache.ignite.configuration._
+
+  import scala.collection.JavaConversions._
+
+  val cache: IgniteCache[AffinityUuid, String] = ignite.cache("words")
+
+  val qry = new SqlFieldsQuery("select avg(cnt), min(cnt), max(cnt) from 
(select count(_val) as cnt from String group by _val)", true)
+
+  val res = cache.query(qry).getAll()
+
+  collectionAsScalaIterable(res).foreach(println _)
+  ```
+  
+  ![Using Scala 
Code](/assets/themes/zeppelin/img/docs-img/ignite-scala-example.png)
+
+Apache Ignite also provides a guide docs for Zeppelin ["Ignite with Apache 
Zeppelin"](https://apacheignite.readme.io/docs/data-analysis-with-apache-zeppelin)
+ 
+  

Reply via email to