SSH的安装及配置

  SSH分客户端openssh-client和openssh-server

  如果你只是想登陆别的机器的SSH只需要安装openssh-client(ubuntu有默认安装,如果没有则sudoapt-get install openssh-client),如果要使本机开放SSH服务就需要安装openssh-server。

一、安装客户端

Ubuntu缺省已经安装了ssh client。

sudo apt-get install ssh  或者 sudo apt-get installopenssh-client
ssh-keygen 

(按回车设置默认值)

按缺省生成id_rsa和id_rsa.pub文件,分别是私钥和公钥。

说明:如果sudo apt-get insall ssh出错,无法安装可使用sudo apt-get install openssh-client进行安装

假定服务器ip为192.168.1.1,ssh服务的端口号为22,服务器上有个用户为root;
用ssh登录服务器的命令为:
>ssh –p 22 root@192.168.1.1
>输入root用户的密码

二、安装服务端

Ubuntu缺省没有安装SSH Server,使用以下命令安装:

sudo apt-get install openssh-server

然后确认sshserver是否启动了:(或用“netstat -tlp”命令)

ps -e|grep ssh

如果只有ssh-agent那ssh-server还没有启动,需要/etc/init.d/ssh start,如果看到sshd那说明ssh-server已经启动了。

如果没有则可以这样启动:

sudo/etc/init.d/ssh start

事实上如果没什么特别需求,到这里 OpenSSH Server 就算安装好了。但是进一步设置一下,可以让 OpenSSH 登录时间更短,并且更加安全。这一切都是通过修改 openssh 的配置文件 sshd_config 实现的。

三、SSH配置

ssh-server配置文件位于/etc/ssh/sshd_config,在这里可以定义SSH的服务端口,默认端口是22,你可以自己定义成其他端口号,如222。然后重启SSH服务:

sudo /etc/init.d/ssh resart  

通过修改配置文件/etc/ssh/sshd_config,可以改ssh登录端口和禁止root登录。改端口可以防止被端口扫描。

sudo cp/etc/ssh/sshd_config /etc/ssh/sshd_config.original
sudochmod a-w /etc/ssh/sshd_config.original  

编辑配置文件:

Port 22
PermitRootLogin prohibit-password

修改:

Port 2233
PermitRootLogin no

配置完成后重起:

sudo/etc/init.d/ssh restart 

四、SSH服务命令

停止服务:sudo /etc/init.d/ssh stop

启动服务:sudo /etc/init.d/ssh start

重启服务:sudo /etc/init.d/sshresart

断开连接:exit

登录:sshroot@192.168.0.100

root为192.168.0.100机器上的用户,需要输入密码。

五、SSH登录命令

常用格式:ssh [-llogin_name] [-p port] [user@]hostname

更详细的可以用ssh -h查看。

举例

不指定用户:

ssh 192.168.0.1 

指定用户:

ssh -l root 192.168.0.1
ssh root@192.168.0.1  

如果修改过ssh登录端口的可以:

ssh -p 2233 192.168.0.111
ssh -l root -p 2233 216.230.230.105
ssh -p 2233 root@216.230.230.105  

六、提高登录速度

  在远程登录的时候可能会发现,在输入完用户名后需要等很长一段时间才会提示输入密码。其实这是由于 sshd 需要反查客户端的 dns 信息导致的。可以通过禁用这个特性来大幅提高登录的速度。首先,打开 sshd_config 文件:

sudo nano /etc/ssh/sshd_config  

找到 GSSAPI options 这一节,将下面两行注释掉:

# GSSAPI options
#GSSAPIAuthentication no
#GSSAPICleanupCredentials yes

然后重新启动 ssh 服务即可。

七、利用 PuTTy 通过证书认证登录服务器

  SSH 服务中,所有的内容都是加密传输的,安全性基本有保证。但是如果能使用证书认证的话,安全性将会更上一层楼,而且经过一定的设置,还能实现证书认证自动登录的效果。

  首先修改 sshd_config 文件,开启证书认证选项:

RSAAuthentication yes
PubkeyAuthentication yes
#AuthorizedKeysFile     %h/.ssh/authorized_keys

修改完成后重新启动 ssh 服务。

下一步我们需要为 SSH 用户建立私钥和公钥。首先要登录到需要建立密钥的账户下,这里注意退出 root 用户,需要的话用 su 命令切换到其它用户下。然后运行:

ssh-keygen  

这里,我们将生成的 key 存放在默认目录下即可。建立的过程中会提示输入 passphrase,这相当于给证书加个密码,也是提高安全性的措施,这样即使证书不小心被人拷走也不怕了。当然如果这个留空的话,后面即可实现 PuTTy 通过证书认证的自动登录。

  ssh-keygen 命令会生成两个密钥,首先我们需要将公钥改名留在服务器上:

cd ~/.ssh mv id_rsa.pub authorized_keys  

然后将私钥 id_rsa 从服务器上复制出来,并删除掉服务器上的 id_rsa 文件。

  服务器上的设置就做完了,下面的步骤需要在客户端电脑上来做。首先,我们需要将 id_rsa 文件转化为 PuTTy 支持的格式。这里我们需要利用 PuTTyGEN 这个工具:

  点击 PuTTyGen 界面中的 Load 按钮,选择 id_rsa 文件,输入 passphrase(如果有的话),然后再点击 Save PrivateKey 按钮,这样 PuTTy 接受的私钥就做好了。

  打开 PuTTy,在 Session 中输入服务器的 IP 地址,在 Connection->SSH->Auth 下点击 Browse 按钮,选择刚才生成好的私钥。然后回到 Connection 选项,在 Auto-login username 中输入证书所属的用户名。回到 Session 选项卡,输入个名字点 Save 保存下这个 Session。点击底部的 Open 应该就可以通过证书认证登录到服务器了。如果有 passphrase 的话,登录过程中会要求输入 passphrase,否则将会直接登录到服务器上,非常的方便。

