---------------------------

2017-01-16 初版

2017-01-17 增加ssh登录端口修改

--------------------------

一、使用ssh

ssh命令用于远程登录Linux主机。

window下可以用putty来ssh登录,mac下直接使用terminal即可。

1.语法

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

更详细的可以用man ssh查看。

使用账号登录指定ip的服务器:

ssh 用户名@ip地址

如果服务器使用的不是标准端口,比如1024,则是:

ssh 用户名@ip地址 -p 

Mac下还有窗口打开方式:
打开terminal,菜单栏选shell - 新建远程连接

在弹出窗口内选择ssh(自动),输入服务器ip地址和用户名

完成后,在ssh菜单上选择 导出设置,在你的桌面就会看到一个刚命名的test.terminal

2. 实例

公司的服务器地址是192.168.0.11,用户名和密码是jenkins,那么登录的方式就是

ssh jenkins@192.168.0.11

3. ssh登录端口修改

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

·编辑配置文件:

vim /etc/ssh/sshd_config

·找到#Port 22,去掉注释,修改成一个五位的端口,比如:

Port 

·找到#PermitRootLogin yes,去掉注释,修改为:

PermitRootLogin no

·重启sshd服务:

service sshd restart

二、使用SCP

windows下我习惯使用winscp,mac下没有winscp,索性使用自带的scp命令。

语法

dzblogdeMacBook-Pro:TestFolder dzblog$ scp --help
scp: illegal option -- -
usage: scp [-12346BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program]
[[user@]host1:]file1 ... [[user@]host2:]file2

参数说明:

-1    强制scp命令使用协议ssh1 
-2    强制scp命令使用协议ssh2 
-4    强制scp命令只使用IPv4寻址 
-6    强制scp命令只使用IPv6寻址 
-B    使用批处理模式(传输过程中不询问传输口令或短语) 
-C    允许压缩。(将-C标志传递给ssh,从而打开压缩功能) 
-p    保留原文件的修改时间,访问时间和访问权限
-q    不显示传输进度条
-r    递归复制整个目录
-v     详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,

-c cipher      以cipher将数据传输进行加密,这个选项将直接传递给ssh。
-F ssh_config   指定一个替代的ssh配置文件,此参数直接传递给ssh。
-i identity_file  从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
-l limit       限定用户所能使用的带宽,以Kbit/s为单位。
-o ssh_option  如果习惯于使用ssh_config(5)中的参数传递方式,
-P port      注意是大写的P, port是指定数据传输用到的端口号
-S program   指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。

实例

1. 复制目录到本地
将192.168.0.11linux系统下的tools文件夹,复制到/Users/dongzheng/GitRepository/temp/

scp -r jenkins@192.168.0.11:/home/jenkins/tools /Users/dzblog/GitRepository/temp/

2. 复制文件到本地

将192.168.0.11linux系统/home/jenkins/tools/test.file,复制到当前目录

scp jenkins@192.168.0.11:/home/jenkins/tools/test.file ./

3. 上传本地目录到服务器

将本地目录testFolder,上传到,地址是192.168.0.11的linux系统下的/home/jenkins/tools/文件夹下

scp -r ./testFolder jenkins@192.168.0.11:/home/jenkins/tools/

也可以反过来:

scp -r jenkins@192.168.0.16:/Users/jenkins/jenkins-android/workspace/testFolder ./

4. 上传本地文件到服务器

将在testFolder下的test.txt,上传到,地址是192.168.0.11的linux系统下的/home/jenkins/tools/文件夹下

scp ./testFolder/test.txt jenkins@192.168.0.11:/home/jenkins/tools/

参考

http://www.cnblogs.com/littleBit/p/5362806.html
http://ypf3027.iteye.com/blog/1405507
http://blog.163.com/l1_jun/blog/static/143863882014325115230504/
https://www.zhihu.com/question/50641425

