Securing configs with ZooKeeper ACLs and Ranger
Learn how you can restrict access to configuration sets by setting ZooKeeper Acces
    control Lists (ACLs) on all znodes under and including the /solr
    directory and using Ranger to control access to the ConfigSets API.
- Ranger requires Kerberos authentication.
- If the SunJCE cryptographic provider is removed to run the zkcli.shutility, you must set theJDK_JAVA_OPTIONSenvironment variable. For example,export FIPS_JAVA_ARGS = "-Dcom.safelogic.cryptocomply.fips.approved_only=true --add-modules=com.safelogic.cryptocomply.fips.core --add-modules=bctls --add-exports=java.base/sun.security.provider=com.safelogic.cryptocomply.fips.core --add-exports=java.base/sun.security.provider=bctls --module-path=/cdep/extra_jars -Djdk.tls.trustNameService=true -Dsun.security.krb5.disableReferrals=true -Djdk.tls.ephemeralDHKeySize=2048 -Dcom.sun.management.jmxremote.ssl.enabled.protocols=TLSv1.2,TLSv1.3 --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-exports=java.base/sun.net.www.protocol.jar=ALL-UNNAMED --add-opens=java.base/sun.net.www.protocol.jar=ALL-UNNAMED --add-opens=java.base/sun.net.www.protocol.file=ALL-UNNAMED --add-exports=java.base/sun.net.www=ALL-UNNAMED --add-opens=java.base/sun.net.www=ALL-UNNAMED" export JDK_JAVA_OPTIONS = "${JDK_JAVA_OPTIONS} ${FIPS_JAVA_ARGS}"
The solrctl instancedir command interacts directly with ZooKeeper, and
      therefore cannot be protected by Ranger. Because the solrctl config
      command is a wrapper script for the ConfigSets API, it can be protected by Ranger.
To force users to use the ConfigSets API, you must set all ZooKeeper znodes under and including
          /solr to read-only (except for the solr user). 
After completing these steps, you cannot run commands such as solrctl instancedir
          --create or solrctl instancedir --delete without first
        authenticating as the solr@EXAMPLE.COM super user principal.
        Unauthenticated users can still run solrctl instancedir --list and
          solrctl instancedir --get, because those commands only perform read
        operations against ZooKeeper.
