http://git-wip-us.apache.org/repos/asf/incubator-atlas-website/blob/ff453c82/0.8.0-incubating/Configuration.html
----------------------------------------------------------------------
diff --git a/0.8.0-incubating/Configuration.html 
b/0.8.0-incubating/Configuration.html
new file mode 100644
index 0000000..c7c6148
--- /dev/null
+++ b/0.8.0-incubating/Configuration.html
@@ -0,0 +1,508 @@
+<!DOCTYPE html>
+<!--
+ | Generated by Apache Maven Doxia at 2017-03-16
+ | Rendered using Apache Maven Fluido Skin 1.3.0
+-->
+<html xmlns="http://www.w3.org/1999/xhtml"; xml:lang="en" lang="en">
+  <head>
+    <meta charset="UTF-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <meta name="Date-Revision-yyyymmdd" content="20170316" />
+    <meta http-equiv="Content-Language" content="en" />
+    <title>Apache Atlas &#x2013; Configuring Apache Atlas - Application 
Properties</title>
+    <link rel="stylesheet" href="./css/apache-maven-fluido-1.3.0.min.css" />
+    <link rel="stylesheet" href="./css/site.css" />
+    <link rel="stylesheet" href="./css/print.css" media="print" />
+
+      
+    <script type="text/javascript" 
src="./js/apache-maven-fluido-1.3.0.min.js"></script>
+
+                          
+        
+<script type="text/javascript">$( document ).ready( function() { $( 
'.carousel' ).carousel( { interval: 3500 } ) } );</script>
+          
+            </head>
+        <body class="topBarEnabled">
+          
+                        
+                    
+                
+
+    <div id="topbar" class="navbar navbar-fixed-top ">
+      <div class="navbar-inner">
+                                  <div class="container" style="width: 
68%;"><div class="nav-collapse">
+            
+                
+                                <ul class="nav">
+                          <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Atlas <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="index.html"  title="About">About</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="Wiki">Wiki</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="News">News</a>
+</li>
+                  
+                      <li>      <a 
href="https://git-wip-us.apache.org/repos/asf/incubator-atlas.git";  
title="Git">Git</a>
+</li>
+                  
+                      <li>      <a 
href="https://issues.apache.org/jira/browse/ATLAS";  title="Jira">Jira</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS/PoweredBy";  
title="Powered by">Powered by</a>
+</li>
+                  
+                      <li>      <a href="http://blogs.apache.org/atlas/";  
title="Blog">Blog</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Project 
Information <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="project-info.html"  
title="Summary">Summary</a>
+</li>
+                  
+                      <li>      <a href="mail-lists.html"  title="Mailing 
Lists">Mailing Lists</a>
+</li>
+                  
+                      <li>      <a 
href="http://webchat.freenode.net?channels=apacheatlas&uio=d4";  
title="IRC">IRC</a>
+</li>
+                  
+                      <li>      <a href="team-list.html"  title="Team">Team</a>
+</li>
+                  
+                      <li>      <a href="issue-tracking.html"  title="Issue 
Tracking">Issue Tracking</a>
+</li>
+                  
+                      <li>      <a href="source-repository.html"  
title="Source Repository">Source Repository</a>
+</li>
+                  
+                      <li>      <a href="license.html"  
title="License">License</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/dyn/closer.cgi/incubator/atlas/0.8.0-incubating/";  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.1-incubating/";  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.0-incubating/";  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.6.0-incubating/";  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.5.0-incubating/";  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" 
data-toggle="dropdown">Documentation <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="0.8.0-incubating/index.html"  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.1-incubating/index.html"  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.0-incubating/index.html"  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.6.0-incubating/index.html"  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.5.0-incubating/index.html"  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">ASF <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/foundation/how-it-works.html";  title="How Apache 
Works">How Apache Works</a>
+</li>
+                  
+                      <li>      <a href="http://www.apache.org/foundation/";  
title="Foundation">Foundation</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/sponsorship.html";  title="Sponsoring 
Apache">Sponsoring Apache</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/thanks.html";  title="Thanks">Thanks</a>
+</li>
+                          </ul>
+      </li>
+                  </ul>
+          
+                      <form id="search-form" 
action="http://www.google.com/search"; method="get"  class="navbar-search 
pull-right" >
+    
+  <input value="http://atlas.incubator.apache.org"; name="sitesearch" 
type="hidden"/>
+  <input class="search-query" name="q" id="query" type="text" />
+</form>
+<script type="text/javascript" 
src="http://www.google.com/coop/cse/brand?form=search-form";></script>
+          
+                            
+            
+            
+            
+    <iframe 
src="http://www.facebook.com/plugins/like.php?href=http://atlas.incubator.apache.org/atlas-docs&send=false&layout=button_count&show-faces=false&action=like&colorscheme=dark";
+        scrolling="no" frameborder="0"
+        style="border:none; width:80px; height:20px; margin-top: 10px;"  
class="pull-right" ></iframe>
+                        
+    <script type="text/javascript" 
src="https://apis.google.com/js/plusone.js";></script>
+
+        <ul class="nav pull-right"><li style="margin-top: 10px;">
+    
+    <div class="g-plusone" 
data-href="http://atlas.incubator.apache.org/atlas-docs"; data-size="medium"  
width="60px" align="right" ></div>
+
+        </li></ul>
+                              
+                   
+                      </div>
+          
+        </div>
+      </div>
+    </div>
+    
+        <div class="container">
+          <div id="banner">
+        <div class="pull-left">
+                                                  <a href=".." id="bannerLeft">
+                                                                               
                 <img src="images/atlas-logo.png"  alt="Apache Atlas" 
width="200px" height="45px"/>
+                </a>
+                      </div>
+        <div class="pull-right">                  <a 
href="http://incubator.apache.org"; id="bannerRight">
+                                                                               
                 <img src="images/apache-incubator-logo.png"  alt="Apache 
Incubator"/>
+                </a>
+      </div>
+        <div class="clear"><hr/></div>
+      </div>
+
+      <div id="breadcrumbs">
+        <ul class="breadcrumb">
+                
+                    
+                              <li class="">
+                    <a href="http://www.apache.org"; class="externalLink" 
title="Apache">
+        Apache</a>
+        </li>
+      <li class="divider ">/</li>
+            <li class="">
+                    <a href="index.html" title="Atlas">
+        Atlas</a>
+        </li>
+      <li class="divider ">/</li>
+        <li class="">Configuring Apache Atlas - Application Properties</li>
+        
+                
+                    
+                  <li id="publishDate" class="pull-right">Last Published: 
2017-03-16</li> <li class="divider pull-right">|</li>
+              <li id="projectVersion" class="pull-right">Version: 
0.8-incubating</li>
+            
+                            </ul>
+      </div>
+
+      
+                        
+        <div id="bodyColumn" >
+                                  
+            <div class="section">
+<h2><a 
name="Configuring_Apache_Atlas_-_Application_Properties"></a>Configuring Apache 
Atlas - Application Properties</h2>
+<p>All configuration in Atlas uses java properties style configuration. The 
main configuration file is atlas-application.properties which is in the 
<b>conf</b> dir at the deployed location. It consists of the following 
sections:</p></div>
+<div class="section">
+<h3><a name="Graph_Configs"></a>Graph Configs</h3></div>
+<div class="section">
+<h4><a name="Graph_persistence_engine"></a>Graph persistence engine</h4>
+<p>This section sets up the graph db - titan - to use a persistence engine. 
Please refer to <a 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/titan-config-ref.html";>link</a>
 for more details. The example below uses BerkeleyDBJE.</p>
