| #!/usr/bin/env python |
| ############################################################################ |
| # |
| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| ############################################################################ |
| |
| from __future__ import print_function |
| from phoenix_utils import tryDecode |
| import os |
| import subprocess |
| import sys |
| import phoenix_utils |
| import atexit |
| |
| # import argparse |
| try: |
| import argparse |
| except ImportError: |
| current_dir = os.path.dirname(os.path.abspath(__file__)) |
| sys.path.append(os.path.join(current_dir, 'argparse-1.4.0')) |
| import argparse |
| |
| global childProc |
| childProc = None |
| def kill_child(): |
| if childProc is not None: |
| childProc.terminate() |
| childProc.kill() |
| if os.name != 'nt': |
| os.system("reset") |
| atexit.register(kill_child) |
| |
| phoenix_utils.setPath() |
| |
| parser = argparse.ArgumentParser(description='Launches the Apache Phoenix Client.') |
| # Positional argument 'zookeepers' is optional. The PhoenixDriver will automatically populate |
| # this if it's not provided by the user (so, we want to leave a default value of empty) |
| parser.add_argument('zookeepers', nargs='?', help='The ZooKeeper quorum string or full JDBC URL', default='') |
| # Positional argument 'sqlfile' is optional |
| parser.add_argument('sqlfile', nargs='?', help='A file of SQL commands to execute', default='') |
| parser.add_argument('--noconnect', help='Start without making a connection', |
| action="store_true") |
| parser.add_argument('--verbose-command', |
| help='Show the Java command on the console before executing it', |
| action="store_true") |
| # Common arguments across sqlline.py and sqlline-thin.py |
| phoenix_utils.common_sqlline_args(parser) |
| # Parse the args |
| args=parser.parse_args() |
| |
| zookeeper = tryDecode(args.zookeepers) |
| if zookeeper.startswith('jdbc:phoenix'): |
| jdbc_url = zookeeper |
| else: |
| # We do want to use the default "jdbc:phoenix:" URL if no URL was specified |
| jdbc_url = 'jdbc:phoenix:' + zookeeper |
| sqlfile = tryDecode(args.sqlfile) |
| |
| |
| if sqlfile and not os.path.isfile(sqlfile): |
| parser.print_help() |
| sys.exit(-1) |
| |
| if sqlfile: |
| sqlfile = "--run=" + phoenix_utils.shell_quote([sqlfile]) |
| |
| colorSetting = tryDecode(args.color) |
| # disable color setting for windows OS |
| if os.name == 'nt': |
| colorSetting = "false" |
| |
| #See PHOENIX-6661 |
| if os.uname()[4].startswith('ppc'): |
| disable_jna = " -Dorg.jline.terminal.jna=false " |
| else: |
| disable_jna = "" |
| |
| java_cmd = phoenix_utils.java + ' ' + phoenix_utils.jvm_module_flags + ' $PHOENIX_OPTS ' + \ |
| ' -cp "' + phoenix_utils.hbase_conf_dir + os.pathsep + \ |
| phoenix_utils.hadoop_conf + os.pathsep + \ |
| phoenix_utils.sqlline_with_deps_jar + os.pathsep + \ |
| phoenix_utils.slf4j_backend_jar + os.pathsep + \ |
| phoenix_utils.logging_jar + os.pathsep + \ |
| phoenix_utils.phoenix_client_embedded_jar + \ |
| '" -Dlog4j2.configurationFile=file:' + os.path.join(phoenix_utils.current_dir, "log4j2.properties") + \ |
| disable_jna + \ |
| " sqlline.SqlLine -d org.apache.phoenix.jdbc.PhoenixDriver" + \ |
| (not args.noconnect and " -u " + phoenix_utils.shell_quote([jdbc_url]) or "") + \ |
| " -n none -p none --color=" + \ |
| (args.color and "true" or "false") + \ |
| " --fastConnect=" + (args.fastconnect and "true" or "false") + \ |
| " --verbose=" + (args.verbose and "true" or "false") + \ |
| " --incremental=false --isolation=TRANSACTION_READ_COMMITTED " + sqlfile |
| |
| if args.verbose_command: |
| print("Executing java command: " + java_cmd) |
| |
| os.execl("/bin/sh", "/bin/sh", "-c", java_cmd) |