啦啦啦

Ubuntu 16.04服务器 软件的安装及配置相关推荐

  1. ubuntu安装pr_在Ubuntu 16.04服务器上安装Zabbix 3.2

    监控服务器 - 什么是Zabbix Zabbix是企业级开源分布式监控服务器解决方案. 该软件监控网络的不同参数和服务器的完整性,还允许为任何事件配置基于电子邮件的警报. Zabbix根据存储在数据库 ...

  2. Ubuntu 16.04 一系列软件安装命令,包括QQ、搜狗

    2019独角兽企业重金招聘Python工程师标准>>> Ubuntu 16.04 一系列软件安装命令,包括QQ.搜狗.Chrome.vlc.网易云音乐安装方法 2016年07月20日 ...

  3. Ubuntu 16.04更新软件提示需要安装不能信任的软件包 http://archive.ubuntukylin.com:10006/ubuntukylin xenial InRelease

    刚才用 Ubuntu 16.04更新软件时提示"需要安装不能信任的软件包","这个动作需要从没有授权的软件源来安装软件包", 赋予权限执行仍然无法安装,上网查了 ...

  4. linux server下载64位,ubuntu 16.04服务器版

    ubuntu 16.04服务器版是一个最常用的linux操作系统,新版本变化很多,基于Linux 4.4版,这里为大家提供ubuntu server 16.04 64位+32位的迅雷下载地址. 系统特 ...

  5. 本地Windows远程桌面连接阿里云Ubuntu 16.04服务器:

    本地Windows远程桌面连接阿里云Ubuntu 16.04服务器: 1.目的:希望通过本地的Windows远程桌面连接到阿里云的Ubuntu服务器,通过远程桌面图形界面的方式操作服务器. 2.条件: ...

  6. 在Ubuntu 16.04.6 LTS上安装python3.7和pip3后出现Command '('lsb_release', '-a')' 出错问题的解决方法

    在Ubuntu 16.04.6 LTS上安装python3.7和pip3后出现Command '('lsb_release', '-a')' returned non-zero exit status ...

  7. Ubuntu 16.04源码编译安装Apache 2.4.25教程

    这篇文章主要为大家详细介绍了Ubuntu 16.04源码编译安装Apache 2.4.25,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文为大家介绍了Ubuntu 16.04源码编译安装Apa ...

  8. w10安装ubuntu_Win10 + Ubuntu 16.04双系统完美安装教程【详细】

    务必记得备份自己的数据,数据无价!!! 电脑型号:Thinkpad E550 固态装了win10,机械硬盘打算装Ubuntu16.04 固态硬盘格式MBR,机械硬盘格式GPT 一.制作U启动盘 1.下 ...

  9. 在Ubuntu 16.04 LTS下编译安装OpenCV 4.1.1

    目录 一 安装前的准备 二 编译并安装OpenCV 4.1.1 注:原创不易,转载请务必注明原作者和出处,感谢支持! OpenCV目前(2019-8-1)的最新版本为4.1.1.本文将介绍如何在Ubu ...

  10. Ubuntu 16.04 系统 gflags glog 安装

    系统环境 Ubuntu 16.04 GCC 5.4 安装步骤 安装 GFlags 运行如下指令: git clone https://github.com/gflags/gflags.git cd g ...

最新文章

  1. centos共享linux文件夹权限,CENTOS7 搭建文件服务器:samba共享linux文件夹
  2. pil拷贝,剪切,缩放
  3. UA MATH571B 试验设计VI 随机效应与混合效应2
  4. tensorflow-计算图
  5. 中业科技机器人价格_2019年年中盘点:智能扫地机器人十大畅销品牌排名
  6. 【Android】Apk安装方式
  7. 基于云平台的家居综合监测管理系统的设计与实现
  8. html手机网站font-size:16em,px、em、rem
  9. php卡盟专用主机,php卡盟
  10. Python 3.10 中的 6 个新特性,你体验了吗?
  11. 从B树、B+树、B*树谈到R树
  12. MAC OS系统如何使用动态远程桌面
  13. 辅修计算机科学与技术有哪些课程,计算机科学与技术专业辅修课程表.doc
  14. hibernate两张表关联查询
  15. Android学习及如何利用android来赚钱
  16. android 用blend设计,Android OpenGLES2.0(十八)——轻松搞定Blend颜色混合
  17. C#文件操作——文件、数据流与注册表
  18. 原生app开发的优缺点
  19. 关于系统架构你不知道的那些事-架构设计流程:设计备选方案
  20. CommandLineRunner接口介绍

热门文章

  1. webService(一)开篇
  2. VB API 之 第七课 字体应用四
  3. 遍历Panel1中所有label控件的Text
  4. ADO.NET编程(3)在内存中对DataTable进行增/删/改操作
  5. POJ 3415 Common Substrings(后缀数组 + 单调栈)题解
  6. 《Java设计模式》之代理模式 -Java动态代理(InvocationHandler) -简单实现
  7. linux-阿里云仓库搭建-搭建本地仓库-yum
  8. Valid Palindrome LeetCode Java
  9. leetcode 221. Maximal Square 求一个数组中由1组成的最大的正方形面积 ---------- java...
  10. 跨域的小小总结:js跨域及跨域的几种解决方法