+<div class="source">
+<pre>
+atlas.graph.storage.backend=berkeleyje
+atlas.graph.storage.directory=data/berkley
+
+</pre></div></div>
+<div class="section">
+<h5><a name="Graph_persistence_engine_-_Hbase"></a>Graph persistence engine - 
Hbase</h5>
+<p>Basic configuration</p>
+<div class="source">
+<pre>
+atlas.graph.storage.backend=hbase
+#For standalone mode , specify localhost
+#for distributed mode, specify zookeeper quorum here - For more information 
refer 
http://s3.thinkaurelius.com/docs/titan/current/hbase.html#_remote_server_mode_2
+atlas.graph.storage.hostname=&lt;ZooKeeper Quorum&gt;
+
+</pre></div>
+<p>HBASE_CONF_DIR environment variable needs to be set to point to the Hbase 
client configuration directory which is added to classpath when Atlas starts 
up. hbase-site.xml needs to have the following properties set according to the 
cluster setup</p>
+<div class="source">
+<pre>
+#Set below to /hbase-secure if the Hbase server is setup in secure mode
+zookeeper.znode.parent=/hbase-unsecure
+
+</pre></div>
+<p>Advanced configuration</p>
+<p># If you are planning to use any of the configs mentioned below, they need 
to be prefixed with &quot;atlas.graph.&quot; to take effect in ATLAS Refer <a 
class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/titan-config-ref.html#_storage_hbase";>http://s3.thinkaurelius.com/docs/titan/0.5.4/titan-config-ref.html#_storage_hbase</a></p>
+<p>Permissions</p>
+<p>When Atlas is configured with HBase as the storage backend the graph db 
(titan) needs sufficient user permissions to be able to create and access an 
HBase table.  In a secure cluster it may be necessary to grant permissions to 
the 'atlas' user for the 'titan' table.</p>
+<p>With Ranger, a policy can be configured for 'titan'.</p>
+<p>Without Ranger, HBase shell can be used to set the permissions.</p>
+<div class="source">
+<pre>
+   su hbase
+   kinit -k -t &lt;hbase keytab&gt; &lt;hbase principal&gt;
+   echo &quot;grant 'atlas', 'RWXCA', 'titan'&quot; | hbase shell
+
+</pre></div>
+<p>Note that if the embedded-hbase-solr profile is used then HBase is included 
in the distribution so that a standalone instance of HBase can be started as 
the default storage backend for the graph repository.  Using the 
embedded-hbase-solr profile will configure Atlas so that HBase instance will be 
started and stopped along with the Atlas server by default. To use the 
embedded-hbase-solr profile please see &quot;Building Atlas&quot; in the <a 
href="./InstallationSteps.html">Installation Steps</a> section.</p></div>
+<div class="section">
+<h4><a name="Graph_Search_Index"></a>Graph Search Index</h4>
+<p>This section sets up the graph db - titan - to use an search indexing 
system. The example configuration below sets up to use an embedded Elastic 
search indexing system.</p>
+<div class="source">
+<pre>
+atlas.graph.index.search.backend=elasticsearch
+atlas.graph.index.search.directory=data/es
+atlas.graph.index.search.elasticsearch.client-only=false
+atlas.graph.index.search.elasticsearch.local-mode=true
+atlas.graph.index.search.elasticsearch.create.sleep=2000
+
+</pre></div></div>
+<div class="section">
+<h5><a name="Graph_Search_Index_-_Solr"></a>Graph Search Index - Solr</h5>
+<p>Please note that Solr installation in Cloud mode is a prerequisite before 
configuring Solr as the search indexing backend. Refer <a 
href="./InstallationSteps.html">InstallationSteps</a> section for Solr 
installation/configuration.</p>
+<div class="source">
+<pre>
+ atlas.graph.index.search.backend=solr5
+ atlas.graph.index.search.solr.mode=cloud
+ atlas.graph.index.search.solr.zookeeper-url=&lt;the ZK quorum setup for solr 
as comma separated value&gt; eg: 10.1.6.4:2181,10.1.6.5:2181
+ atlas.graph.index.search.solr.zookeeper-connect-timeout=&lt;SolrCloud 
Zookeeper Connection Timeout&gt;. Default value is 60000 ms
+ atlas.graph.index.search.solr.zookeeper-session-timeout=&lt;SolrCloud 
Zookeeper Session Timeout&gt;. Default value is 60000 ms
+
+</pre></div>
+<p>Also note that if the embedded-hbase-solr profile is used then Solr is 
included in the distribution so that a standalone instance of Solr can be 
started as the default search indexing backend. Using the embedded-hbase-solr 
profile will configure Atlas so that the standalone Solr instance will be 
started and stopped along with the Atlas server by default. To use the 
embedded-hbase-solr profile please see &quot;Building Atlas&quot; in the <a 
href="./InstallationSteps.html">Installation Steps</a> section.</p></div>
+<div class="section">
+<h4><a name="Choosing_between_Persistence_and_Indexing_Backends"></a>Choosing 
between Persistence and Indexing Backends</h4>
+<p>Refer <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/bdb.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/bdb.html</a>
 and <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/hbase.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/hbase.html</a>
 for choosing between the persistence backends. BerkeleyDB is suitable for 
smaller data sets in the range of upto 10 million vertices with ACID gurantees. 
HBase on the other hand doesnt provide ACID guarantees but is able to scale for 
larger graphs. HBase also provides HA inherently.</p></div>
+<div class="section">
+<h4><a name="Choosing_between_Persistence_Backends"></a>Choosing between 
Persistence Backends</h4>
+<p>Refer <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/bdb.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/bdb.html</a>
 and <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/hbase.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/hbase.html</a>
 for choosing between the persistence backends. BerkeleyDB is suitable for 
smaller data sets in the range of upto 10 million vertices with ACID gurantees. 
HBase on the other hand doesnt provide ACID guarantees but is able to scale for 
larger graphs. HBase also provides HA inherently.</p></div>
+<div class="section">
+<h4><a name="Choosing_between_Indexing_Backends"></a>Choosing between Indexing 
Backends</h4>
+<p>Refer <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/elasticsearch.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/elasticsearch.html</a>
 and <a class="externalLink" 
href="http://s3.thinkaurelius.com/docs/titan/0.5.4/solr.html";>http://s3.thinkaurelius.com/docs/titan/0.5.4/solr.html</a>
 for choosing between ElasticSearch and Solr. Solr in cloud mode is the 
recommended setup.</p></div>
+<div class="section">
+<h4><a name="Switching_Persistence_Backend"></a>Switching Persistence 
Backend</h4>
+<p>For switching the storage backend from BerkeleyDB to HBase and vice versa, 
refer the documentation for &quot;Graph Persistence Engine&quot; described 
above and restart ATLAS. The data in the indexing backend needs to be cleared 
else there will be discrepancies between the storage and indexing backend which 
could result in errors during the search. ElasticSearch runs by default in 
embedded mode and the data could easily be cleared by deleting the 
ATLAS_HOME/data/es directory. For Solr, the collections which were created 
during ATLAS Installation - vertex_index, edge_index, fulltext_index could be 
deleted which will cleanup the indexes</p></div>
+<div class="section">
+<h4><a name="Switching_Index_Backend"></a>Switching Index Backend</h4>
+<p>Switching the Index backend requires clearing the persistence backend data. 
Otherwise there will be discrepancies between the persistence and index 
backends since switching the indexing backend means index data will be lost. 
This leads to &quot;Fulltext&quot; queries not working on the existing data For 
clearing the data for BerkeleyDB, delete the ATLAS_HOME/data/berkeley directory 
For clearing the data for HBase, in Hbase shell, run 'disable titan' and 'drop 
titan'</p></div>
+<div class="section">
+<h3><a name="Lineage_Configs"></a>Lineage Configs</h3>
+<p>The higher layer services like lineage, schema, etc. are driven by the type 
system and this section encodes the specific types for the hive data model.</p>
+<p># This models reflects the base super types for Data and Process</p>
+<div class="source">
+<pre>
+atlas.lineage.hive.table.type.name=DataSet
+atlas.lineage.hive.process.type.name=Process
+atlas.lineage.hive.process.inputs.name=inputs
+atlas.lineage.hive.process.outputs.name=outputs
+
+## Schema
+atlas.lineage.hive.table.schema.query=hive_table where name=?, columns
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Search_Configs"></a>Search Configs</h3>
+<p>Search APIs (DSL and full text search) support pagination and have optional 
limit and offset arguments. Following configs are related to search 
pagination</p>
+<div class="source">
+<pre>
+# Default limit used when limit is not specified in API
+atlas.search.defaultlimit=100
+
+# Maximum limit allowed in API. Limits maximum results that can be fetched to 
make sure the atlas server doesn't run out of memory
+atlas.search.maxlimit=10000
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Notification_Configs"></a>Notification Configs</h3>
+<p>Refer <a class="externalLink" 
href="http://kafka.apache.org/documentation.html#configuration";>http://kafka.apache.org/documentation.html#configuration</a>
 for Kafka configuration. All Kafka configs should be prefixed with 
