You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@ambari.apache.org by "Andrew Onischuk (JIRA)" <ji...@apache.org> on 2015/11/22 17:01:11 UTC
[jira] [Created] (AMBARI-14006) During Component Install
conf-select Shell Uses Current Working Directory That Doesn't Exist Yet
Andrew Onischuk created AMBARI-14006:
----------------------------------------
Summary: During Component Install conf-select Shell Uses Current Working Directory That Doesn't Exist Yet
Key: AMBARI-14006
URL: https://issues.apache.org/jira/browse/AMBARI-14006
Project: Ambari
Issue Type: Bug
Reporter: Andrew Onischuk
Assignee: Andrew Onischuk
Fix For: 2.1.3
On an existing (not upgraded) HDP 2.3.2.0-2390 cluster, installation of
additional components fails with the following error:
2015-10-21 08:28:44,613 - Skipping Execute[('cp', '-R', '-p', '/etc/zookeeper/conf', '/etc/zookeeper/conf.install')] due to not_if
2015-10-21 08:28:44,767 - New conf directories: shell-init: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory, shell-init: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory, job-working-directory: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory, /etc/zookeeper/2.3.2.0-2950/0
2015-10-21 08:28:45,075 - checked_call['conf-select set-conf-dir --package zookeeper --stack-version 2.3.2.0-2950 --conf-version 0'] {'logoutput': False, 'sudo': True, 'quiet': False}
2015-10-21 08:28:45,228 - checked_call returned (0, 'shell-init: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory\nshell-init: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory\njob-working-directory: error retrieving current directory: getcwd: cannot access parent directories: No such file or directory\n/usr/hdp/2.3.2.0-2950/zookeeper/conf -> /etc/zookeeper/2.3.2.0-2950/0')
Subsequent runs of the install command succeed. The root of the problem is:
getcwd: cannot access parent directories: No such file or directory\n/usr/hdp/2.3.2.0-2950/zookeeper/conf -> /etc/zookeeper/2.3.2.0-2950/0')
During a component install, we invoke the `conf-select` module which:
* Creates `conf.install` from `conf`
* Changes `conf` into a symlink
* Invoke `conf-select` to change pointers to <version>/0
However, the /etc/zookeeper/2.3.2.0-2950/0 does not yet exist while `conf-
select` is being invoked:
**after-INSTALL/scripts/shared_initialization.py**
versioned_confs = conf_select.create("HDP", package, version, dry_run = True)
**conf_select.py**
code, stdout = shell.call(get_cmd(command, package, version), logoutput=False, quiet=False, sudo=True)
**Now the real question here is why in the world the `/etc/zookeeper/2.3.2.0-2950/0` directory is being used a the cwd!** The workaround of this issue is to ensure we pass in the `cwd` to `shell` which will pass it to `Popen`:
code, stdout = shell.call(get_cmd(command, package, version), logoutput=False, quiet=False, sudo=True, cwd="/")
I think we need to:
* See if this can be reproduced and understood
* Determine a proper value for `cwd` here
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)