mac连接linux服务器

1、mac连接linux服务器

复制代码
# ssh -p 22  root@192.168.1.15

2、mac指定密码连接linux服务器

复制代码
(1) 先安装sshpass,下载后解压执行 ./configure && make && makeinstall 
https://sourceforge.net/projects/sshpass/
(2) 连接linux
# sshpass -p \/\\\[\!\'\@wen12\$ ssh -p 22 root@192.168.1.15  # 复杂密码需要加转义符,转义后的密码是 /\[!'@wen12$
(3) 把密码写入文件中通过-f指定文件登录
# cat pass.txt
/\[!'@wen12$
# sshpass -f pass.txt ssh -p 22 root@192.168.1.15   # pass.txt文件中的复杂密码无需转义

3、mac指定私钥和私钥密码短语连接linux服务器

复制代码
(1) 服务器先生成密钥对并把生成的私钥传给mac机,为了方便查询可以把私钥重命名
# ssh-keygen -t rsa
# ssh-keygen -t rsa -P \/\\\[\!\'\@wen12\$     # 可以通过-P指定密码短语,特殊符号要转义,转义后密码/\[!'@wen12$ 
# cp ~/.ssh/id_rsa.pub ~/.ssh/authorized_keys
# chmod 600 ~/.ssh/authorized_keys
(2)mac指定私钥连接linux服务器
# ssh -p 22 -i /Users/wenqiang/Documents/myjumpserver/k8s-master-192.168.1.15-id_rsa root@192.168.1.15
(3) 如果生成私钥时指定了密码短语,ssh登录linux服务器时会每次都询问密码,可以先在mac上添加私钥密码短语,然后再指定私钥连接linux服务器就不会每次都询问私钥密码了
# ssh-add -K 私钥     # 执行该条命令会提示输入私钥密码并自动保存私钥密码到mac钥匙串中,如果更换了私钥只需要在执行改命令即可,执行ssh-add 后无需知道秘钥也可以直接登录linux服务器

4、mac通过命令终端编写连接linux服务器工具

复制代码
wenqiang@wq password % cat ../myjumpserver 
#!/bin/bash
# 修改或添加服务器信息需要改三处: 1>服务器数组列表 2>函数中case条件  3>私钥或密码文件名称

# 公司服务器数组
companyserverlist=(
gitlib_北区微软-192.168.1.111
esxi_腾讯云上海-192.168.1.112
)
# 个人服务器数组
personserverlist=(
etcd1_虚拟机-192.168.1.111
etcd2-192.168.1.112
etcd3-192.168.1.113
)
# 密码文件存放目录和私钥文件存放目录
passdir='/Users/wenqiang/Documents/myjumpserver/password'
privadir='/Users/wenqiang/Documents/myjumpserver/privatekey'
# 登录公司服务器函数
function companyserver(){
  select hosts in "${companyserverlist[@]}"
  do
    case ${hosts} in 
      'gitlib_北区微软-192.168.1.111')
        sshpass -f ${passdir}/${hosts} ssh -p 22 root@${hosts#*-}  # ${hosts#*-}表示取变量开头到第一个-之外内容
        ;;
      'esxi_腾讯云上海-192.168.1.112')
        ssh -p 22 -i ${privadir}/${hosts} root@${hosts#*-}
        ;;
      *)
        ;;
    esac
    echo "---enter选择公司服务器---"
  done
}
# 登录个人服务器函数
function personserver(){
  select hosts in "${personserverlist[@]}"
  do
    case ${hosts} in
      'etcd1_虚拟机-192.168.1.111')
        sshpass -f ${passdir}/${hosts} ssh -p 22 root@${hosts#*-}
        ;;
      'etcd2-192.168.1.112')
        sshpass -f ${passdir}/${hosts} ssh -p 22 root@${hosts#*-}
        ;;
      'etcd3-192.168.1.113')
        sshpass -f ${passdir}/${hosts} ssh -p 22 root@${hosts#*-}
        ;;
      *)
        ;;
    esac
    echo "---enter选择个人服务器---"
  done

}

select values in '公司服务器' '个人服务器'
do
  case ${values} in
    '公司服务器')
      companyserver
      ;;

    '个人服务器')
      personserver
      ;;
    *)
      ;;
  esac
done


# 把myjumpserver脚本加入环境变量,重启终端生效
wenqiang@wq ~ % cat ~/.zshrc 
MYJUMPSERVER="/Users/wenqiang/Documents/myjumpserver/"
export PATH=$PATH:$MYJUMPSERVER

# 查看效果
wenqiang@wq ~ % myjumpserver 
1) 公司服务器
2) 个人服务器
#? 2
---按enter选择要登录的【个人服务器】---
1) k8s-master-192.168.1.15
2) k8s-node-192.168.1.16
#? 1
Last login: Sat Dec  2 20:06:22 2023 from 192.168.1.9
[root@k8s-master ~]#
相关推荐
想唱rap1 小时前
Linux开发工具(4)
linux·运维·服务器·开发语言·算法
robin59112 小时前
Linux-通过端口转发访问数据库
linux·数据库·adb
视觉AI2 小时前
如何查看 Linux 下正在运行的 Python 程序是哪一个
linux·人工智能·python
扣脚大汉在网络2 小时前
如何在centos 中运行arm64程序
linux·运维·centos
泷羽Sec-静安2 小时前
Less-9 GET-Blind-Time based-Single Quotes
服务器·前端·数据库·sql·web安全·less
lang201509282 小时前
Linux命令行:cat、more、less终极指南
linux·chrome·less
猫头虎3 小时前
永久免费白嫖多个域名,一键托管Cloudflare,免费申请SSL加密证书,轻松建站、搭建线路伪装
服务器·开发语言·网络·数据库·python·网络协议·ssl
攒钱植发3 小时前
嵌入式Linux——“大扳手”与“小螺丝”:为什么不该用信号量(Semaphore)去模拟“完成量”(Completion)
linux·服务器·c语言
三五度3 小时前
vmware的ubuntu20.04无网络图标
linux·ubuntu
真正的醒悟3 小时前
什么是安全设备组网
服务器·数据库·php