'atlas.kafka.'</p>
+<div class="source">
+<pre>
+atlas.notification.embedded=true
+atlas.kafka.data=${sys:atlas.home}/data/kafka
+atlas.kafka.zookeeper.connect=localhost:9026
+atlas.kafka.bootstrap.servers=localhost:9027
+atlas.kafka.zookeeper.session.timeout.ms=400
+atlas.kafka.zookeeper.sync.time.ms=20
+atlas.kafka.auto.commit.interval.ms=1000
+atlas.kafka.hook.group.id=atlas
+
+</pre></div>
+<p>Note that Kafka group ids are specified for a specific topic.  The Kafka 
group id configuration for entity notifications is 
'atlas.kafka.entities.group.id'</p>
+<div class="source">
+<pre>
+atlas.kafka.entities.group.id=&lt;consumer id&gt;
+
+</pre></div>
+<p>These configuration parameters are useful for setting up Kafka topics via 
Atlas provided scripts, described in the <a 
href="./InstallationSteps.html">Installation Steps</a> page.</p>
+<div class="source">
+<pre>
+# Whether to create the topics automatically, default is true.
+# Comma separated list of topics to be created, default is 
&quot;ATLAS_HOOK,ATLAS_ENTITES&quot;
+atlas.notification.topics=ATLAS_HOOK,ATLAS_ENTITIES
+# Number of replicas for the Atlas topics, default is 1. Increase for higher 
resilience to Kafka failures.
+atlas.notification.replicas=1
+# Enable the below two properties if Kafka is running in Kerberized mode.
+# Set this to the service principal representing the Kafka service
+atlas.notification.kafka.service.principal=kafka/[email protected]
+# Set this to the location of the keytab file for Kafka
+#atlas.notification.kafka.keytab.location=/etc/security/keytabs/kafka.service.keytab
+
+</pre></div>
+<p>These configuration parameters are useful for saving messages in case there 
are issues in reaching Kafka for sending messages.</p>
+<div class="source">
+<pre>
+# Whether to save messages that failed to be sent to Kafka, default is true
+atlas.notification.log.failed.messages=true
+# If saving messages is enabled, the file name to save them to. This file will 
be created under the log directory of the hook's host component - like 
HiveServer2
+atlas.notification.failed.messages.filename=atlas_hook_failed_messages.log
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Client_Configs"></a>Client Configs</h3>
+<div class="source">
+<pre>
+atlas.client.readTimeoutMSecs=60000
+atlas.client.connectTimeoutMSecs=60000
+atlas.rest.address=&lt;http/https&gt;://&lt;atlas-fqdn&gt;:&lt;atlas port&gt; 
- default http://localhost:21000
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Security_Properties"></a>Security Properties</h3></div>
+<div class="section">
+<h4><a name="SSL_config"></a>SSL config</h4>
+<p>The following property is used to toggle the SSL feature.</p>
+<div class="source">
+<pre>
+atlas.enableTLS=false
+
+</pre></div></div>
+<div class="section">
+<h3><a name="High_Availability_Properties"></a>High Availability 
Properties</h3>
+<p>The following properties describe High Availability related configuration 
options:</p>
+<div class="source">
+<pre>
+# Set the following property to true, to enable High Availability. Default = 
false.
+atlas.server.ha.enabled=true
+
+# Define a unique set of strings to identify each instance that should run an 
Atlas Web Service instance as a comma separated list.
+atlas.server.ids=id1,id2
+# For each string defined above, define the host and port on which Atlas 
server binds to.
+atlas.server.address.id1=host1.company.com:21000
+atlas.server.address.id2=host2.company.com:31000
+
+# Specify Zookeeper properties needed for HA.
+# Specify the list of services running Zookeeper servers as a comma separated 
list.
+atlas.server.ha.zookeeper.connect=zk1.company.com:2181,zk2.company.com:2181,zk3.company.com:2181
+# Specify how many times should connection try to be established with a 
Zookeeper cluster, in case of any connection issues.
+atlas.server.ha.zookeeper.num.retries=3
+# Specify how much time should the server wait before attempting connections 
to Zookeeper, in case of any connection issues.
+atlas.server.ha.zookeeper.retry.sleeptime.ms=1000
+# Specify how long a session to Zookeeper should last without inactiviy to be 
deemed as unreachable.
+atlas.server.ha.zookeeper.session.timeout.ms=20000
+
+# Specify the scheme and the identity to be used for setting up ACLs on nodes 
created in Zookeeper for HA.
+# The format of these options is &lt;scheme&gt;:&lt;identity&gt;. For more 
information refer to 
http://zookeeper.apache.org/doc/r3.2.2/zookeeperProgrammers.html#sc_ZooKeeperAccessControl.
+# The 'acl' option allows to specify a scheme, identity pair to setup an ACL 
for.
+atlas.server.ha.zookeeper.acl=sasl:[email protected]
+# The 'auth' option specifies the authentication that should be used for 
connecting to Zookeeper.
+atlas.server.ha.zookeeper.auth=sasl:[email protected]
+
+# Since Zookeeper is a shared service that is typically used by many 
components,
+# it is preferable for each component to set its znodes under a namespace.
+# Specify the namespace under which the znodes should be written. Default = 
/apache_atlas
+atlas.server.ha.zookeeper.zkroot=/apache_atlas
+
+# Specify number of times a client should retry with an instance before 
selecting another active instance, or failing an operation.
+atlas.client.ha.retries=4
+# Specify interval between retries for a client.
+atlas.client.ha.sleep.interval.ms=5000
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Server_Properties"></a>Server Properties</h3>
+<div class="source">
+<pre>
+# Set the following property to true, to enable the setup steps to run on each 
server start. Default = false.
+atlas.server.run.setup.on.start=false
+
+</pre></div></div>
+<div class="section">
+<h3><a name="Performance_configuration_items"></a>Performance configuration 
items</h3>
+<p>The following properties can be used to tune performance of Atlas under 
specific circumstances:</p>
+<div class="source">
+<pre>
+# The number of times Atlas code tries to acquire a lock (to ensure 
consistency) while committing a transaction.
+# This should be related to the amount of concurrency expected to be supported 
by the server. For e.g. with retries set to 10, upto 100 threads can 
concurrently create types in the Atlas system.
+# If this is set to a low value (default is 3), concurrent operations might 
fail with a PermanentLockingException.
+atlas.graph.storage.lock.retries=10
+
+# Milliseconds to wait before evicting a cached entry. This should be &gt; 
atlas.graph.storage.lock.wait-time x atlas.graph.storage.lock.retries
+# If this is set to a low value (default is 10000), warnings on transactions 
taking too long will occur in the Atlas application log.
+atlas.graph.storage.cache.db-cache-time=120000
+
+# Minimum number of threads in the atlas web server
+atlas.webserver.minthreads=10
+
+# Maximum number of threads in the atlas web server
+atlas.webserver.maxthreads=100
+
+# Keepalive time in secs for the thread pool of the atlas web server
+atlas.webserver.keepalivetimesecs=60
+
+# Queue size for the requests(when max threads are busy) for the atlas web 
server
+atlas.webserver.queuesize=100
+
+</pre></div></div>
+<div class="section">
+<h4><a name="Recording_performance_metrics"></a>Recording performance 
metrics</h4>
+<p>Atlas package should be built with '-P perf' to instrument atlas code to 
collect metrics. The metrics will be recorded in 
&lt;atlas.log.dir&gt;/metric.log, with one log line per API call. The metrics 
contain the number of times the instrumented methods are called and the total 
time spent in the instrumented method. Logging to metric.log is controlled 
through log4j configuration in atlas-log4j.xml. When the atlas code is 
instrumented, to disable logging to metric.log at runtime, set log level of 
METRICS logger to info level:</p>
+<div class="source">
+<pre>
+&lt;logger name=&quot;METRICS&quot; additivity=&quot;false&quot;&gt;
+    &lt;level value=&quot;info&quot;/&gt;
+    &lt;appender-ref ref=&quot;METRICS&quot;/&gt;
+&lt;/logger&gt;
+
+</pre></div></div>
+                  </div>
+          </div>
+
+    <hr/>
+
+    <footer>
+            <div class="container">
+              <div class="row span12">Copyright &copy;                    
2015-2017
+                        <a href="http://www.apache.org";>Apache Software 
Foundation</a>.
+            All Rights Reserved.      
+                    
+      </div>
+
+                          
+                <p id="poweredBy" class="pull-right">
+                          <a href="http://maven.apache.org/"; title="Built by 
Maven" class="poweredBy">
+        <img class="builtBy" alt="Built by Maven" 
src="./images/logos/maven-feather.png" />
+      </a>
+              </p>
+        
+                </div>
+    </footer>
+  </body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-atlas-website/blob/ff453c82/0.8.0-incubating/EclipseSetup.html
----------------------------------------------------------------------
diff --git a/0.8.0-incubating/EclipseSetup.html 
b/0.8.0-incubating/EclipseSetup.html
new file mode 100644
index 0000000..0178719
--- /dev/null
+++ b/0.8.0-incubating/EclipseSetup.html
@@ -0,0 +1,336 @@
+<!DOCTYPE html>
+<!--
+ | Generated by Apache Maven Doxia at 2017-03-16
+ | Rendered using Apache Maven Fluido Skin 1.3.0
+-->
+<html xmlns="http://www.w3.org/1999/xhtml"; xml:lang="en" lang="en">
+  <head>
+    <meta charset="UTF-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <meta name="Date-Revision-yyyymmdd" content="20170316" />
+    <meta http-equiv="Content-Language" content="en" />
+    <title>Apache Atlas &#x2013; Tools required to build and run Apache Atlas 
on Eclipse</title>
+    <link rel="stylesheet" href="./css/apache-maven-fluido-1.3.0.min.css" />
+    <link rel="stylesheet" href="./css/site.css" />
+    <link rel="stylesheet" href="./css/print.css" media="print" />
+
+      
+    <script type="text/javascript" 
src="./js/apache-maven-fluido-1.3.0.min.js"></script>
+
+                          
+        
+<script type="text/javascript">$( document ).ready( function() { $( 
'.carousel' ).carousel( { interval: 3500 } ) } );</script>
+          
+            </head>
+        <body class="topBarEnabled">
+          
+                        
+                    
+                
+
+    <div id="topbar" class="navbar navbar-fixed-top ">
+      <div class="navbar-inner">
+                                  <div class="container" style="width: 
68%;"><div class="nav-collapse">
+            
+                
+                                <ul class="nav">
+                          <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Atlas <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="index.html"  title="About">About</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="Wiki">Wiki</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="News">News</a>
+</li>
+                  
+                      <li>      <a 
href="https://git-wip-us.apache.org/repos/asf/incubator-atlas.git";  
title="Git">Git</a>
+</li>
+                  
+                      <li>      <a 
href="https://issues.apache.org/jira/browse/ATLAS";  title="Jira">Jira</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS/PoweredBy";  
title="Powered by">Powered by</a>
+</li>
+                  
+                      <li>      <a href="http://blogs.apache.org/atlas/";  
title="Blog">Blog</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Project 
Information <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="project-info.html"  
title="Summary">Summary</a>
+</li>
+                  
+                      <li>      <a href="mail-lists.html"  title="Mailing 
Lists">Mailing Lists</a>
+</li>
+                  
+                      <li>      <a 
href="http://webchat.freenode.net?channels=apacheatlas&uio=d4";  
title="IRC">IRC</a>
+</li>
+                  
+                      <li>      <a href="team-list.html"  title="Team">Team</a>
+</li>
+                  
+                      <li>      <a href="issue-tracking.html"  title="Issue 
Tracking">Issue Tracking</a>
+</li>
+                  
+                      <li>      <a href="source-repository.html"  
title="Source Repository">Source Repository</a>
+</li>
+                  
+                      <li>      <a href="license.html"  
title="License">License</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/dyn/closer.cgi/incubator/atlas/0.8.0-incubating/";  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.1-incubating/";  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.0-incubating/";  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.6.0-incubating/";  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.5.0-incubating/";  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" 
data-toggle="dropdown">Documentation <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="0.8.0-incubating/index.html"  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.1-incubating/index.html"  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.0-incubating/index.html"  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.6.0-incubating/index.html"  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.5.0-incubating/index.html"  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">ASF <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/foundation/how-it-works.html";  title="How Apache 
Works">How Apache Works</a>
+</li>
+                  
+                      <li>      <a href="http://www.apache.org/foundation/";  
title="Foundation">Foundation</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/sponsorship.html";  title="Sponsoring 
Apache">Sponsoring Apache</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/thanks.html";  title="Thanks">Thanks</a>
+</li>
+                          </ul>
+      </li>
+                  </ul>
+          
+                      <form id="search-form" 
action="http://www.google.com/search"; method="get"  class="navbar-search 
pull-right" >
+    
+  <input value="http://atlas.incubator.apache.org"; name="sitesearch" 
type="hidden"/>
+  <input class="search-query" name="q" id="query" type="text" />
+</form>
+<script type="text/javascript" 
src="http://www.google.com/coop/cse/brand?form=search-form";></script>
+          
+                            
+            
+            
+            
+    <iframe 
src="http://www.facebook.com/plugins/like.php?href=http://atlas.incubator.apache.org/atlas-docs&send=false&layout=button_count&show-faces=false&action=like&colorscheme=dark";
+        scrolling="no" frameborder="0"
+        style="border:none; width:80px; height:20px; margin-top: 10px;"  
class="pull-right" ></iframe>
+                        
+    <script type="text/javascript" 
src="https://apis.google.com/js/plusone.js";></script>
+
+        <ul class="nav pull-right"><li style="margin-top: 10px;">
+    
+    <div class="g-plusone" 
data-href="http://atlas.incubator.apache.org/atlas-docs"; data-size="medium"  
width="60px" align="right" ></div>
+
+        </li></ul>
+                              
+                   
+                      </div>
+          
+        </div>
+      </div>
+    </div>
+    
+        <div class="container">
+          <div id="banner">
+        <div class="pull-left">
+                                                  <a href=".." id="bannerLeft">
+                                                                               
                 <img src="images/atlas-logo.png"  alt="Apache Atlas" 
