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:07:10 UTC

[jira] [Resolved] (AMBARI-14006) During Component Install conf-select Shell Uses Current Working Directory That Doesn't Exist Yet

     [ https://issues.apache.org/jira/browse/AMBARI-14006?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Andrew Onischuk resolved AMBARI-14006.
--------------------------------------
    Resolution: Fixed

Committed to trunk and branch-2.1

> 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)