位置: 编程技术 - 正文

高效使用SSH的技巧总结(如何使用ssh)

编辑:rootadmin

推荐整理分享高效使用SSH的技巧总结(如何使用ssh),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ssh命令如何使用,ssh协议使用,ssh基本操作,ssh命令如何使用,高效使用ssh的技术,高效使用ssh的技术方法,如何使用ssh,高效使用ssh的技术方法,内容如对您有帮助,希望把文章链接给更多的朋友!

SSH有很多非常酷的特性,如何它是你每天的工作伴侣,那么我想你有必要了解以下条高效使用SSH的秘籍,它们帮你节省的时间肯定会远远大于你用来配置它们的时间。

1. 多条连接共享

如果你需要在多个窗口中打开到同一个服务器的连接,而不想每次都输入用户名,密码,或是等待连接建立,那么你可以配置SSH的连接共享选项,在本地打开你的SSH配置文件,通常它们位于~/.ssh/config,然后添加下面2行:

复制代码代码如下:ControlMaster autoControlPath /tmp/ssh_mux_%h_%p_%r

现在试试断开你与服务器的连接,并建立一条新连接,然后打开一个新窗口,再创建一条连接,你会发现,第二条连接几乎是在瞬间就建立好了。

Windows用户

如果你是Windows用户,很不幸,最流行的开源SSH客户端Putty并不支持这个特性,但是Windows上也有OpenSSH的实现,比如这个Copssh,如果你觉得下面的一些技巧对你很有帮助,或许你应该试试Copssh。

文件传输

连接共享不止可以帮助你共享多个SSH连接,如果你需要通过SFTP与服务器传输文件,你会发现,它们使用的依然是同一条连接,如果你使用的 Bash,你会发现,你甚至SSH甚至支持Tab对服务器端文件进行自动补全,共享连接选项对于那些需要借助SSH的工具,比如rsync,git等等也 同样有效。

2. 长连接

如果你发现自己每条需要连接同一个服务器无数次,那么长连接选项就是为你准备的:

复制代码代码如下:ControlPersist 4h

现在你每次通过SSH与服务器建立连接之后,这条连接将被保持4个小时,即使在你退出服务器之后,这条连接依然可以重用,因此,在你下一次(4小时 之内)登录服务器时,你会发现连接以闪电般的速度建立完成,这个选项对于通过scp拷贝多个文件提速尤其明显,因为你不在需要为每个文件做单独的认证了。

3. 别再输入密码

如果你还在通过密码方式登录SSH,那么你或许应该试试SSH Keys,首先使用OpenSSH为自己声称一对密钥:

复制代码代码如下:$ ssh-keygen

跟随指示,完成之后,你应该可以在你的.ssh目录下看到两个文件,id_rsa就是你的私钥,而id_ras.pub则是你的公钥,现在你需要将你的公钥拷贝到服务器上,如果你的系统有ssh-copy-id命令,拷贝会很简单:

复制代码代码如下:$ ssh-copy-id smylers@compo.example.org

否则,你需要手动将你的公钥拷贝到服务器上的~/.ssh/authorized_keys文件中:

复制代码代码如下:$ < ~/.ssh/id_rsa.pub ssh clegg.example.org 'mkdir -p .ssh; cat >> .ssh/authorized_keys; chmod go-w .ssh .ssh/authorized_keys'

现在试试重新连接到SSH服务器,或是拷贝文件,是不是已经不需要再输入密码了?

为Putty配置SSH Key

Putty也可以使用SSH Key,从Putty网站下载PuttyGen和Pageant,然后使用PuttyGen生成你的密钥,将公钥拷贝到服务器的'.ssh/authorized_keys'目录,然后运行Pageant,导入你的私钥,让它在后台运行,险隘你就可以使用Putty通过公钥直接登录服务器了,你可以在Putty手册的第8,9章了解关于这一特性的详细介绍。

4. 连接中转

有时候你可能需要从一个服务器连接另外一个服务器,比如在两个服务器之间直接传输数据,而不用通过本地电脑中转:

复制代码代码如下:www1 $ scp -pr templates www2:$PWD

(顺便说一下,当你需要在两台服务器间拷贝文件时,$PWD变量时非常有用的),因为即使你已经在两台服务器上添加了你本地电脑的公钥,scp默认 仍然会提示你输入密码:这是因为你用来作为跳板的那台服务器上并没有你的私钥,所以,第二胎服务器会拒绝你的公钥,但是一定不要通过将你的私钥拷贝到中转 服务器上来解决这个问题,你可以使用agent forwarding来解决这个问题,只要在你的.ssh/config文件中加入下面这行代码就可以了:

