#!/bin/bash HOSTNAME=`hostname -f` sudo yum install -y mod_ssl sudo mv /etc/httpd/conf.d/ssl.conf /home/hadoop/ssl.conf_original sudo mv /etc/httpd/conf/httpd.conf /home/hadoop/httpd.conf_original sudo unzip -o /usr/share/aws/emr/security/workingdir/tls-artifacts.zip -d /etc/ssl/certs/ #Dynamicportfordwarding ssl.conf sudo echo #
# When we also provide SSL we have to listen to the
# the HTTPS port in addition.
#
Listen 19443 https
#Listen 443 https
##
##  SSL Global Context
##
##  All SSL configuration in this context applies both to
##  the main server and all SSL-enabled virtual hosts.
##
#   Pass Phrase Dialog:
#   Configure the pass phrase gathering process.
#   The filtering dialog program (`builtin' is a internal
#   terminal dialog) has to provide the pass phrase on stdout.
SSLPassPhraseDialog exec:/usr/libexec/httpd-ssl-pass-dialog
#   Inter-Process Session Cache:
#   Configure the SSL Session Cache: First the mechanism
#   to use and second the expiring timeout (in seconds).
SSLSessionCache         shmcb:/run/httpd/sslcache(512000)
SSLSessionCacheTimeout  300
#   Pseudo Random Number Generator (PRNG):
#   Configure one or more sources to seed the PRNG of the
#   SSL library. The seed data should be of good random quality.
#   WARNING! On some platforms /dev/random blocks if not enough entropy
#   is available. This means you then cannot use the /dev/random device
#   because it would lead to very long connection times (as long as
#   it requires to make more entropy available). But usually those
#   platforms additionally provide a /dev/urandom device which doesn't
#   block. So, if available, use this one instead. Read the mod_ssl User
#   Manual for more details.
SSLRandomSeed startup file:/dev/urandom  256
SSLRandomSeed connect builtin
#SSLRandomSeed startup file:/dev/random  512
#SSLRandomSeed connect file:/dev/random  512
#SSLRandomSeed connect file:/dev/urandom 512
#
# Use "SSLCryptoDevice" to enable any supported hardware
# accelerators. Use "openssl engine -v" to list supported
# engine names.  NOTE: If you enable an accelerator and the
# server does not start, consult the error logs and ensure
# your accelerator is functioning properly.
#
SSLCryptoDevice builtin
#SSLCryptoDevice ubsec
##
## SSL Virtual Host Context
##
<VirtualHost *:19443>
ServerName serverhostname
SSLEngine on
SSLCertificateChainFile /etc/ssl/certs/trustedCertificates.pem
SSLCertificateKeyFile /etc/ssl/certs/privateKey.pem
SSLCertificateFile /etc/ssl/certs/certificateChain.pem
RewriteEngine on
RewriteRule ^/shs$ /shs/ [R]
RewriteRule ^/yts$ /yts/ [R]
RewriteRule ^/applicationhistory$ /applicationhistory/ [R]
RewriteRule ^/jh$ /jh/ [R]
RewriteRule ^/rm$ /rm/ [R]
RewriteRule ^/cluster$ /cluster/ [R]
ProxyPassReverse https://serverhostname:19443/ http://localhost:18899/
ProxyPassReverse https://serverhostname:19443/ https://localhost:18899/
<Location "/proxy">
  ProxyPass "http://localhost:18899/proxy" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8080/tez-ui/|/tez/tez-ui/|nq"
  Substitute "s|http:\/\/(ip-.*?:8042)|/nm/$1|"
</Location>
<Location "/jh/">
  ProxyPass "http://localhost:18899/jh/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/jh/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/jh/$1"|'
</Location>
<LocationMatch "^(\/nm\/(?<nodeip>.*:8042)\/(?<url>.*)$)">
  ProxyPass "http://localhost:18899/" connectiontimeout=25 timeout=30
