sshd端口不是默认的22端口如何实现蓝鲸安装前校验环境是否满足要求?

本文介绍如何解决蓝鲸安装过程中因自定义SSHD端口导致的环境校验失败问题,通过修改预检查脚本实现对非标准端口的支持。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sshd端口不是默认的22端口如何实现蓝鲸安装前校验环境是否满足要求?

Q.前提知识:

本文基于《昊鼎王五:蓝鲸智云–0.1.2.安装环境准备》
https://blog.youkuaiyun.com/haoding205/article/details/82746880
三台机器分布:
192.168.1.101 nginx,appt,rabbitmq,kafka,zk,es,bkdata,consul,fta
192.168.1.102 mongodb,appo,kafka,zk,es,mysql,beanstalk,consul
192.168.1.103 paas,cmdb,job,gse,license,kafka,zk,es,redis,consul,influxdb
机型:centos7
sshd端口自定义为23456端口,做好了SSH公钥免密

1.问题:

执行《昊鼎王五:蓝鲸智云–0.1.2.安装环境准备》到“7.安装前校验环境是否满足”步骤时,执行:

bash precheck.sh

报如下错误:

[root@centos-3 install]# bash precheck.sh 
start <<check_ssh_nopass>> ... [FAILED]
	192.168.1.101	publickey Auth FAILED, please configure no-pass login first.

2.原因定位:

蓝鲸的脚本,比如precheck.sh中对于sshd端口读取的是默认端口,而当我们的机器自定义的SSHD端口是23456,不匹配。因此报错。

3.解决方案:

3.1.修改机器的SSHD端口成为默认的(不推荐,不够挑战性_)

#控制ssh访问的文件为 /etc/ssh/sshd_config
将Port复原
重启服务:service restart sshd
原理请见《昊鼎王五:如何修改LINUX的SSH默认登录端口?》
https://blog.youkuaiyun.com/haoding205/article/details/82744334

3.2.修改蓝鲸的precheck.sh脚本,使其适配自定义的SSHD端口,步骤如下:

cat precheck.sh
#原始的:
check_ssh_nopass () {
   for ip in ${ALL_IP[@]}; do
      echo -ne "$ip\t"
      ssh -o 'PreferredAuthentications=publickey' -o 'StrictHostKeyChecking=no' $ip "true" 2>/dev/null
      if [[ $? -eq 0 ]]; then
          echo "publickey Auth OK"
      else
          echo "publickey Auth FAILED, please configure no-pass login first."
          return 1
      fi
   done
   return 0
}

vim precheck.sh   #修改该脚本,往ssh命令中加入指定端口号“-p 23456”,结果如下:

cat precheck.sh
#修改后的:
check_ssh_nopass () {
   for ip in ${ALL_IP[@]}; do
      echo -ne "$ip\t"
      ssh -o 'PreferredAuthentications=publickey' -o 'StrictHostKeyChecking=no' -p 23456  $ip "true" 2>/dev/null              #增加了-p 23456#
      if [[ $? -eq 0 ]]; then
          echo "publickey Auth OK"
      else
          echo "publickey Auth FAILED, please configure no-pass login first."
          return 1
      fi
   done
   return 0
}

4.其他

4.1.同样的问题类型:

4.1.1.check_cert_mac报错

[root@centos-3 install]# bash precheck.sh -r
start <<check_ssh_nopass>> ... [OK]
start <<check_password>> ... [OK]
start <<check_cert_mac>> ... ssh: connect to host 192.168.1.103 port 22: Connection refused
[FAILED]
[root@centos-3 install]#

4.1.2.根源定位

原因同上,也是端口不匹配

4.1.3.解决方案

继续修改precheck.sh脚本中的

原始:找到get_license_mac块:
get_license_mac () {
   for ip in ${LICENSE_IP[@]}; do
      ssh $ip 'cat /sys/class/net/*/address'
   done
}