[Linux][Mac]如何使用SSH登陆远程Linux服务器&使用SCP下载远程终端文件的更多相关文章

  1. Mac下用SSH连接远程Linux或Mac服务器

    1.打开Mac终端 2.切换到root登录 输入命令:sudo -i,然后输入本机密码 p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px &qu ...

  2. Mac OS X下配置远程Linux 服务器SSH密钥认证自动登录

    1. 在本地机器创建公钥 打开万能的终端,执行如下命令,无视一切输出,一路欢快地回车即可. ssh-keygen -t rsa -C 'your email@domain.com' -t 指定密钥类型 ...

  3. ssky-keygen + ssh-copy-id 无密码登陆远程LINUX主机

    ssky-keygen + ssh-copy-id 无密码登陆远程LINUX主机 使用下例中ssky-keygen和ssh-copy-id,仅需通过3个步骤的简单设置而无需输入密码就能登录远程Linu ...

  4. ssky-keygen + ssh-copy-id 无密码登陆远程LINUX主机【OK】

    ssky-keygen + ssh-copy-id 无密码登陆远程LINUX主机[OK]     使用下例中ssky-keygen和ssh-copy-id,仅需通过3个步骤的简单设置而无需输入密码就能 ...

  5. Linux下不借助工具实现远程linux服务器上传下载文件

    # Linux下不借助工具实现远程linux服务器上传下载文件 ## 简介 - Linux下自带ssh工具,可以实现远程Linux服务器的功能- Linux下自带scp工具,可以实现文件传输功能 ## ...

  6. Mac使用ssh登录远程linux系统查看jetty日志及同时使用github工具

    转载请注明出处:http://www.houxiurong.com/?post=27 Mac默认是安装了ssh工具软件的. 先用mac的 终端工具生成 id_rsa 和id_rsa.pub 秘钥,生成 ...

  7. linux_ssky-keygen + ssh-copy-id 无密码登陆远程LINUX主机

    使用下例中ssky-keygen和ssh-copy-id,仅需通过3个步骤的简单设置而无需输入密码就能登录远程Linux主机. ssh-keygen 创建公钥和密钥. ssh-copy-id 把本地主 ...

  8. 教你如何配置linux用户实现禁止ssh登陆机器但可用sftp登录!

    构想和目标最近有个这样的诉求:基于对线上服务器的保密和安全,不希望开发人员直接登录线上服务器,因为登录服务器的权限太多难以管控,如直接修改代码.系统配置,并且也直接连上mysql.因此希望能限制开发人 ...

  9. linux 禁止指定账号ssh登陆

    1 2 3 4 vim /etc/pam.d/sshd   #在第一行添加以下代码 auth       required     pam_listfile.so item=user sense=de ...

随机推荐

  1. Open quote is expected for attribute "{1}" associated with an element type "column".

    这个的错误的意思很简单:就是自己的配置文件是否缺少""号

  2. tensorflow学习之(八)使用dropout解决overfitting(过拟合)问题

    #使用dropout解决overfitting(过拟合)问题 #如果有dropout,在feed_dict的参数中一定要加入dropout的值 import tensorflow as tf from ...

  3. Java平台

    Java的平台无关性 不同的网络环境,操作系统 支持嵌入式设备 减少开发部署时间 Java自身的平台和语言 编译成class文件 可在Java虚拟机中运行,与外部环境无关(对虚拟机的依赖) 通过外部A ...

  4. squid 正向代理 简单配置

    linux 正向同步 项目上web服务器不给访问外网,迁移服务器环境又太麻烦,决定给web服务器做正向代理,刚开始使用nginx,但是https代理一直不成功,后面大佬建议使用squid来达到相同目的 ...

  5. shell脚本新建文件夹或用到目录时多出M或者?之类的

    新建问价加多出? 删除多显示M   建立软连接多\n等 可能是文件兼容问题, 1.首先用vi命令打开文件[root@localhost test]# vi test.sh   2.在vi命令模式中使用 ...

  6. CSS+DIV布局中absolute和relative区别

    原文:http://developer.51cto.com/art/201009/225201.htm 这里向大家简单介绍一下CSS+DIV布局中absolute和relative属性的用法和区别,定 ...

  7. java与eclipse的工作小结

    1.Eclipse 的启动画面 A.加启动参数.如: eclipse.exe -showsplash C:/splash.bmp 更多可参考:http://www.cnblogs.com/sharew ...

  8. 协程 及 libco 介绍

    libco 是腾讯开源的一个协程库,主要应用于微信后台RPC框架,下面我们从为什么使用协程.如何实现协程.libco使用等方面了解协程和libco. why协程 为什么使用协程,我们先从server框 ...

  9. MySQL--更新自增列的潜在风险

    ##=====================================================================##测试环境:MySQL版本:MySQL 5.7.19复制 ...

  10. Windows Server2012 搭建域错误“本地Administraor账户不需要密码”

    标签:MSSQL/SQLServer/域控制器提升的先决条件验证失败/密码不符合要求 概述 在安装WindowsServer2012域控出现administrator账户密码不符合要求的错误,但是实际 ...