width="200px" height="45px"/>
+                </a>
+                      </div>
+        <div class="pull-right">                  <a 
href="http://incubator.apache.org"; id="bannerRight">
+                                                                               
                 <img src="images/apache-incubator-logo.png"  alt="Apache 
Incubator"/>
+                </a>
+      </div>
+        <div class="clear"><hr/></div>
+      </div>
+
+      <div id="breadcrumbs">
+        <ul class="breadcrumb">
+                
+                    
+                              <li class="">
+                    <a href="http://www.apache.org"; class="externalLink" 
title="Apache">
+        Apache</a>
+        </li>
+      <li class="divider ">/</li>
+            <li class="">
+                    <a href="index.html" title="Atlas">
+        Atlas</a>
+        </li>
+      <li class="divider ">/</li>
+        <li class="">Tools required to build and run Apache Atlas on 
Eclipse</li>
+        
+                
+                    
+                  <li id="publishDate" class="pull-right">Last Published: 
2017-03-16</li> <li class="divider pull-right">|</li>
+              <li id="projectVersion" class="pull-right">Version: 
0.8-incubating</li>
+            
+                            </ul>
+      </div>
+
+      
+                        
+        <div id="bodyColumn" >
+                                  
+            <div class="section">
+<h2><a 
name="Tools_required_to_build_and_run_Apache_Atlas_on_Eclipse"></a>Tools 
required to build and run Apache Atlas on Eclipse</h2>
+<p>These instructions are provided as-is. They worked at a point in time; 
other variants of software may work. These instructions may become stale if the 
build dependencies change.</p>
+<p>They have been shown to work on 19th of December 2016.</p>
+<p>To build, run tests, and debug Apache Atlas, the following software is 
required:</p>
+<p><b>Java</b></p>
+<ul>
+<li>Download and install a 1.8 Java SDK</li>
+<li>Set JAVA_HOME system environment variable to the installed JDK home 
directory</li>
+<li>Add JAVA_HOME/bin directory to system PATH</li></ul><b>Python</b>
+<p>Atlas command line tools are written in Python.</p>
+<ul>
+<li>Download and install Python version 2.7.7</li>
+<li>For Mac, we used 2.7.11</li>
+<li>Add Python home directory to system PATH</li></ul><b>Maven</b>
+<ul>
+<li>Download and install Maven 3.3.9</li>
+<li>Set the environment variable M2_HOME to point to the maven install 
directory</li>
+<li>Add M2_HOME/bin directory to system PATH e.g. 
C:\Users\IBM_ADMIN\Documents\Software\apache-maven-3.3.9\bin</li></ul><b>Git</b>
+<ul>
+<li>Install Git</li>
+<li>Add git bin directory to the system PATH e.g. C:\Program Files 
(x86)\Git\bin</li></ul><b>Eclipse</b>
+<ul>
+<li>Install Eclipse Neon (4.6)</li>
+<li>The non-EE Neon for iOS from eclipse.org has been proven to work here.</li>
+<li>Install the Scala IDE, TestNG, and m2eclipse-scala features/plugins as 
described below.</li></ul><b>Scala IDE Eclipse feature</b>
+<p>Some of the Atlas source code is written in the Scala programming language. 
The Scala IDE feature is required to compile Scala source code in Eclipse.</p>
+<ul>
+<li>In Eclipse, choose Help - Install New Software..</li>
+<li>Click Add... to add an update site, and set Location to <a 
class="externalLink" 
href="http://download.scala-ide.org/sdk/lithium/e44/scala211/stable/site";>http://download.scala-ide.org/sdk/lithium/e44/scala211/stable/site</a></li>
+<li>Select Scala IDE for Eclipse from the list of available features</li>
+<li>Restart Eclipse after install</li>
+<li>Set the Scala compiler to target the 1.7 JVM: Window - Preferences - Scala 
- Compiler, change target to 1.7</li></ul><b>TestNG Eclipse plug-in</b>
+<p>Atlas tests use the <a class="externalLink" 
href="http://testng.org/doc/documentation-main.html";>TestNG framework</a>, 
which is similar to JUnit. The TestNG plug-in is required to run TestNG tests 
from Eclipse.</p>
+<ul>
+<li>In Eclipse, choose Help - Install New Software..</li>
+<li>Click Add... to add an update site, and set Location to <a 
class="externalLink" 
href="http://beust.com/eclipse-old/eclipse_6.9.9.201510270734";>http://beust.com/eclipse-old/eclipse_6.9.9.201510270734</a>
+<ul>
+<li>Choose TestNG and continue with install</li>
+<li>Restart Eclipse after installing the plugin</li>
+<li>In Window - Preferences - TestNG, <b>un</b>check &quot;Use project TestNG 
jar&quot;</li></ul></li></ul><b>m2eclipse-scala Eclipse plugin</b>
+<ul>
+<li>In Eclipse, choose Help - Install New Software..</li>
+<li>Click Add... to add an update site, and set Location to <a 
class="externalLink" 
href="http://alchim31.free.fr/m2e-scala/update-site/";>http://alchim31.free.fr/m2e-scala/update-site/</a></li>
+<li>Choose Maven Integration for Scala IDE, and continue with install</li>
+<li>Restart Eclipse after install</li>
+<li>In Window - Preferences -Maven - Errors/Warnings, set Plugin execution not 
covered by lifecycle configuration to Warning</li></ul><b>Import Atlas maven 
projects into Eclipse:</b>
+<p>a. File - Import - Maven - Existing Maven Projects b. Browse to your Atlas 
folder c. Uncheck the root project and non-Java projects such as dashboardv2, 
docs and distro, then click Finish</p>
+<p>On the Mac, the Maven import fails with message</p>
+<div class="source">
+<pre>
+&quot;Cannot complete the install because one or more required items could not 
be found. Software being installed: Maven Integration for AJDT (Optional) 
0.14.0.201506231302 (org.maven.ide.eclipse.ajdt.feature.feature.group 
0.14.0.201506231302) Missing requirement: Maven Integration for AJDT (Optional) 
0.14.0.201506231302 (org.maven.ide.eclipse.ajdt.feature.feature.group 
0.14.0.201506231302) requires 'org.eclipse.ajdt.core 1.5.0' but it could not be 
found&quot;.
+
+</pre></div>
+<p>Install <a class="externalLink" 
href="http://download.eclipse.org/tools/ajdt/46/dev/update";>http://download.eclipse.org/tools/ajdt/46/dev/update</a>
 and rerun. The Maven AspectJ should plugin install - allowing the references 
