Error “non-absolute home” via Net:SSH

浪尽此生 提交于 2019-12-08 17:07:33

问题


The code in question

Net::SSH.start('server name', 'user')

This returns "non-absolute home". The 'user' in fact does have a home directory. One suggested approach was to modify ~/.ssh/config with full paths to the IdentityFile. This did not solve the issue.

The crazy part of this is that the code works fine if called through irb or console. The moment we try calling it from within a class method (with the same code) it returns the "non-absolute home" error.

The 'user' can also ssh into the server via command line without issue. The server is running Ubuntu.

UPDATE

Thanks to @Phrogz - The fix for this was setting ENV['HOME'] to '/home/deploy'. However, I have not figured out why $HOME is getting set to "." on the server. So, I will leave this question up without an "Answer" until I, or someone else, figures that out. Having to manually set HOME feels more like a "hack" than a proper solution, but it does work.


回答1:


We just ran into the same problem, and found the root cause. We're running our script as a service, and if you check the manpage for service, it strips most env variables before running the script, including HOME. I don't know if your scenario is the same, but HOME is not set.

net-ssh wants to look up ssh config from the users home folder, so it used to force ENV['HOME'] to "." if it was not set. But when File.expand_path tries to expand "~/.ssh" the ArgumentError is raised.

This was fixed two months ago ( https://github.com/net-ssh/net-ssh/pull/98 ), so updating your net-ssh gem should resolve this.




回答2:


It definitely works by setting the HOME env var if it's not set.




回答3:


Linux sets this information based on the /etc/passwd file.

Check what exists in /etc/passwd for the deployer user. It should be near the bottom of the list.

The items are colon separated. The value for ENV['HOME'] should be the second to last entry in that line.

Is it blank, ie have two colons together?

I suspect that your HOME variable isn't present in the /etc/passwd and is being set in one of the default dotfiles, ie something like .bashrc. Then, .bashrc is short circuited if your app is running via an init.d script that doesn't source your dotfiles. (Many .bashrc files stop loading remainder of commands if it is executed via a non-interactive shell).

Hope this helps and please post back with your findings.



来源:https://stackoverflow.com/questions/10391298/error-non-absolute-home-via-netssh

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!