diff --git a/HowToRanger.md b/HowToRanger.md
new file mode 100644
index 000000000..aeb74215b
--- /dev/null
+++ b/HowToRanger.md
@@ -0,0 +1,86 @@
+![Bee waggle-dancing on a hive.](logo.png "Federating Hive Meta Stores.")
+
+# Instructions to ranger plugin in Waggle Dance
+
+
+### Process
+
+Apache Ranger is a framework to enable, monitor and manage comprehensive data security across the Hadoop platform. [Apache ranger](https://ranger.apache.org/).
+
+Waggle-dance can implement permission verification based on ranger hive plugin on the metadata side. Permission control is implemented by intercepting the API request to waggle-dance, obtaining the db name and table name, and then sending an authentication request to the ranger. Waggle-Dance ranger-based permission control has the following constraints.
+
+1. The waggle-dance ranger authentication scheme only achieves table-level granularity and cannot achieve column-level granularity.
+2. The waggle-dance ranger authentication scheme does not support ranger’s advanced features, such as `Row level filtering`, `Data masking`, etc.
+3. When a table has `alter`, `update` or `drop` permissions, the table must have `select` permissions
+4. Currently, only the acquisition of `user` and `group` in the Kerberos environment is implemented (other methods need to be expanded in `RangerWrappingHMSHandler`)
+
+
+
+### Configuration
+
+Waggle Dance does not read Hadoop's core-site.xml so the property of ranger plugin should be added to the Hive configuration file `hive-site.xml`:
+
+```
+
+ ranger.plugin.waggle-dance.policy.rest.url
+ http://ranger.url:6080
+
+
+ ranger.plugin.waggle-dance.policy.cache.dir
+ /home/hadoop/cache/path
+
+
+ ranger.plugin.waggle-dance.service.name
+ ranger_service_name
+
+
+ ranger.plugin.waggle-dance.policy.pollIntervalMs
+ 180000
+
+
+```
+
+In addition, if use LDAP for account management, the follow property should be add in the `hive-site.xml`.
+
+```
+
+ hadoop.security.group.mapping
+ org.apache.hadoop.security.LdapGroupsMapping
+
+
+ hadoop.security.group.mapping.ldap.url
+ ldap://ldap.url.com:389
+
+
+ hadoop.security.group.mapping.ldap.bind.user
+ cn=readonlyuser,dc=x,dc=xxx,dc=xx
+
+
+ hadoop.security.group.mapping.ldap.bind.password.file
+ /home/hadoop/path/of/ldap.password
+
+
+ hadoop.security.group.mapping.ldap.base
+ dc=xx,dc=xx,dc=x,dc=xx,dc=xx
+
+
+ hadoop.security.group.mapping.ldap.search.filter.user
+ (search.filter.user)
+
+
+ hadoop.security.group.mapping.ldap.search.filter.group
+ (search.filter.user))
+
+
+ hadoop.security.group.mapping.ldap.search.attr.member
+ xxx
+
+
+ hadoop.security.group.mapping.ldap.search.attr.group.name
+ xx
+
+```
+
+### Running
+
+After running, Waggle-dance will pull a ranger policy cache in json format to the `ranger.plugin.waggle-dance.policy.cache.dir` configuration path. And the cache is not updated within the `ranger.plugin.waggle-dance.policy.pollIntervalMs` configured time interval.