to Aspects in Maven to be resolved.</p>
+<p>d. In the atlas-typesystem, atlas-repository, hdfs-model, and storm-bridge 
projects, add the src/main/scala and src/test/scala (if available) directories 
as source folders. Note: the hdfs-model and storm-bridge projects do not have 
the src/test/scala folder.</p>
+<p>Right-click on the project, and choose <b>Properties</b>.</p>
+<p>Click the <b>Java Build Path</b> in the left-hand panel, and choose the 
<b>Source</b> tab.</p>
+<p>Click <b>Add Folder</b>, and select the src/main/scala and src/test/scala 
directories.</p>
+<p>Only the atlas-repository and atlas-type system projects have Scala source 
folders to update.</p>
+<p>e. Select atlas-typesystem, atlas-repository, hdfs-model, and storm-bridge 
projects, right-click, go to the Scala menu, and choose &#x2018;Set the Scala 
Installation&#x2019;.</p>
+<p>f. Choose Fixed Scala Installation: 2.11.8 (bundled) , and click OK.</p>
+<p>g. Restart Eclipse</p>
+<p>h. Choose Project - Clean, select Clean all projects, and click OK.</p>
+<p>Some projects may not pick up the Scala library &#x2013; if this occurs, 
quick fix on those projects to add in the Scala library &#x2013; projects 
atlas-typesystem, atlas-repository, hdfs-model, storm-bridge and 
altas-webapp.</p>
+<p>You should now have a clean workspace.</p>
+<p><b>Sample Bash scripts to help mac users</b></p>
+<p>You will need to change some of these scripts to point to your installation 
targets.</p>
+<ul>
+<li>Run this script to setup your command line build environment</li></ul>
+<div class="source">
+<pre>
+#!/bin/bash # export 
JAVA_HOME=/Library/Java/JavaVirtualMachines/macosxx6480sr3fp10hybrid-20160719_01-sdk
+export 
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_101.jdk/Contents/Home
+export M2_HOME=/Applications/apache-maven-3.3.9 # Git is installed in the 
system path
+export PYTHON_HOME='/Applications/Python 2.7'
+export PATH=$PYTHON_HOME:$M2_HOME/bin:$JAVA_HOME/bin:$PATH
+export MAVEN_OPTS=&quot;-Xmx1536m -Drat.numUnapprovedLicenses=100 
-XX:MaxPermSize=256m&quot;
+
+</pre></div>
+<p></p>
+<ul>
+<li>If you do  not want to set Java 8 as your system java, you can use this  
bash script to setup the environment and run Eclipse (which you can drop in 
Applications and rename to neon).</li></ul>
+<div class="source">
+<pre>
+#!/bin/bash
+export 
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_101.jdk/Contents/Home
+export M2_HOME=/Applications/apache-maven-3.3.9
+# Git is installed in the system path
+export PYTHON_HOME='/Applications/Python 2.7'
+export 
PATH=$PYTHON_HOME:$M2_HOME/bin:$JAVA_HOME/bin:$PATH/Applications/neon.app/Contents/MacOS/eclipse
+
+</pre></div></div>
+                  </div>
+          </div>
+
+    <hr/>
+
+    <footer>
+            <div class="container">
+              <div class="row span12">Copyright &copy;                    
2015-2017
+                        <a href="http://www.apache.org";>Apache Software 
Foundation</a>.
+            All Rights Reserved.      
+                    
+      </div>
+
+                          
+                <p id="poweredBy" class="pull-right">
+                          <a href="http://maven.apache.org/"; title="Built by 
Maven" class="poweredBy">
+        <img class="builtBy" alt="Built by Maven" 
src="./images/logos/maven-feather.png" />
+      </a>
+              </p>
+        
+                </div>
+    </footer>
+  </body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-atlas-website/blob/ff453c82/0.8.0-incubating/HighAvailability.html
----------------------------------------------------------------------
diff --git a/0.8.0-incubating/HighAvailability.html 
b/0.8.0-incubating/HighAvailability.html
new file mode 100644
index 0000000..d1ebffd
--- /dev/null
+++ b/0.8.0-incubating/HighAvailability.html
@@ -0,0 +1,417 @@
+<!DOCTYPE html>
+<!--
+ | Generated by Apache Maven Doxia at 2017-03-16
+ | Rendered using Apache Maven Fluido Skin 1.3.0
+-->
+<html xmlns="http://www.w3.org/1999/xhtml"; xml:lang="en" lang="en">
+  <head>
+    <meta charset="UTF-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
+    <meta name="Date-Revision-yyyymmdd" content="20170316" />
+    <meta http-equiv="Content-Language" content="en" />
+    <title>Apache Atlas &#x2013; Fault Tolerance and High Availability 
Options</title>
+    <link rel="stylesheet" href="./css/apache-maven-fluido-1.3.0.min.css" />
+    <link rel="stylesheet" href="./css/site.css" />
+    <link rel="stylesheet" href="./css/print.css" media="print" />
+
+      
+    <script type="text/javascript" 
src="./js/apache-maven-fluido-1.3.0.min.js"></script>
+
+                          
+        
+<script type="text/javascript">$( document ).ready( function() { $( 
'.carousel' ).carousel( { interval: 3500 } ) } );</script>
+          
+            </head>
+        <body class="topBarEnabled">
+          
+                        
+                    
+                
+
+    <div id="topbar" class="navbar navbar-fixed-top ">
+      <div class="navbar-inner">
+                                  <div class="container" style="width: 
68%;"><div class="nav-collapse">
+            
+                
+                                <ul class="nav">
+                          <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Atlas <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="index.html"  title="About">About</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="Wiki">Wiki</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS";  title="News">News</a>
+</li>
+                  
+                      <li>      <a 
href="https://git-wip-us.apache.org/repos/asf/incubator-atlas.git";  
title="Git">Git</a>
+</li>
+                  
+                      <li>      <a 
href="https://issues.apache.org/jira/browse/ATLAS";  title="Jira">Jira</a>
+</li>
+                  
+                      <li>      <a 
href="https://cwiki.apache.org/confluence/display/ATLAS/PoweredBy";  
title="Powered by">Powered by</a>
+</li>
+                  
+                      <li>      <a href="http://blogs.apache.org/atlas/";  
title="Blog">Blog</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Project 
Information <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="project-info.html"  
title="Summary">Summary</a>
+</li>
+                  
+                      <li>      <a href="mail-lists.html"  title="Mailing 
Lists">Mailing Lists</a>
+</li>
+                  
+                      <li>      <a 
href="http://webchat.freenode.net?channels=apacheatlas&uio=d4";  
title="IRC">IRC</a>
+</li>
+                  
+                      <li>      <a href="team-list.html"  title="Team">Team</a>
+</li>
+                  
+                      <li>      <a href="issue-tracking.html"  title="Issue 
Tracking">Issue Tracking</a>
+</li>
+                  
+                      <li>      <a href="source-repository.html"  
title="Source Repository">Source Repository</a>
+</li>
+                  
+                      <li>      <a href="license.html"  
title="License">License</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/dyn/closer.cgi/incubator/atlas/0.8.0-incubating/";  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.1-incubating/";  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.7.0-incubating/";  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.6.0-incubating/";  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a 
href="http://archive.apache.org/dist/incubator/atlas/0.5.0-incubating/";  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" 
data-toggle="dropdown">Documentation <b class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a href="0.8.0-incubating/index.html"  
title="0.8-incubating">0.8-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.1-incubating/index.html"  
title="0.7.1-incubating">0.7.1-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.7.0-incubating/index.html"  
title="0.7-incubating">0.7-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.6.0-incubating/index.html"  
title="0.6-incubating">0.6-incubating</a>
+</li>
+                  
+                      <li>      <a href="0.5.0-incubating/index.html"  
title="0.5-incubating">0.5-incubating</a>
+</li>
+                          </ul>
+      </li>
+                <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">ASF <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+        
+                      <li>      <a 
href="http://www.apache.org/foundation/how-it-works.html";  title="How Apache 
Works">How Apache Works</a>
+</li>
+                  
+                      <li>      <a href="http://www.apache.org/foundation/";  
title="Foundation">Foundation</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/sponsorship.html";  title="Sponsoring 
Apache">Sponsoring Apache</a>
+</li>
+                  
+                      <li>      <a 
href="http://www.apache.org/foundation/thanks.html";  title="Thanks">Thanks</a>
+</li>
+                          </ul>
+      </li>
+                  </ul>
+          
+                      <form id="search-form" 
action="http://www.google.com/search"; method="get"  class="navbar-search 
pull-right" >
+    
+  <input value="http://atlas.incubator.apache.org"; name="sitesearch" 
type="hidden"/>
+  <input class="search-query" name="q" id="query" type="text" />
+</form>
+<script type="text/javascript" 
src="http://www.google.com/coop/cse/brand?form=search-form";></script>
+          
+                            
+            
+            
+            
+    <iframe 
src="http://www.facebook.com/plugins/like.php?href=http://atlas.incubator.apache.org/atlas-docs&send=false&layout=button_count&show-faces=false&action=like&colorscheme=dark";
+        scrolling="no" frameborder="0"
+        style="border:none; width:80px; height:20px; margin-top: 10px;"  
class="pull-right" ></iframe>
+                        
+    <script type="text/javascript" 
src="https://apis.google.com/js/plusone.js";></script>
+
+        <ul class="nav pull-right"><li style="margin-top: 10px;">
+    
+    <div class="g-plusone" 
data-href="http://atlas.incubator.apache.org/atlas-docs"; data-size="medium"  
width="60px" align="right" ></div>
+
+        </li></ul>
+                              
+                   
+                      </div>
+          
+        </div>
+      </div>
+    </div>
+    
+        <div class="container">
+          <div id="banner">
+        <div class="pull-left">
+                                                  <a href=".." id="bannerLeft">
+                                                                               
                 <img src="images/atlas-logo.png"  alt="Apache Atlas" 