复制代码代码如下:ForwardAgent yes

或者是在Putty中勾上“Allow agent forwarding”选项,现在你的本地SSH就变成了第一台服务器的SSH代理,从第一台服务器在连接其它服务器就变和和在你本地一样简单,注意,如果要开启这个选项,前提是这个中间服务器值得你信任。

5. 省略主机名

输入服务器的完整主机名来建立一个新的SSH连接实在是太乏味无聊了,尤其是当你有一组拥有相同域名但是子域名不同的服务器需要管理时,比如下面这样:

复制代码代码如下:* www1.example.com* www2.example.com* mail.example.com* intranet.internal.example.com* backup.internal.example.com* dev.internal.example.com

或许你的网络已经配置了可以直接使用短域名,比如intranet,但是如果你的网络不支持,实际上你可以自己搞定这个问题,而不用求助网络管理员。

解决办法根据你用的操作系统而略有差异,下面是我的Ubuntu系统的配置:

复制代码代码如下:prepend domain-search "internal.example.com", "example.com";

然后你需要重启网络:复制代码代码如下:$ sudo restart network-manager

不同的系统,这两条命令可能会略有差异。

6. 主机别名

你也可以在你的SSH配置中直接定义主机别名,就像下面这样:

复制代码代码如下:Host dev HostName dev.internal.example.com

你还可以使用通配符来进行分组:

复制代码代码如下:Host dev intranet backup HostName %h.internal.example.com</p><p>Host www* mail HostName %h.example.com

在Putty中你可以为每个主机名保存单独的session,然后双击建立连接(但是它可能没办法支持通配符)。

7. 省去用户名

如果你在远程服务器上的用户名和你本地的用户名不同,你同样可以在SSH配置中进行设置:

复制代码代码如下:Host www* mail &nbsp; HostName %h.example.com User simon

现在就算我的本地用户名是 smylers,我仍然可以这样连接我的服务器:

复制代码代码如下:$ ssh www2

SSH会使用simon账户连接你的服务器,同样,Putty可以保存这个信息在你的session中。

8. 在服务器间跳转

有些时候,你可能没法直接连接到某台服务器,而需要使用一台中间服务器进行中转,这个过程也可以自动化。首先确保你已经为服务器配置了公钥访问,并开启了agent forwarding,现在你就可以通过2条命令来连接目标服务器,不会有任何提示输入:

高效使用SSH的技巧总结(如何使用ssh)

复制代码代码如下:$ ssh gatewaygateway $ ssh db

然后在你的本地SSH配置中,添加下面这条配置:

复制代码代码如下:Host db HostName db.internal.example.com ProxyCommand ssh gateway netcat -q %h %p

现在你就可以通过一条命令来直接连接目标服务器了:

复制代码代码如下:$ ssh db

这里你可能会需要等待长一点的时间,因为SSH需要进行两次认证,注意netcat也有可能被写成nc或者ncat或者前面还需要加上g,你需要检查你的中间服务器来确定实际的参数。

9.突破网络封锁

有些时候,你使用的网络可能只开放了端口,或者它们封锁了SSH端口(默认的端口),这种情况下,你可以通过配置SSH服务器在或者端口进行监听来突,破,封,锁,只需要编辑你的服务器的/etc/ssh/sshd_config文件:

复制代码代码如下:Port

然后重启SSH服务器:

复制代码代码如下:$ sudo reload ssh

当然这样做的前提是你的服务器没有使用HTTS服务,但是实际上你只需要设置一台服务器使用https端口就够了,你但你可以访问这台服务器,你就 可以使用我们前面提到的技术利用它作为跳板来访问其它服务器,但是记住,你需要提前配置好这台服务器(现在怎么样?),这样万一当你身处一个只能访问 Web的网络环境时,就可以省掉打电话让其他人帮你配置中间服务器的麻烦了。

. 穿越Web代理

有些时候,你所在的网络不止封锁SSH端口,它们有可能更进一步,只让你通过Web代理来访问网络,幸运的是我们有一个叫做Corkscrew的程序可以通过Web代理在发送SSH数据。Corkscrew的使用非常简单,一般我都是在需要时搜索,然后直接下载,跟随网站上的指示,然后就搞定了,一般你需要这样一条配置:

