首页 > 其他分享 >ssh远程不登录执行命令,不能执行alias 别名的命令

ssh远程不登录执行命令,不能执行alias 别名的命令

时间:2024-04-09 19:12:10浏览次数:324  
标签:profile 执行命令 shell 配置文件 bashrc alias ssh login bash

前言全局说明

ssh远程不登录执行命令,不能执行alias 别名的命令


一、bash 的工作模式

bash 可以有不同的调出的方式,例如开机之后按 Alt+F1~Alt+F6 呼出不同的终端,输入账户密码进入的 shell;ssh 远程登陆到一台机器进行的 shell;又或者在一个 shell 中执行 bash 命令又创建了一个 shell。总的来说,根据不同的调出的方式,bash 的工作模式也不一样, bash 初始配置是不一样的,这是通过读取不同的配置文件来实现的。

主要可以分为 login 与非 login、interactive 与非 interactive,在 man bash 文档中 INVOCATION 有简单的说明。login 是指需要输入用户名和密码登陆的 shell;interactive 顾名思义为交互式,命令的标准输入与输出为该 bash 绑定到的终端。如果使用 bash 命令来创建一个 shell,可以加参数 --login/-l 来强制使其使用 login 的方式执行。

对一个 shell 如何判断工作在哪种模式下呢?我这边介绍一种方式:

执行命令 echo $- ,查看输出的结果中是否含有 i 这一项,如果有则为 interactive,否则为非 interactive;($- 这个变量记录着当前设置的 shell 选项)
执行命令 shopt login_shell,查看输出的结果,如果为 on 则为 login,否则为非 login。(shopt命令用于显示和设置 shell 中的行为选项)
下表总结了组合之后得到的四种不同工作模式,其触发方式与读取的配置文件:

| | | |
| | | | |
| | | | |
| | | | |

bash 工作模式 触发方式 读取配置文件 备注
login + interactive 1. 登陆 Linux 获取的第一个 shell
2. 通过 ssh user_name@romote_ip 登陆获取到的 shell
3. 运行命令 bash -l 进入的 shell
1. 首先读取 /etc/profile 文件
2. 再从下面三个文件读取到第一个存在的文件 /.bash_profile、/.bash_login、~/.profile
/etc/profile 会依次读取 /etc/profile.d 下所有文件
login + non-interactive 1. 运行命令 bash -l script.sh 同上 该模式比较少用
non-login + interactive 1. 运行命令 bash 1. 读取 /etc/bash.bashrc 2. 读取 ~/.bashrc文件 ~/.bashrc 一般会读 /etc/bashrc 文件
non-login + non-interactive 1. 运行命令 bash script.sh 1. 读取环境变量 $BASH_ENV 的值,导入该值的配置文件 有个特例见下文

当然上表只是 bash 的默认读取配置文件的方式,建议你在这些配置文件中加些 echo 信息,然后通过不通的方式调用 bash 来实践下。

同时,bash 命令还可以通过指定参数来改变这种默认行为,例如 --rcfile、--noprofile 等等,下图更加清晰地展示了这点:

image


二、ssh 远程执行命令属于哪种模式的 bash?

说到现在可能还不知道这个东西和我前面说的问题有什么关联吧?前面说过我把 http_proxy 这个环境变量设置在 /etc/profile.d/xxx.sh(/etc/profile 文件会去读)中,结合上表如果 bash 是 login shell 的话,必然会读取到;那为何有些节点没有设置 http_proxy 呢?难道不是 login shell 吗?我意识到 ansible 推送命令和 ssh user_name@romote_ip script.sh 类似,那么这种方式 bash 工作在哪种模式呢?通过实验来证明下:

$ ssh root@vlutr 'echo $-; shopt login_shell'
@~/.bashrc@
@/etc/bashrc@
hBc
login_shell off
上面输出的结果中前两行是我在 ~/.bashrc 和 /etc/bashrc 打印的跟踪信息,后两行显示这种方式 bash 属于非 interactive 和非 login 模式,那结合上面的表格,应该读取环境变量 $BASH_ENV 的值作为导入环境变量的文件路径,但这个变量我们却没有设置啊,事实却是 ssh 远程执行命令会读取 ~/.bashrc 文件,百思不得其解。

最终还是从 bash 的帮助文档中获得了答案,详见下面这段,大致意思是 bash 会判断标准输入是否关联到 sshd 这样的网络链接上,如果是,会读取 ~/.bashrc 配置文件。

Bash attempts to determine when it is being run with its standard input connected to a network connection, as when executed by the remote shell daemon, usually rshd, or the secure shell daemon sshd. If bash determines it is being run in this fashion, it reads and executes commands from ~/.bashrc, if that file exists and is read‐ able.

那么至此一切才终于对上了。

为什么要这么多配置文件?
一个 bash 就有这么多配置文件,使用上有什么差异呢?

首先,/etc/profile 是一个全局的配置文件,bash 还有个每用户私有的配置文件~/.bash_profile,又为了各种 shell 之间的兼容性,又引入了两个配置文件,其中 .profile 继承了 Bourne shell 和 ksh 的 .profile 命名方法,~/.bash_login继承了 csh 的 .login 命名方法。

