前言
相信大家在工作中经常会遇到这样的需求:代码写完提交了,需要链接一下内网服务器,打一个新包跑起来给大家用;内网测试服报错了,需要去查看一下程序的错误日志,有时候log很长还需要拉到本机才方便查看,等等这一类的需求。在windows下开发你可以直接用xshell或者putty一类的工具来管理,而在linux下开发是不是就没辙了呢?
显然不是,linux强大到让你不敢相信,下面我们就来操作一下。
临时用法
如果只是临时链接一下远程服务器,那这个方法比较适用,当然,这里默认你已经在本机安装好了sshd,并已经启用了sshd服务:
systemctl status sshd.service
查看状态是active就是运行中。
链接远程服务器:
ssh -p 22 root@192.168.51.231
提示你输入远程服务器的密码,回车你就能链接上了,操作完成之后 exit
即可退出链接。
长期使用
当你有很多台服务器,尤其是大一点的公司,涉及的业务较复杂,需要管理的服务器自然会比较多,这时候我们没有工具的支持,要还是使用ssh -p xx user@ip
来玩的话,迟早你要把自己玩死,不然就是把公司玩死~
所以应该探索一种高效并且安全可行的方案,操作如下:
-
配置公钥
ssh-keygen
使用这个命令生成密钥,这个很简单,和github或者gitee配置仓库密钥是一样的操作,原理也是一样的。
-
上传公钥到目标服务器
ssh-copy-id -p port user@remote_ip
port填22就好了,不填默认也是22,然后填写服务器密码即可,说白了就是让目标服务器认证一下你,看看是不是有链接权限,如果有了权限,服务器会记录你的公钥,下次就可以拿公钥来链接了。
-
配置管理项
这个时候,你可以试试
ssh root@ip
你会发现现在不用输入密码就能登录了,就说明你的认证是被记录了的,但是每次都需要输入ip还是很麻烦啊,我们能不能用一个别名来配置一下呢?实现类似xshell的会话管理,答案当然是可以的了。首先我们进入
~/.ssh
目录,这是sshd的配置目录。vim config
如果有该文件,则在末尾追加,没有则新建:
Host server231 #别名 HostName 192.168.51.231 #ip User root Port 22
如上配置一下保存,然后
ssh server231
就能无障碍直达231服务器了,是不是很方便。
结语
经过以上的一些小配置,基本上可以实现xshell的主要功能,操作起来还是比较方便快捷,并且是比较安全的,也不用再纠结选择那个终端模拟工具了~
网友评论