复制代码代码如下:ProxyCommand corkscrew proxy.example.org %h %p

. 远程GUI

有时候通过本地的GUI程序来访问远程服务器的文件会非常有用,比如,编辑一副图片,或者查看一个PDF文件,或者只是简单的通过一个非命令行的编 辑器来修改代码,我发现GVim要比终端里的Vim更有用,因为我可以通过gvimopens打开一个新窗口来编辑文件,而用当前的SSH窗口继续执行其 它操作,不要要这样做,你需要先在你的SSH配置中开启一个叫做X forwarding的选项:

复制代码代码如下:ForwardX yes

这个选项需要服务器配置才能起作用,服务器也需要开启X forwarding,你可以在服务器的/etc/ssh/sshd_config中添加下面这个命令:

复制代码代码如下:XForwarding yes

同时你还需要确保安装了xauth,编辑器,图片查看器以及其它的你需要运行的图形化程序,这种方式只有在支持本地X服务器的操作提供才可以工 作,mac和Windows上都有免费的X Server,你可能需要花些时间配置它们,相比之下,切换到Linux相对会更容易一下。

.本地操作远程文件

另一种让远程GUI程序显示在本地的替代方案就是让本地的GUI程序可以直接操作远程文件,你可以通过SSHFS来实现,只需要创建一个空目录,然后使用SSHFS将一个远程目录mount到这个目录就可以了:

复制代码代码如下:$ mkdir gallery_src$ sshfs dev:projects/gallery/src gallery_src$ cd gallery_src$ ls

现在你就可以使用任何你喜欢的本地程序来便捷这个目录中的文件了,它们看起来是在你的本地,但其实时远程服务器上的文件,你可以使用fusermount命令来unmount这些文件,不要担心记不住,它们就在sshfs手册的顶上:

复制代码代码如下:$ cd ..$ fusermount -u gallery_src

SSHFS可以在Linux和OSX上工作,Windows用户我目前还没找到什么好办法。

. 通过Vim访问远程文件

Vim有一个内置的功能可以直接编辑远程文件,需要借助SCP URL:

复制代码代码如下:$ gvim netrw-problems

. 使用本地App连接远程服务器

有时可能有些服务,比如数据库或是Web服务器,它们运行在远程服务器上,但是如果有用方式可以直接从本地程序连接它们,那会非常有用,要做到这一 点,你需要用到端口转发(port forwarding),举个例子,如果你的服务器运行Postgres(并且只允许本地访问),那么你就可以在你的SSH配置中加入:

复制代码代码如下:Host db LocalForward localhost:

现在当你连接你的SSH服务器时,它会在你本地电脑打开一个端口(我随便挑的),并将所有发送到这个端口的数据转发到服务器的端口 (Postgres的默认端口),然后,只要你和服务器建立了连接,你就可以通过端口来访问服务器的Postgres了。

复制代码代码如下:$ ssh db

现在打开另外一个窗口,你就可以通过下面这条命令在本地连接你的Postgres数据库了:

复制代码代码如下:$ psql -h localhost -p orders

如果你想要使用服务器不支持的图形化Postgres客户端时,这条命令会显得尤其有用:

复制代码代码如下:$ pgadmin3 &

或者你有一个后台的Web服务器,你不希望直接通过Internet访问它,你也可以通过端口转发来访问它:

复制代码代码如下:Host api LocalForward localhost:

现在连接到服务器:

复制代码代码如下:$ ssh api

然后将浏览器指向你选择的端口号:

复制代码代码如下:$ firefox 减少延迟

如果每次连接服务器都意味着你需要等待几十秒而无所事事,那么你或许应该试试在你的SSH配置中加入下面这条:

复制代码代码如下:GSSAPIAuthentication no

如果这条命令有效的话,你应该通知你的系统管理员让他在服务器上禁用这个选项,这样其他人就不用再分别添加这条配置到它们的本地配置了。

. 加速连接

如果你确保你和某个服务器之间的连接是安全的(比如通过公司内网连接),那么你就可以通过选择arcfourencryption算法来让数据传输更快一些:

复制代码代码如下:Host dev Ciphers arcfour

注意这个加速是以牺牲数据的“加密"性为代价的,所以如果你连接的是位于网上的服务器,千万不要打开这个选项,并且确保你是通过VPN建立的连接。

开始行动吧!