</LocationMatch>
<Location "/shs/">
  ProxyPass "http://localhost:18899/shs/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute 's|href="/|href="/shs/|nq'
  Substitute 's|src="/|src="/shs/|nq'
  Substitute 's|uiRoot=""|uiRoot="/shs"|nq'
  Substitute "s|setUIRoot('')|setUIRoot('/shs')|nq"
  Substitute "s|http:\/\/(ip-.*?:8042)|/nm/$1|"
</Location>
<Location "/static/">
  ProxyPass "http://localhost:18899/static/" connectiontimeout=25 timeout=30
</Location>
<Location "/applicationhistory/">
  ProxyPass "http://localhost:18899/applicationhistory/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/yts/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/yts/$1"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8188/|/yts/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>
<Location "/yts/">
  ProxyPass "http://localhost:18899/yts/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/yts/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/yts/$1"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8188/|/yts/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>
<Location "/rm/">
  ProxyPass "http://localhost:18899/rm/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/\/(ip-.*?:8042)'|href='/nm/$1/'|"
  Substitute 's|[hH][rR][eE][fF]="\/\/(ip-.*?:8042)"|href="/nm/$1/"|'
  Substitute 's%[hH][rR][eE][fF]="\/((?!static|nm|rm).*?)"%href="/rm/$1"%'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*:8042)\/(.*?)'|href='/nm/$2/$3'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*:8042)\/(.*?)"|href="/nm/$2/$3"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>
<Location "/cluster/">
  ProxyPass "http://localhost:18899/cluster/" connectiontimeout=25 timeout=30
</Location>
<Location "/tez/">
  ProxyPass "http://localhost:18899/tez/" connectiontimeout=25 timeout=30
</Location>

<Location "/presto/">
  ProxyPass "http://localhost:18899/presto/" connectiontimeout=25 timeout=30
  RequestHeader unset Accept-Encoding
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute 's|"/v1/|"/presto/v1/|nq'
  Substitute "s|'/v1/|'/presto/v1/|nq"
  Substitute 's|href: \"/ui/|href: \"/presto/ui/|nq'
  Substitute 's|\Q_react2.default.createElement(\n\E\s*\Q\"a\",\n\E\s*{\s*href:\s*task\.taskStatus\.self\s*\+\s*\Q\"?pretty\"\E\s*},\Q\n\E\s*\(0,\s*\Q_utils.getTaskIdSuffix)(task.taskId)\n\E\s*\)|(0, _utils.getTaskIdSuffix)(task.taskId)|'
</Location>

<Location "/hiveui/">
  ProxyPass "http://localhost:18899/hiveui/" connectiontimeout=25 timeout=30
  SetOutputFilter SUBSTITUTE;DEFLATE
  Substitute 's|href="/|href="/hiveui/|nq'
  Substitute 's|src="/|src="/hiveui/|nq'
  Substitute 's|href= /|href= /hiveui/|nq'
</Location>