width="200px" height="45px"/>
+                </a>
+                      </div>
+        <div class="pull-right">                  <a 
href="http://incubator.apache.org"; id="bannerRight">
+                                                                               
                 <img src="images/apache-incubator-logo.png"  alt="Apache 
Incubator"/>
+                </a>
+      </div>
+        <div class="clear"><hr/></div>
+      </div>
+
+      <div id="breadcrumbs">
+        <ul class="breadcrumb">
+                
+                    
+                              <li class="">
+                    <a href="http://www.apache.org"; class="externalLink" 
title="Apache">
+        Apache</a>
+        </li>
+      <li class="divider ">/</li>
+            <li class="">
+                    <a href="index.html" title="Atlas">
+        Atlas</a>
+        </li>
+      <li class="divider ">/</li>
+        <li class="">Fault Tolerance and High Availability Options</li>
+        
+                
+                    
+                  <li id="publishDate" class="pull-right">Last Published: 
2017-03-16</li> <li class="divider pull-right">|</li>
+              <li id="projectVersion" class="pull-right">Version: 
0.8-incubating</li>
+            
+                            </ul>
+      </div>
+
+      
+                        
+        <div id="bodyColumn" >
+                                  
+            <div class="section">
+<h2><a name="Fault_Tolerance_and_High_Availability_Options"></a>Fault 
Tolerance and High Availability Options</h2></div>
+<div class="section">
+<h3><a name="Introduction"></a>Introduction</h3>
+<p>Apache Atlas uses and interacts with a variety of systems to provide 
metadata management and data lineage to data administrators. By choosing and 
configuring these dependencies appropriately, it is possible to achieve a high 
degree of service availability with Atlas. This document describes the state of 
high availability support in Atlas, including its capabilities and current 
limitations, and also the configuration required for achieving this level of 
high availability.</p>
+<p><a href="./Architecture.html">The architecture page</a> in the wiki gives 
an overview of the various components that make up Atlas. The options mentioned 
below for various components derive context from the above page, and would be 
worthwhile to review before proceeding to read this page.</p></div>
+<div class="section">
+<h3><a name="Atlas_Web_Service"></a>Atlas Web Service</h3>
+<p>Currently, the Atlas Web Service has a limitation that it can only have one 
active instance at a time. In earlier releases of Atlas, a backup instance 
could be provisioned and kept available. However, a manual failover was 
required to make this backup instance active.</p>
+<p>From this release, Atlas will support multiple instances of the Atlas Web 
service in an active/passive configuration with automated failover. This means 
that users can deploy and start multiple instances of the Atlas Web Service on 
different physical hosts at the same time. One of these instances will be 
automatically selected as an 'active' instance to service user requests. The 
others will automatically be deemed 'passive'. If the 'active' instance becomes 
unavailable either because it is deliberately stopped, or due to unexpected 
failures, one of the other instances will automatically be elected as an 
'active' instance and start to service user requests.</p>
+<p>An 'active' instance is the only instance that can respond to user requests 
correctly. It can create, delete, modify or respond to queries on metadata 
objects. A 'passive' instance will accept user requests, but will redirect them 
using HTTP redirect to the currently known 'active' instance. Specifically, a 
passive instance will not itself respond to any queries on metadata objects. 
However, all instances (both active and passive), will respond to admin 
requests that return information about that instance.</p>
+<p>When configured in a High Availability mode, users can get the following 
operational benefits:</p>
+<p></p>
+<ul>
+<li><b>Uninterrupted service during maintenance intervals</b>: If an active 
instance of the Atlas Web Service needs to be brought down for maintenance, 
another instance would automatically become active and can service 
requests.</li>
+<li><b>Uninterrupted service in event of unexpected failures</b>: If an active 
instance of the Atlas Web Service fails due to software or hardware errors, 
another instance would automatically become active and can service 
requests.</li></ul>
+<p>In the following sub-sections, we describe the steps required to setup High 
Availability for the Atlas Web Service. We also describe how the deployment and 
client can be designed to take advantage of this capability. Finally, we 
describe a few details of the underlying implementation.</p></div>
+<div class="section">
+<h4><a name="Setting_up_the_High_Availability_feature_in_Atlas"></a>Setting up 
the High Availability feature in Atlas</h4>
+<p>The following pre-requisites must be met for setting up the High 
Availability feature.</p>
+<p></p>
+<ul>
+<li>Ensure that you install Apache Zookeeper on a cluster of machines (a 
minimum of 3 servers is recommended for production).</li>
+<li>Select 2 or more physical machines to run the Atlas Web Service instances 
on. These machines define what we refer to as a 'server ensemble' for 
Atlas.</li></ul>
+<p>To setup High Availability in Atlas, a few configuration options must be 
defined in the <tt>atlas-application.properties</tt> file. While the complete 
list of configuration items are defined in the <a 
href="./Configuration.html">Configuration Page</a>, this section lists a few of 
the main options.</p>
+<p></p>
+<ul>
+<li>High Availability is an optional feature in Atlas. Hence, it must be 
enabled by setting the configuration option <tt>atlas.server.ha.enabled</tt> to 
true.</li>
+<li>Next, define a list of identifiers, one for each physical machine you have 
selected for the Atlas Web Service instance. These identifiers can be simple 
strings like <tt>id1</tt>, <tt>id2</tt> etc. They should be unique and should 
not contain a comma.</li>
+<li>Define a comma separated list of these identifiers as the value of the 
option <tt>atlas.server.ids</tt>.</li>
+<li>For each physical machine, list the IP Address/hostname and port as the 
value of the configuration <tt>atlas.server.address.id</tt>, where <tt>id</tt> 
refers to the identifier string for this physical machine.
+<ul>
+<li>For e.g., if you have selected 2 machines with hostnames 
<tt>host1.company.com</tt> and <tt>host2.company.com</tt>, you can define the 
configuration options as below:</li></ul></li></ul>
+<div class="source">
+<pre>
+      atlas.server.ids=id1,id2
+      atlas.server.address.id1=host1.company.com:21000
+      atlas.server.address.id2=host2.company.com:21000
+      
+</pre></div>
+<p></p>
+<ul>
+<li>Define the Zookeeper quorum which will be used by the Atlas High 
Availability feature.</li></ul>
+<div class="source">
+<pre>
+      
atlas.server.ha.zookeeper.connect=zk1.company.com:2181,zk2.company.com:2181,zk3.company.com:2181
+      
+</pre></div>
+<p></p>
+<ul>
+<li>You can review other configuration options that are defined for the High 
Availability feature, and set them up as desired in the 
<tt>atlas-application.properties</tt> file.</li>
+<li>For production environments, the components that Atlas depends on must 
also be set up in High Availability mode. This is described in detail in the 
following sections. Follow those instructions to setup and configure them.</li>
+<li>Install the Atlas software on the selected physical machines.</li>
+<li>Copy the <tt>atlas-application.properties</tt> file created using the 
steps above to the configuration directory of all the machines.</li>
+<li>Start the dependent components.</li>
+<li>Start each instance of the Atlas Web Service.</li></ul>
+<p>To verify that High Availability is working, run the following script on 
each of the instances where Atlas Web Service is installed.</p>
+<div class="source">
+<pre>
+$ATLAS_HOME/bin/atlas_admin.py -status
+
+</pre></div>
+<p>This script can print one of the values below as response:</p>
+<p></p>
+<ul>
+<li><b>ACTIVE</b>: This instance is active and can respond to user 
requests.</li>
+<li><b>PASSIVE</b>: This instance is PASSIVE. It will redirect any user 
requests it receives to the current active instance.</li>
+<li><b>BECOMING_ACTIVE</b>: This would be printed if the server is 
transitioning to become an ACTIVE instance. The server cannot service any 
metadata user requests in this state.</li>
+<li><b>BECOMING_PASSIVE</b>: This would be printed if the server is 
transitioning to become a PASSIVE instance. The server cannot service any 
metadata user requests in this state.</li></ul>
+<p>Under normal operating circumstances, only one of these instances should 
print the value <b>ACTIVE</b> as response to the script, and the others would 
print <b>PASSIVE</b>.</p></div>
+<div class="section">
+<h4><a 
name="Configuring_clients_to_use_the_High_Availability_feature"></a>Configuring 
clients to use the High Availability feature</h4>
+<p>The Atlas Web Service can be accessed in two ways:</p>
+<p></p>
+<ul>
+<li><b>Using the Atlas Web UI</b>: This is a browser based client that can be 
used to query the metadata stored in Atlas.</li>
+<li><b>Using the Atlas REST API</b>: As Atlas exposes a RESTful API, one can 
use any standard REST client including libraries in other applications. In 
fact, Atlas ships with a client called AtlasClient that can be used as an 
example to build REST client access.</li></ul>
+<p>In order to take advantage of the High Availability feature in the clients, 
there are two options possible.</p></div>
+<div class="section">
+<h5><a name="Using_an_intermediate_proxy"></a>Using an intermediate proxy</h5>
+<p>The simplest solution to enable highly available access to Atlas is to 
install and configure some intermediate proxy that has a capability to 
transparently switch services based on status. One such proxy solution is <a 
class="externalLink" href="http://www.haproxy.org/";>HAProxy</a>.</p>
+<p>Here is an example HAProxy configuration that can be used. Note this is 
provided for illustration only, and not as a recommended production 
configuration. For that, please refer to the HAProxy documentation for 
appropriate instructions.</p>
+<div class="source">
+<pre>
+frontend atlas_fe
+  bind *:41000
+  default_backend atlas_be
+
+backend atlas_be
+  mode http
+  option httpchk get /api/atlas/admin/status
+  http-check expect string ACTIVE
+  balance roundrobin
+  server host1_21000 host1:21000 check
+  server host2_21000 host2:21000 check backup
+
+listen atlas
+  bind localhost:42000
+
+</pre></div>
+<p>The above configuration binds HAProxy to listen on port 41000 for incoming 
client connections. It then routes the connections to either of the hosts host1 
or host2 depending on a HTTP status check. The status check is done using a 
HTTP GET on the REST URL <tt>/api/atlas/admin/status</tt>, and is deemed 
successful only if the HTTP response contains the string ACTIVE.</p></div>
+<div class="section">
+<h5><a name="Using_automatic_detection_of_active_instance"></a>Using automatic 
detection of active instance</h5>
+<p>If one does not want to setup and manage a separate proxy, then the other 
option to use the High Availability feature is to build a client application 
that is capable of detecting status and retrying operations. In such a setting, 
the client application can be launched with the URLs of all Atlas Web Service 
instances that form the ensemble. The client should then call the REST URL 
<tt>/api/atlas/admin/status</tt> on each of these to determine which is the 
active instance. The response from the Active instance would be of the form 
<tt>{Status:ACTIVE}</tt>. Also, when the client faces any exceptions in the 
course of an operation, it should again determine which of the remaining URLs 
is active and retry the operation.</p>
+<p>The AtlasClient class that ships with Atlas can be used as an example 
client library that implements the logic for working with an ensemble and 
selecting the right Active server instance.</p>
+<p>Utilities in Atlas, like <tt>quick_start.py</tt> and 
<tt>import-hive.sh</tt> can be configured to run with multiple server URLs. 
When launched in this mode, the AtlasClient automatically selects and works 
with the current active instance. If a proxy is set up in between, then its 
address can be used when running quick_start.py or import-hive.sh.</p></div>
+<div class="section">
+<h4><a 
name="Implementation_Details_of_Atlas_High_Availability"></a>Implementation 
Details of Atlas High Availability</h4>
+<p>The Atlas High Availability work is tracked under the master JIRA <a 
class="externalLink" 
href="https://issues.apache.org/jira/browse/ATLAS-510";>ATLAS-510</a>. The JIRAs 
filed under it have detailed information about how the High Availability 
feature has been implemented. At a high level the following points can be 
called out:</p>
+<p></p>
+<ul>
+<li>The automatic selection of an Active instance, as well as automatic 
failover to a new Active instance happen through a leader election 
algorithm.</li>
+<li>For leader election, we use the <a class="externalLink" 
href="http://curator.apache.org/curator-recipes/leader-latch.html";>Leader Latch 
Recipe</a> of <a class="externalLink" href="http://curator.apache.org";>Apache 
Curator</a>.</li>
+<li>The Active instance is the only one which initializes, modifies or reads 
state in the backend stores to keep them consistent.</li>
+<li>Also, when an instance is elected as Active, it refreshes any cached 
information from the backend stores to get up to date.</li>
+<li>A servlet filter ensures that only the active instance services user 
requests. If a passive instance receives these requests, it automatically 
redirects them to the current active instance.</li></ul></div>
+<div class="section">
+<h3><a name="Metadata_Store"></a>Metadata Store</h3>
+<p>As described above, Atlas uses Titan to store the metadata it manages. By 
default, Atlas uses a standalone HBase instance as the backing store for Titan. 
In order to provide HA for the metadata store, we recommend that Atlas be 
configured to use distributed HBase as the backing store for Titan.  Doing this 
implies that you could benefit from the HA guarantees HBase provides. In order 
to configure Atlas to use HBase in HA mode, do the following:</p>
+<p></p>
+<ul>
+<li>Choose an existing HBase cluster that is set up in HA mode to configure in 
Atlas (OR) Set up a new HBase cluster in <a class="externalLink" 
href="http://hbase.apache.org/book.html#quickstart_fully_distributed";>HA 
mode</a>.
+<ul>
+<li>If setting up HBase for Atlas, please following instructions listed for 
setting up HBase in the <a href="./InstallationSteps.html">Installation 
Steps</a>.</li></ul></li>
+<li>We recommend using more than one HBase masters (at least 2) in the cluster 
on different physical hosts that use Zookeeper for coordination to provide 
redundancy and high availability of HBase.
+<ul>
+<li>Refer to the <a href="./Configuration.html">Configuration page</a> for the 
options to configure in atlas.properties to setup Atlas with 
HBase.</li></ul></li></ul></div>
+<div class="section">
+<h3><a name="Index_Store"></a>Index Store</h3>
+<p>As described above, Atlas indexes metadata through Titan to support full 
text search queries. In order to provide HA for the index store, we recommend 
that Atlas be configured to use Solr as the backing index store for Titan. In 
order to configure Atlas to use Solr in HA mode, do the following:</p>
+<p></p>
+<ul>
+<li>Choose an existing SolrCloud cluster setup in HA mode to configure in 
Atlas (OR) Set up a new <a class="externalLink" 
href="https://cwiki.apache.org/confluence/display/solr/SolrCloud";>SolrCloud 
cluster</a>.
+<ul>
+<li>Ensure Solr is brought up on at least 2 physical hosts for redundancy, and 
each host runs a Solr node.</li>
+<li>We recommend the number of replicas to be set to at least 2 for 
redundancy.</li></ul></li>
+<li>Create the SolrCloud collections required by Atlas, as described in <a 
href="./InstallationSteps.html">Installation Steps</a></li>
+<li>Refer to the <a href="./Configuration.html">Configuration page</a> for the 
options to configure in atlas.properties to setup Atlas with 
Solr.</li></ul></div>
+<div class="section">
+<h3><a name="Notification_Server"></a>Notification Server</h3>
+<p>Metadata notification events from Hooks are sent to Atlas by writing them 
to a Kafka topic called <b>ATLAS_HOOK</b>. Similarly, events from Atlas to 
other integrating components like Ranger, are written to a Kafka topic called 
<b>ATLAS_ENTITIES</b>. Since Kafka persists these messages, the events will not 
be lost even if the consumers are down as the events are being sent. In 
addition, we recommend Kafka is also setup for fault tolerance so that it has 
higher availability guarantees. In order to configure Atlas to use Kafka in HA 
mode, do the following:</p>
+<p></p>
+<ul>
+<li>Choose an existing Kafka cluster set up in HA mode to configure in Atlas 
(OR) Set up a new Kafka cluster.</li>
+<li>We recommend that there are more than one Kafka brokers in the cluster on 
different physical hosts that use Zookeeper for coordination to provide 
redundancy and high availability of Kafka.
+<ul>
+<li>Setup at least 2 physical hosts for redundancy, each hosting a Kafka 
broker.</li></ul></li>
+<li>Set up Kafka topics for Atlas usage:
+<ul>
+<li>The number of partitions for the ATLAS topics should be set to 1 
(numPartitions)</li>
+<li>Decide number of replicas for Kafka topic: Set this to at least 2 for 
redundancy.</li>
+<li>Run the following commands:</li></ul></li></ul>
+<div class="source">
+<pre>
+      $KAFKA_HOME/bin/kafka-topics.sh --create --zookeeper &lt;list of 
zookeeper host:port entries&gt; --topic ATLAS_HOOK --replication-factor 
&lt;numReplicas&gt; --partitions 1
+      $KAFKA_HOME/bin/kafka-topics.sh --create --zookeeper &lt;list of 
zookeeper host:port entries&gt; --topic ATLAS_ENTITIES --replication-factor 
&lt;numReplicas&gt; --partitions 1
+      Here KAFKA_HOME points to the Kafka installation directory.
+      
+</pre></div>
+<p></p>
+<ul>
+<li>In atlas-application.properties, set the following configuration:</li></ul>
+<div class="source">
+<pre>
+     atlas.notification.embedded=false
+     atlas.kafka.zookeeper.connect=&lt;comma separated list of servers forming 
Zookeeper quorum used by Kafka&gt;
+     atlas.kafka.bootstrap.servers=&lt;comma separated list of Kafka broker 
endpoints in host:port form&gt; - Give at least 2 for redundancy.
+     
+</pre></div></div>
+<div class="section">
+<h3><a name="Known_Issues"></a>Known Issues</h3>
+<p></p>
+<ul>
+<li>If the HBase region servers hosting the Atlas &#x2018;titan&#x2019; HTable 
are down, Atlas would not be able to store or retrieve metadata from HBase 
until they are brought back online.</li></ul></div>
+                  </div>
+          </div>
+
+    <hr/>
+
+    <footer>
+            <div class="container">
+              <div class="row span12">Copyright &copy;                    
2015-2017
+                        <a href="http://www.apache.org";>Apache Software 
Foundation</a>.
+            All Rights Reserved.      
+                    
+      </div>
+
+                          
+                <p id="poweredBy" class="pull-right">
+                          <a href="http://maven.apache.org/"; title="Built by 
Maven" class="poweredBy">
+        <img class="builtBy" alt="Built by Maven" 
src="./images/logos/maven-feather.png" />
+      </a>
+              </p>
+        
+                </div>
+    </footer>
+  </body>
+</html>

Reply via email to