其次,各种 profile 和 bashrc 又有什么区别呢?前者主要放一些环境变量,例如 /etc/profile 是某个用户唯一的用来设置全局环境变量的地方,因为用户可以有多个shell比如 bash、sh、zsh等,像环境变量这种其实只需要在统一的一个地方初始化就可以了。后者主要设置与 bash 运行相关的设置,rc 的意思为 Run Commands,由名字可以推断出,此处存放 bash 需要运行的命令,但注意,这些命令一般只用于交互式的shell,通常在这里会设置交互所需要的所有信息,比如 bash 的补全、alias、颜色、提示符等等。


三、



四、




免责声明:本号所涉及内容仅供安全研究与教学使用,如出现其他风险,后果自负。




参考、来源:
https://hazirguo.github.io/articles/2017/bash_login_interactive_mode.html



标签:profile,执行命令,shell,配置文件,bashrc,alias,ssh,login,bash
From: https://www.cnblogs.com/wutou/p/18124591

相关文章

  • CentOS7设置ssh本机免密登录
    点击查看代码登出Connectiontoclone1closed.[[email protected]]#ll总用量16-rw-rw-r--.1rootroot3934月909:23authorized_keys-rw-------.1rootroot16794月719:16id_rsa-rw-r--r--.1rootroot3934月719:16id_rsa.pub-rw-r--r--.1r......
  • 在GitHub上用HTTP端口使用ssh
    问题:在实现本地仓库与GitHub仓库相关联时出现下图问题尝试了很多方法包括但不限于:更改公私钥密码,更改防火墙,检查仓库UPL等方法但都没有效果解决方法:通过HTTPS端口使用SSH测试有时,防火墙完全拒绝允许SSH连接。如果无法使用带有凭据缓存的HTTPS克隆,则可以尝试使用通过......
  • 配置交换机 SSH 管理和端口安全——实验1:配置交换机基本安全和 SSH管理
    实验目的通过本实验可以掌握:交换机基本安全配置。SSH的工作原理和SSH服务端和客户端的配置。实验拓扑交换机基本安全和SSH管理实验拓扑如图所示。                                         交换机基本安全和SSH管理实验拓......
  • web渗透-SSH私钥泄露
    发现主机netdiscover-r192.168.164.0扫描端口看到开放80和31337端口都为http服务 浏览器访问测试查看80端口和31337端口网页和源代码并无发现有用信息 目录扫描 扫描出80端口并无有用信息扫描31337端口发现敏感文件robots.txt和目录.ssh 访问敏感文件和目......
  • Q:ssh远程连接慢的原因排查
    连接linux服务器一般都是使用SSH远程连接的方式。有时,SSH连接速度很慢,大约30s左右,但是ping时一切正常。问题原因1、server的sshd会去DNS查找访问的clientip的hostname,如果DNS不可用或者没有相关记录,就会消耗一段时间。(我是这种情况)2、在authenticationgssapi-with-mic有时候......
  • H3C S3600 交换机配置SSH登录
    S3600这款交换机比较旧了,版本为V3生成服务器端的RSA和DSA密钥对时完成SSH登录的必要操作#生成RSA和DSA密钥对。[Switch]public-keylocalcreatersa[Switch]public-keylocalcreatedsa#设置用户接口上的认证模式为AAA认证。[Switch]user-interfacevty04[Switch-......
  • Java 解决 Process 执行命令行命令报【CreateProcess error=2, 系统找不到指定的文件
    目录问题问题代码解决方案判断操作系统问题使用Process执行命令行命令时,报 CreateProcesserror=2,系统找不到指定的文件。但明明指定的文件是存在的。而且这种错误只在 IDEA中运行会报错,打包后直接java-jar运行就能正常运行,不会报错。问题代码publicclas......
  • 在Linux中,如何配置SSH以确保远程连接的安全?
    在Linux中,可以通过以下步骤配置SSH以确保远程连接的安全:更新SSH软件包:首先,确保已安装最新版本的OpenSSH软件包。在终端中运行以下命令来更新软件包:sudoapt-getupdatesudoapt-getupgradeopenssh-server修改SSH端口:默认情况下,SSH服务器使用端口22。为了......
  • Ubuntu-openssh
    安装版本:ubuntu-14.04在Ubuntu上启用SSH默认情况下,当Ubuntu最初被安装的时候,通过SSH进行远程访问是不被允许的。在Ubuntu上启用SSH非常的简单直接。以root或者其他sudo用户身份执行下面的步骤,在你的Ubuntu系统上安装并且启用SSH。01.使用Ctrl+Alt+T打开终端......
  • 设置ssh免密登录
    点击查看代码[root@master~]#cd~/.ssh[[email protected]]#ssh-keygen-trsaGeneratingpublic/privatersakeypair.Enterfileinwhichtosavethekey(/root/.ssh/id_rsa):Enterpassphrase(emptyfornopassphrase):Entersamepassphraseagain:Yourid......