美文网首页
linux执行远程命令找不到环境变量

linux执行远程命令找不到环境变量

作者: 卡萨布兰卡ginger | 来源:发表于2018-11-07 19:40 被阅读0次

    问题:
    当使用ssh执行远程命令或者远程服务器的运行脚本时,报错:can‘t find .....这里我碰到的是go里面的,见下图:


    image

    我配置的gopath在/home/go下面,本质的问题还是找不到自定义的环境变量;但是直接用ssh登录到远程服务器上面以后,再执行相应的脚本时成功的。

    查阅资料发现,这两种方式使用的bash模式不同(bash:shell的一种,也是现在大部分的linux的发行版本,shell就简单理解成命令行解释器吧)

    首先,先解释一下linux下面的四种bash模式:

    1. login shell:

    When you log onto the system use password
    表示当你登录使用用户名密码到服务器上的时候,会得到一个login shell
    在终端使用--login会得到一个交互式的login shell
    在脚本中使用--login会得到一个非交互式的login shell(非交互式:执行完脚本就退出)
    使用su -切换用户会得到此用户login shell

    1. non-login shell

    除了上面的情况,得到的都是non-login shell。不需要使用密码重复登录获取shell得到的都是non-login shell。比如:
    window登录到linux,然后再使用图形化界面登录就不需要密码,是non-login shell
    在当前的bash下面再执行一个bash指令,也是一个non-login shell。
    简单来说,不需要用户名密码的都是non-login shell

    1. interactive

    交互式

    4.non-interactive

    非交互式

    其中1和2是或者的关系,3和4也是或者的关系

    1和2的shell 模式决定了配置文件的加载方式!!!

    一:使用ssh登录到服务器再执行脚本或者命令

    使用的bash模式: interactive + login shell
    加载的配置文件方式(按照先后顺序,找到退出)
    /etc/profile
    ~/.bash_profile ~/.bash_login ~/.profile

    二:使用ssh执行远程命令和脚本

    使用的bash模式:non-interactive+non-login shell
    加载的配置文件方式(按照先后顺序,找到退出)
    ~/.bashrc

    出现的原因:
    由于~/.bashrc中没有配置相关自定义的环境变量,所以找不到配置的gopath,默认在/root目录下面找,找不到所需的文件

    解决问题:
    可以在~/.bashrc里面配置自己所需要的环境变量

    参考资料:
    shell 模式参考资料:https://likegeeks.com/linux-environment-variables/

    相关文章

      网友评论

          本文标题:linux执行远程命令找不到环境变量

          本文链接:https://www.haomeiwen.com/subject/fjfvxqtx.html