Menu

HBase Thrit Server Configuration

module.exports = (service) ->
  options = service.options

Kerberos

  options.krb5 ?= {}
  options.krb5.realm ?= service.deps.krb5_client.options.etc_krb5_conf?.libdefaults?.default_realm
  throw Error 'Required Options: "realm"' unless options.krb5.realm
  options.krb5.admin ?= service.deps.krb5_client.options.admin[options.krb5.realm]

Identities

  options.group = merge service.deps.hbase_master[0].options.group, options.group
  options.user = merge service.deps.hbase_master[0].options.user, options.user
  options.admin = merge service.deps.hbase_master[0].options.admin, options.admin
  options.ranger_admin ?= service.deps.ranger_admin.options.admin if service.deps.ranger_admin

Environment

  # Layout
  options.conf_dir ?= '/etc/hbase-thrift/conf'
  options.log_dir ?= '/var/log/hbase'
  options.pid_dir ?= '/var/run/hbase'
  # Env & Java
  options.env ?= {}
  options.java_home ?= "#{service.deps.java.options.java_home}"
  options.heapsize ?= '1024m'
  options.newsize ?= '200m'
  # Misc
  options.fqdn = service.node.fqdn
  options.iptables ?= service.deps.iptables and service.deps.iptables.options.action is 'start'
  options.clean_logs ?= false

System Options

  options.opts ?= {}
  options.opts.base ?= ''
  options.opts.java_properties ?= {}
  options.opts.jvm ?= {}
  options.opts.jvm['-Xms'] ?= options.heapsize
  options.opts.jvm['-Xmx'] ?= options.heapsize
  options.opts.jvm['-XX:NewSize='] ?= options.newsize #should be 1/8 of hbase regionserver heapsize
  options.opts.jvm['-XX:MaxNewSize='] ?= options.newsize #should be 1/8 of hbase regionserver heapsize

Thrift Server Configuration

  options.hbase_site ?= {}
  options.hbase_site['hbase.thrift.port'] ?= '9090' # Default to "8080"
  options.hbase_site['hbase.thrift.info.port'] ?= '9095' # Default to "8085"
  options.hbase_site['hbase.thrift.ssl.enabled'] ?= 'true'
  options.hbase_site['hbase.thrift.ssl.keystore.store'] ?= service.deps.hadoop_core.options.ssl_server['ssl.server.keystore.location']
  options.hbase_site['hbase.thrift.ssl.keystore.password'] ?= service.deps.hadoop_core.options.ssl_server['ssl.server.keystore.password']
  options.hbase_site['hbase.thrift.ssl.keystore.keypassword'] ?= service.deps.hadoop_core.options.ssl_server['ssl.server.keystore.keypassword']
  # Type of HBase thrift server
  options.hbase_site['hbase.regionserver.thrift.server.type'] ?= 'TThreadPoolServer'
  # The value for the property hbase.thrift.security.qop can be one of the following values:
  # auth-conf - authentication, integrity, and confidentiality checking
  # auth-int - authentication and integrity checking
  # auth - authentication checking only
  options.hbase_site['hbase.thrift.security.qop'] ?= "auth"

Security

  options.hbase_site['hbase.security.authentication'] ?= service.deps.hbase_master[0].options.hbase_site['hbase.security.authentication']
  options.hbase_site['hbase.security.authorization'] ?= service.deps.hbase_master[0].options.hbase_site['hbase.security.authorization']
  options.hbase_site['hbase.rpc.engine'] ?= service.deps.hbase_master[0].options.hbase_site['hbase.rpc.engine']
  options.hbase_site['hbase.thrift.authentication.type'] = options.hbase_site['hbase.security.authentication'] ?= 'kerberos'
  options.hbase_site['hbase.master.kerberos.principal'] = service.deps.hbase_master[0].options.hbase_site['hbase.master.kerberos.principal']
  options.hbase_site['hbase.regionserver.kerberos.principal'] = service.deps.hbase_master[0].options.hbase_site['hbase.regionserver.kerberos.principal']
  # hbase.site['hbase.thrift.kerberos.principal'] ?= "hbase/_HOST@#{options.krb5.realm}" # Dont forget `grant 'thrift_server', 'RWCA'`
  # hbase.site['hbase.thrift.keytab.file'] ?= "#{hbase.conf_dir}/thrift.service.keytab"
  # Principal changed to http by default in order to enable impersonation and make it work with hue
  options.hbase_site['hbase.thrift.kerberos.principal'] ?= "HTTP/#{service.node.fqdn}@#{options.krb5.realm}" # was hbase_thrift/_HOST
  options.hbase_site['hbase.thrift.keytab.file'] ?= service.deps.hadoop_core.options.core_site['hadoop.http.authentication.kerberos.keytab']

Impersonation

  # Enables impersonation
  # For now thrift server does not support impersonation for framed transport: check cloudera setup warning
  options.hbase_site['hbase.regionserver.thrift.http'] ?= 'true'
  options.hbase_site['hbase.thrift.support.proxyuser'] ?= 'true'
  options.hbase_site['hbase.regionserver.thrift.framed'] ?= if options.hbase_site['hbase.regionserver.thrift.http'] then 'buffered' else 'framed'

Proxy Users

  krb5_username = /^(.+?)[@\/]/.exec(options.hbase_site['hbase.thrift.kerberos.principal'])?[1]
  throw Error 'Invalid HBase Thrift principal' unless krb5_username
  for srv in [service.deps.hbase_master..., service.deps.hbase_regionserver...]
    srv.options.hbase_site["hadoop.proxyuser.#{krb5_username}.groups"] ?= '*'
    srv.options.hbase_site["hadoop.proxyuser.#{krb5_username}.hosts"] ?= '*'

Distributed Mode

  for property in [
    'zookeeper.znode.parent'
    'hbase.cluster.distributed'
    'hbase.rootdir'
    'hbase.zookeeper.quorum'
    'hbase.zookeeper.property.clientPort'
    'dfs.domain.socket.path'
  ] then options.hbase_site[property] ?= service.deps.hbase_master[0].options.hbase_site[property]

Wait

  options.wait_krb5_client = service.deps.krb5_client.options.wait
  options.wait_hbase_master = service.deps.hbase_master[0].options.wait
  for srv in service.deps.hbase_thrift
    srv.options.hbase_site ?= {}
    srv.options.hbase_site['hbase.thrift.port'] ?= '9090'
    srv.options.hbase_site['hbase.thrift.info.port'] ?= '9095'
  options.wait = {}
  options.wait.http = for srv in service.deps.hbase_thrift
    host: srv.node.fqdn
    port: srv.options.hbase_site['hbase.thrift.port']
  options.wait.http_info = for srv in service.deps.hbase_thrift
    host: srv.node.fqdn
    port: srv.options.hbase_site['hbase.thrift.info.port']

Dependencies

{merge} = require '@nikitajs/core/lib/misc'