</VirtualHost> |base64 -d > /home/hadoop/ssl.conf #Dynamicportfordwarding nginx.conf sudo echo #user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    #server {
        #listen       80;
        #server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        #location / {
            #root   html;
            #index  index.html index.htm;
        #}

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        #error_page   500 502 503 504  /50x.html;
        #location = /50x.html {
            #root   html;
        #}

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    #}


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
    upstream notebook {
        server localhost:9547;
    }

    # HTTPS server
    #
    server {

        listen 18888 ssl;
        ssl_certificate /etc/ssl/certs/nginx.crt;
        ssl_certificate_key /etc/ssl/certs/nginx.key;
        ssl_protocols TLSv1.2;

        server_name localhost;

        location /webhdfs/v1/user {
          proxy_pass    http://localhost:14000;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /sessions {
          proxy_pass    http://localhost:8998;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /batches {
          proxy_pass    http://localhost:8998;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }
        location /proxy {
          proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:20888;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /api/kernels {
          proxy_pass    http://localhost:9547;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /api/sessions {
          proxy_pass    http://localhost:9547;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /api/kernelspecs {
          proxy_pass    http://localhost:9547;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /kernelspecs {
          proxy_pass    http://localhost:9547;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location ~* /(api/kernels/[^/]+/(channels|iopub|shell|stdin)|terminals/websocket)/? {
                proxy_pass            http://notebook;
                proxy_set_header      Host $host;
                # websocket support
                proxy_http_version    1.1;
                proxy_set_header      Upgrade "websocket";
                proxy_set_header      Connection "Upgrade";
                proxy_read_timeout    86400;
        }

        location /emr/kernelmeta {
          proxy_pass    http://localhost:7780;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }

        location /emr/clusterconfig {
          proxy_pass    http://localhost:7780;
          proxy_read_timeout 1800;
          proxy_connect_timeout 1800;
        }
    }

  server {
      listen 18899;
      server_name  localhost;

      location / {
        root   html;
        index  index.html index.htm;
      }

      location /proxy {
        proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:20888;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:18080/history/ /shs/history/;
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:8080/ /tez/;
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:8088/cluster/ /cluster/;
      }

      location ~ ^(?<prefix>/history$) {
        return 302 $scheme://$host:$server_port$prefix/;
      }

      location /jh/ {
        proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:19888/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
      }

      location ~* ^(?<prefix>/shs$) {
        return 302 $scheme://$host:$server_port$prefix/;
      }

      location ~* ^(\/nm\/(?<nodeAddress>.*:8042)\/(?<url>.*)$) {
        resolver 172.31.0.2;
        resolver_timeout 2s;
        proxy_pass http://$nodeAddress/$url$is_args$args;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_set_header Accept-Encoding "";
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:19888/ /jh/;
        proxy_redirect ~*http(s)?:\/\/(.*:8042)\/(.*) /nm/$2/$3;
        sub_filter_once off;
        sub_filter_types *;
        sub_filter http://HOSTNAME.DOMAINNAME.FQDN:8088 /rm/;
        sub_filter /node/ /nm/$nodeAddress/node/;
        sub_filter /conf /nm/$nodeAddress/conf;
        sub_filter /logs /nm/$nodeAddress/logs;
        sub_filter /stacks /nm/$nodeAddress/stacks;
        sub_filter /jmx?qry=Hadoop:* /nm/$nodeAddress/jmx?qry=Hadoop:*;
      }

      location /shs/ {
        proxy_pass http://HOSTNAME.DOMAINNAME.FQDN:18080/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_set_header Accept-Encoding "";
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:18080/history/ /shs/history/;
      }

      location /static/ {
        proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:19888/static/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
      }

      location /applicationhistory/ {
        rewrite /applicationhistory/ /yts/applicationhistory/;
      }

      location /yts/ {
        proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:8188/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_set_header Accept-Encoding "";
      }

      location /rm/ {
        proxy_pass	http://HOSTNAME.DOMAINNAME.FQDN:8088/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_set_header Accept-Encoding "";
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:19888/ /jh/;
        proxy_redirect http://HOSTNAME.DOMAINNAME.FQDN:8088/ /rm/;
      }

      location ~* ^/cluster/(?<url>.*) {
        return 302 /rm/cluster/$url;
      }

      location /tez/ {
        proxy_pass    http://HOSTNAME.DOMAINNAME.FQDN:8080/tez-ui/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
        proxy_set_header Accept-Encoding "";
        sub_filter_once off;
        sub_filter_types *;
        sub_filter http://HOSTNAME.DOMAINNAME.FQDN:8188 /yts;
        sub_filter http://HOSTNAME.DOMAINNAME.FQDN:8088 /rm;
        sub_filter '"http://HOSTNAME.DOMAINNAME.FQDN:20888"' '"/proxy"';
        sub_filter 'proxy/{app_id}' '{app_id}';
        sub_filter 'href: logs' 'href: "/nm/" + logs.substring(logs.indexOf("://")+3)';
        sub_filter "return yarnProtocol + '://' + logURL" "return '/nm/' + logURL";
        sub_filter 'this.normalizeURL(this.get("env.app.hosts.timeline"))' 'location.origin + this.normalizeURL(this.get("env.app.hosts.timeline")).replace(location.protocol + "///", "/")';
        sub_filter 'this.normalizeURL(this.get("env.app.hosts.rm"))' 'location.origin + this.normalizeURL(this.get("env.app.hosts.rm")).replace(location.protocol + "///", "/")';
        sub_filter 'this.normalizeURL(url)' 'location.origin + this.normalizeURL(url).replace(location.protocol + "///", "/")';
    }
    
      location /presto/ {
        proxy_pass    https://localhost:8446/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
      }

      location /hiveui/ {
        proxy_pass    http://localhost:10002/;
        proxy_read_timeout 25;
        proxy_connect_timeout 20;
      }
  }
}
 |base64 -d > /home/hadoop/nginx.conf #Dynamicportfordwarding httpd.conf sudo echo 
ServerRoot "/etc/httpd"

TraceEnable Off

Listen 19999

Include conf.modules.d/*.conf

User apache
Group apache

ServerAdmin root@localhost


<Directory />
    AllowOverride none
    Require all denied
</Directory>


DocumentRoot "/var/www/html"

<Directory "/var/www">
    AllowOverride None
    # Allow open access:
    Require all granted
</Directory>

# Further relax access to the default document root:
<Directory "/var/www/html">

    Options Indexes FollowSymLinks


    AllowOverride None


    Require all granted
</Directory>


<IfModule dir_module>
    DirectoryIndex index.html
</IfModule>


<Files ".ht*">
    Require all denied
</Files>


ErrorLog "logs/error_log"


LogLevel warn

<IfModule log_config_module>

    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
    LogFormat "%h %l %u %t \"%r\" %>s %b" common

    <IfModule logio_module>
      # You need to enable mod_logio.c to use %I and %O
      LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
    </IfModule>


    CustomLog "logs/access_log" combined
</IfModule>

<IfModule alias_module>

    ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"

</IfModule>


<Directory "/var/www/cgi-bin">
    AllowOverride None
    Options None
    Require all granted
</Directory>

<IfModule mime_module>
    TypesConfig /etc/mime.types

    AddType application/x-compress .Z
    AddType application/x-gzip .gz .tgz


    AddType text/html .shtml
    AddOutputFilter INCLUDES .shtml
</IfModule>

AddDefaultCharset UTF-8

<IfModule mime_magic_module>

    MIMEMagicFile conf/magic
</IfModule>

EnableSendfile on

<IfModule mod_http2.c>
    Protocols h2 h2c http/1.1
</IfModule>


<VirtualHost *:19999>
ServerName localhost

RewriteEngine on
RewriteRule ^/shs$ /shs/ [R]
RewriteRule ^/yts$ /yts/ [R]
RewriteRule ^/applicationhistory$ /applicationhistory/ [R]
RewriteRule ^/jh$ /jh/ [R]
RewriteRule ^/rm$ /rm/ [R]
RewriteRule ^/cluster$ /cluster/ [R]

ProxyPassReverse http://localhost:19999/ http://localhost:18899/
ProxyPassReverse http://localhost:19999/ https://localhost:18899/

<Location "/proxy">
  ProxyPass "http://localhost:18899/proxy" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8080/tez-ui/|/tez/tez-ui/|nq"
  Substitute "s|http:\/\/(ip-.*?:8042)|/nm/$1|"
</Location>

<Location "/jh/">
  ProxyPass "http://localhost:18899/jh/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/jh/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/jh/$1"|'
</Location>

<LocationMatch "^(\/nm\/(?<nodeip>.*:8042)\/(?<url>.*)$)">
  ProxyPass "http://localhost:18899/" connectiontimeout=25 timeout=30
</LocationMatch>

<Location "/shs/">
  ProxyPass "http://localhost:18899/shs/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute 's|href="/|href="/shs/|nq'
  Substitute 's|src="/|src="/shs/|nq'
  Substitute 's|uiRoot=""|uiRoot="/shs"|nq'
  Substitute "s|setUIRoot('')|setUIRoot('/shs')|nq"
  Substitute "s|http:\/\/(ip-.*?:8042)|/nm/$1|"
</Location>

<Location "/static/">
  ProxyPass "http://localhost:18899/static/" connectiontimeout=25 timeout=30
</Location>

<Location "/applicationhistory/">
  ProxyPass "http://localhost:18899/applicationhistory/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/yts/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/yts/$1"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8188/|/yts/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>

<Location "/yts/">
  ProxyPass "http://localhost:18899/yts/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/((?!static).*?)'|href='/yts/$1'|"
  Substitute 's|[hH][rR][eE][fF]="\/((?!static).*?)"|href="/yts/$1"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8188/|/yts/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>

<Location "/rm/">
  ProxyPass "http://localhost:18899/rm/" connectiontimeout=25 timeout=30
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute "s|[hH][rR][eE][fF]='\/\/(ip-.*?:8042)'|href='/nm/$1/'|"
  Substitute 's|[hH][rR][eE][fF]="\/\/(ip-.*?:8042)"|href="/nm/$1/"|'
  Substitute 's%[hH][rR][eE][fF]="\/((?!static|nm|rm).*?)"%href="/rm/$1"%'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*?:8042)'|href='/nm/$2/'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*?:8042)"|href="/nm/$2/"|'
  Substitute "s|[hH][rR][eE][fF]='http(s)?:\/\/(.*:8042)\/(.*?)'|href='/nm/$2/$3'|"
  Substitute 's|[hH][rR][eE][fF]="http(s)?:\/\/(.*:8042)\/(.*?)"|href="/nm/$2/$3"|'
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:8088/|/rm/|nq"
  Substitute "s|http://HOSTNAME.DOMAINNAME.FQDN:20888/proxy/|/proxy/|nq"
</Location>

<Location "/cluster/">
  ProxyPass "http://localhost:18899/cluster/" connectiontimeout=25 timeout=30
</Location>

<Location "/tez/">
  ProxyPass "http://localhost:18899/tez/" connectiontimeout=25 timeout=30
</Location>

<Location "/presto/">
  ProxyPass "http://localhost:18899/presto/" connectiontimeout=25 timeout=30
  RequestHeader unset Accept-Encoding
  AddOutputFilterByType SUBSTITUTE text/text text/html text/plain text/xml text/css application/x-javascript application/javascript application/json
  Substitute 's|"/v1/|"/presto/v1/|nq'
  Substitute "s|'/v1/|'/presto/v1/|nq"
  Substitute 's|href: \"/ui/|href: \"/presto/ui/|nq'
  Substitute 's|\Q_react2.default.createElement(\n\E\s*\Q\"a\",\n\E\s*{\s*href:\s*task\.taskStatus\.self\s*\+\s*\Q\"?pretty\"\E\s*},\Q\n\E\s*\(0,\s*\Q_utils.getTaskIdSuffix)(task.taskId)\n\E\s*\)|(0, _utils.getTaskIdSuffix)(task.taskId)|'
</Location>

<Location "/hiveui/">
  ProxyPass "http://localhost:18899/hiveui/" connectiontimeout=25 timeout=30
  SetOutputFilter SUBSTITUTE;DEFLATE
  Substitute 's|href="/|href="/hiveui/|nq'
  Substitute 's|src="/|src="/hiveui/|nq'
  Substitute 's|href= /|href= /hiveui/|nq'
</Location>

</VirtualHost>


# Supplemental configuration
#
# Load config files in the "/etc/httpd/conf.d" directory, if any.
IncludeOptional conf.d/*.conf
 |base64 -d > /home/hadoop/httpd.conf sudo sed -i -e "s|HOSTNAME.DOMAINNAME.FQDN|$HOSTNAME|g" /home/hadoop/ssl.conf sudo sed -i -e "s|HOSTNAME.DOMAINNAME.FQDN|$HOSTNAME|g" /home/hadoop/httpd.conf sudo sed -i -e "s|HOSTNAME.DOMAINNAME.FQDN|$HOSTNAME|g" /home/hadoop/nginx.conf sudo sed -i -e "s|serverhostname|$HOSTNAME|g" /home/hadoop/ssl.conf sudo cp /home/hadoop/ssl.conf /etc/httpd/conf.d/ssl.conf sudo cp /home/hadoop/httpd.conf /etc/httpd/conf/httpd.conf sudo cp /home/hadoop/nginx.conf /etc/nginx/nginx.conf sudo systemctl restart httpd.service sudo systemctl restart nginx.service