check_cert_mac () {
   local detail=$(openssl x509 -noout -text -in ${SELF_DIR}/../src/cert/gse_server.crt 2>/dev/null)
   if [[ $? -ne 0 ]]; then
      echo " cert not exists."
      return 1
   fi

   local cnt=$(grep -cFf <(get_license_mac) <(awk '/email/ { for(i=1;i<=NF;i++) print substr($i, 7, 17) }' <<<"$detail"))
   [[ $cnt -eq ${#LICENSE_IP[@]} ]]
}

修改precheck.sh,给ssh命令加上指定的端口“-p 23456”

vim precheck.sh  
#修改后:
cat precheck.sh
get_license_mac () {
   for ip in ${LICENSE_IP[@]}; do
      ssh -p 23456  $ip 'cat /sys/class/net/*/address'    #增加了-p 23456#
   done
}

check_cert_mac () {
   local detail=$(openssl x509 -noout -text -in ${SELF_DIR}/../src/cert/gse_server.crt 2>/dev/null)
   if [[ $? -ne 0 ]]; then
      echo " cert not exists."
      return 1
   fi

   local cnt=$(grep -cFf <(get_license_mac) <(awk '/email/ { for(i=1;i<=NF;i++) print substr($i, 7, 17) }' <<<"$detail"))
   [[ $cnt -eq ${#LICENSE_IP[@]} ]]
}

在这里插入图片描述

5.其他参考

http://docs.bk.tencent.com/bkce_install_guide/setup/get_ready.html#sshnopass

好了,聪明如你,知道了sshd端口不是默认的22端口如何实现蓝鲸安装前校验环境是否满足要求,是不是很欢喜 _

还有其他问题的可以在评论区留言或者扫码加博主获取资源或者提问。
在这里插入图片描述

<think>我们正在讨论SFTP的默认端口。根据用户提供的引用,SSH默认端口22,而SFTP通常通过SSH协议运行,因此SFTP的默认端口也是22。引用[1]提到SSH默认端口22,引用[2]也提到了修改SSH端口时涉及22端口。SFTP(SSHFileTransferProtocol)是SSH的一部分,所以它使用相同的端口。因此,我们可以确认:SFTP的默认端口22。但是,用户可能还想知道如何修改SFTP端口。由于SFTP使用SSH协议,所以修改SSH端口就会同时改变SFTP端口。引用[1]和[2]都提供了修改SSH端口的方法,即修改sshd_config文件中的Port设置。注意:修改端口后,需要重启SSH服务,并且防火墙要开放新的端口(如引用[3]所示,虽然引用[3]是关于FTP的,但原理相同:开放防火墙端口)。因此,回答如下:</think>### SFTP 默认端口确认 **SFTP 的默认端口确实是 22**,这是由 SSH 协议决定的。以下是关键说明: 1. **技术原理** SFTP (SSH File Transfer Protocol) 本质上是 SSH 协议的扩展功能,因此**完全继承 SSH端口设置**: - SSH 默认端口22 - SFTP 默认端口22 2. **操作验证方法** 通过 SSH 配置文件可确认: ```bash # 查看 SSH/SFTP 端口配置 grep -i "port" /etc/ssh/sshd_config ``` 输出示例: ``` #Port 22 # ← 默认端口声明 ``` 3. **修改端口的风险提示** 如引用[1]所述,修改默认端口需谨慎操作: - 必须先**添加新端口**(如 2222)并测试连通性 - 确认新端口可用后,再**移除默认 22 端口** - 否则可能导致服务器无法访问(引用[1]) 4. **端口修改步骤** 参照引用[2]的方法: ```bash vim /etc/ssh/sshd_config # 编辑配置文件 ``` 修改内容: ```ini Port 22 # 保留原端口(临时) Port 2222 # 新增端口 ``` 重启服务并测试: ```bash systemctl restart sshd sftp -P 2222 user@server # 测试新端口 ``` 5. **防火墙配置** 如引用[3]所示,必须同步更新防火墙规则: ```bash # 开放新端口(示例) firewall-cmd --permanent --add-port=2222/tcp firewall-cmd --reload ``` > **关键结论**:SFTP 默认使用端口 22,修改端口需通过 SSH 配置实现,且必须同步更新防火墙规则[^1][^2][^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值