Linux系统的服务器上出现故障时常用的分析命令总结 PS:整理一些LinuxWeb服务器网站故障分析常用的命令,内容均来源于网络。如果你是老手,什么好的命令集或者必杀技欢迎留言,丰富此文!系统连接状

Linux系统下NFS服务器常见的故障解决方法 NFS,全名叫NetworkFileSystem,中文叫网络文件系统,是Linux、UNIX系统的分布式文件系统的一个组成部分,可实现在不同网络上共享远程文件系统。NFS由Sun公

Linux系统的服务器上Samba服务器端的配置教程 Samba服务器配置部分第一步:进入/etc/samba目录,备份下smb.conf,然后删除这个文件,自己重新建立一个,输入如下内容复制代码代码如下:[global]workgroup=WO

标签: 如何使用ssh

本文链接地址:https://www.jiuchutong.com/biancheng/364767.html 转载请保留说明!

上一篇:详解Linux系统中hdparm硬盘检测工具的使用(linux中的)

下一篇:Linux系统的服务器上出现故障时常用的分析命令总结(linux系统的服务器有哪些)

  • 房地产业预售房的预收款退回的涉税处理?
  • 契税完税凭证是不是契税发票
  • 集团内部两个公司业务可以互相外包吗
  • 会计凭证销毁方法
  • 投资性房地产发生减值迹象均要计提减值准备
  • 营业总收入包括营业外收入吗
  • 应收暂估账务处理
  • 其他应付款长期挂账违反什么规定
  • 纳税人少缴税款,税务机关发现之日怎么算
  • 企业所得税可以抵扣吗
  • 怎么确定印花税申报成功
  • 一次性发放年终奖怎么税务筹划
  • 税金及附加怎么计提
  • 开票商品名称是什么意思
  • 装修公司开发票需要客户承担税点吗?
  • 民办非营利组织幼儿园清算时固定资产如何处理
  • 税务局锁了开票系统票已领出还可以开出来吗
  • 生产企业研发用原料抵进项可以吗?
  • 全年一次性奖金税收优惠政策2024
  • 个税申报方式可以修改去年的吗
  • 待认证发票后面需要做附件吗
  • 广告公司认定一般多少钱
  • 非公司员工可以交社保吗
  • 职工福利进项税可以抵扣吗
  • 餐饮行业固定资产界定
  • 抄报不了是怎么回事?
  • 固定资产平均年限法公式
  • 个体户怎么核定开多少票
  • mac outlook怎么设置邮箱签名
  • 土地合并需要什么资料
  • 如何处理库存差异问题
  • windows10更新会丢失数据吗
  • php注释的主要作用是什么?
  • 基建借款属于什么科目
  • 融资租赁会计处理小企业会计准则
  • 资产类备抵科目借方是加还是减
  • 金税盘锁住了怎么办
  • vue2转vue3工具
  • 当月认证的发票可以进行进项税额转出嘛
  • termux 安装
  • 正在求偶的凤头卡拉鹰,美国德克萨斯州 (© Alan Murphy/Minden Pictures)
  • php实现上传文件
  • 社保和公积金个人缴纳在哪里查看
  • vscode写前端代码,如何运行
  • 新星计划2021
  • css中的hover属性
  • torchaudio教程
  • 企业如何利用期货对冲风险怎么操作
  • 残疾人个人所得税减免怎么填写申报
  • 100%控股权什么意思
  • 质保金挂账是否需要发票
  • 余额百分比法计提坏账准备
  • 资金结存属于资产科目吗
  • 土地增值税间接转让怎么算
  • 哪些进项税额不能抵扣
  • 商业保理怎么账务处理?
  • 办公室租赁费摊销分录
  • 政府发的奖金需要交个税吗
  • 多提税金的具体分录
  • 哪些业务可以进入共享服务中心
  • 以前年度的费用忘记入账怎么办
  • 个人所得税专项扣除需要交钱吗
  • 费用预算表怎么做
  • 服务企业会计建账流程
  • win8系统笔记本怎么恢复出厂设置
  • winxp启动
  • secbizsrv.exe是什么程序
  • win10edge浏览器如何切换到ie
  • win7任务栏颜色怎么改成蓝色
  • linux 测试工具
  • nginx sbin目录
  • win8系统怎么设置共享局域网
  • win10查看电脑配置显卡
  • javascript语言介绍
  • 超酷风格
  • Linux 中的time函数
  • NGUI之UITexture
  • 如何使用nginx
  • 山东省税务局网上办税服务厅
  • 税控盘如何分配发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设