Linux SSH远程登陆

参考:Acwing

SSH

参考ACWing官方讲义
链接:https://www.acwing.com/file_system/file/content/whole/index/content/2898263/
来源:AcWing

SSH 登录


基本用法

远程登录服务器:
ssh user@hostname

  • user: 用户名
  • hostname: IP地址或域名
    第一次登录时会提示:
The authenticity of host '123.57.47.211 (123.57.47.211)' can't be established.
ECDSA key fingerprint is SHA256:iy237yysfCe013/l+kpDGfEG9xxHxm0dnxnAbJTPpG8.
Are you sure you want to continue connecting (yes/no/[fingerprint])?

输入yes,然后回车即可。
这样会将该服务器的信息记录在~/.ssh/known_hosts文件中。

然后输入密码即可登录到远程服务器中
在终端输入exit或者CTRL+D可以退出

acs@236f0e9d715c:~$ ls -a
.              .homework                  .test.sh.swn
..             .ipython                   .test.sh.swo
.bash_history  .profile                   .tmux.conf
.bash_logout   .python_history            .vim
.bashrc        .ssh                       .viminfo
.cache         .sudo_as_admin_successful  .vimrc
.config        .test.sh.swm               homework
acs@236f0e9d715c:~$ cd .ssh
acs@236f0e9d715c:~/.ssh$ ls
known_hosts

服务器的信息记录在~/.ssh/known_hosts文件中
第二次再登录就不会提示这个服务器是陌生的服务器,可以直接输入密码登陆了

默认登录端口号为22,如果想登录某一特定端口(port):

ssh user@hostname -p 22

配置文件
每次登录都要输入一串命令,ip地址不好背,我们可以设置别名

创建文件 ~/.ssh/config。

然后在文件中输入:

Host myserver1
    Hostname IP地址或域名
    User 用户名

Host myserver2
    Hostname IP地址或域名
    User 用户名

之后再使用服务器时,可以直接使用别名myserver1myserver2
有端口的话就是port ,ACWING默认是22,有多个服务器则配置多个服务器的账号

ssh myserver1
再输入密码就可以直接登录了

密钥登录(免密码登陆)

在本地终端
创建密钥:

ssh-keygen

然后一直回车即可。

执行结束后,~/.ssh/目录下会多两个文件:

  • id_rsa:私钥
  • id_rsa.pub:公钥
    之后想免密码登录哪个服务器,就将公钥传给哪个服务器即可
##############################本地终端###############################
acs@236f0e9d715c:~$ cd .ssh
acs@236f0e9d715c:~/.ssh$ ls
config  id_rsa  id_rsa.pub  known_hosts
acs@236f0e9d715c:~/.ssh$ cat id_rsa.pub 
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCh/Zhbykq9Y6jknyoWIf23FcuX0902iWUKrAcrguv6+UyyutF3ZevcIa9p7wldzanmHeRRtZGSsd/fDG9fgqTgWMB0nBlz9axl3sSdECAcWZf/jRKNkq637yzw/4roV75b8oSdMbWQtZh7k+KYmrwf+ngZBkXRQz4T35UXad3ZHbZ/gL49DCNiqBhowLYuxw98HcyVx2Qw8VzoAOjdJeROuXnCUQE9d7uohP2oPGrJN4R6DhMG309mxbX9KeyCbkF0QAa7GmqDZhCXkLGYc/w8ViH4r5lgrpIWcK2/rTpV1zRZh7cnt3CmgB4PBLEF/ThY5a3sObE6XwDqmfJzHhOGM8QU5QJgM9RiPyOdWN4y0YbrdKJ0DshIz8trDJBj9H9hn5wUwMUZifwShtYUXkTK4e5tKPZ+iS6WS5q5kCOZAfzwiqY3NrkefjQDinEEnAsi0W75Mat+u8VSriLeSthd/OlI+eiPagIZkXYKaYjSPDrKnIUtCJJ9QtZGJwjJZx8= acs@236f0e9d715c
##############################服务器终端###############################
acs_1423@acs:~$ 
acs_1423@acs:~$ ls -a
.  ..  .bash_history  .bash_logout  .bashrc  .cache  .profile
acs_1423@acs:~$ mkdir .ssh     #没有的话及创建一个
acs_1423@acs:~$ cd .ssh
acs_1423@acs:~/.ssh$ ls
acs_1423@acs:~/.ssh$ ls -a
.  ..
acs_1423@acs:~/.ssh$ vim authorized_keys

例如,想免密登录myserver1服务器。则将公钥中的内容,复制到myserver1中的~/.ssh/authorized_keys文件里即可。

也可以使用如下命令一键添加公钥:(输入完命令后输入一次密码再SSH就免密登陆了)

ssh-copy-id myserver1

执行命令

命令格式:

ssh user@hostname command

例如:

ssh user@hostname ls -a

或者

#单引号中的$i可以求值,在服务器端执行的for循环
ssh myserver1 'for ((i = 0; i < 10; i ++ )) do echo $i; done'
acs@236f0e9d715c:~$ ssh myserver1 'for((i=0;i<10;i++)) do echo $i;done'
0
1
2
3
4
5
6
7
8
9
acs@236f0e9d715c:~$ 

或者

#双引号中的$i不可以求值
ssh myserver1 "for ((i = 0; i < 10; i ++ )) do echo $i; done"

SSH 传文件

基本用法

命令格式:

scp source destination

将·source·路径下的文件复制到·destination·中

一次复制多个文件:

scp source1 source2 destination

复制文件夹:

scp -r ~/tmp myserver:/home/acs/

将本地家目录中的tmp文件夹复制到myserver服务器中的/home/acs/目录下。

scp -r ~/tmp myserver:homework/

将本地家目录中的tmp文件夹复制到myserver服务器中的~/homework/目录下。

scp -r myserver:homework .

myserver服务器中的~/homework/文件夹复制到本地的当前路径下。

指定服务器的端口号:(ssh是p这里是P

scp -P 22 source1 source2 destination

注意: scp-r -P等参数尽量加在sourcedestination之前。

使用scp配置其他服务器的vimtmux
scp ~/.vimrc ~/.tmux.conf myserver:

作业

创建好作业后,先进入文件夹/home/acs/homework/lesson_4/,然后:

(0) 进入homework_0文件夹,要求:
    [1] 该文件夹内容为空
    [2] 配置服务器账号的密钥登陆方式。服务器信息可以通过如下命令获得:
        homework 4 getinfo
        将服务器账号的名称(Host)配置成:myserver
 acs@236f0e9d715c:~$ 
acs@236f0e9d715c:~$ cd .ssh
acs@236f0e9d715c:~/.ssh$ ls
config  id_rsa  id_rsa.pub  known_hosts
acs@236f0e9d715c:~/.ssh$ cat config 

Host myserver
    Hostname 123.57.47.211
    User acs_1423


acs@236f0e9d715c:~/.ssh$ ssh-copy-id myserver
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/home/acs/.ssh/id_rsa.pub"
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed

/usr/bin/ssh-copy-id: WARNING: All keys were skipped because they already exist on the remote system.
                (if you think this is a mistake, you may want to use -f option)

acs@236f0e9d715c:~/.ssh$ 
acs@236f0e9d715c:~/.ssh$ ssh myserver
Welcome to AC Server
 * Tutorial:        https://www.acwing.com/activity/content/57/
     __    __________      __ ______  ___ _______
    /  \  / ______/ /      \ \| ||  \ | |/  _____|
   / /\ \ | |     | |  /\  | || || \ \| || /   ___
  / /__\ \| |     | | /  \ | || || |\ \ || |   |_ |
 / ______ \ \_____\ \/ /\ \/ /| || | \  || \____| |
/_/      \_\_______\__/  \__/ |_||_|  \_|\________/


(1) 进入homework_1文件夹,下列描述中的“本地”均表示当前文件夹。要求:
    [1] 在myserver服务器上创建并清空文件夹:~/homework/lesson_4/homework_1/
    [2] 将本地的main.cpp文件上传到myserver中的~/homework/lesson_4/homework_1/目录中。
    [3] 在本地创建文件夹dir。
    [4] 将myserver中的/etc/lsb-release文件复制到dir中。

#######################################要求1、2############################################
acs@236f0e9d715c:~/.ssh$ cd ~/homework/lesson_4
acs@236f0e9d715c:~/homework/lesson_4$ ls
homework_0  homework_1  homework_2  homework_3  homework_4
acs@236f0e9d715c:~/homework/lesson_4$ cd homework_1
acs@236f0e9d715c:~/homework/lesson_4/homework_1$ ls
main.cpp
acs@236f0e9d715c:~/homework/lesson_4/homework_1$ ssh myserver                              
Welcome to AC Server
 * Tutorial:        https://www.acwing.com/activity/content/57/
     __    __________      __ ______  ___ _______
    /  \  / ______/ /      \ \| ||  \ | |/  _____|
   / /\ \ | |     | |  /\  | || || \ \| || /   ___
  / /__\ \| |     | | /  \ | || || |\ \ || |   |_ |
 / ______ \ \_____\ \/ /\ \/ /| || | \  || \____| |
/_/      \_\_______\__/  \__/ |_||_|  \_|\________/

acs_1423@acs:~$ mkdir -p ~/homework/lesson_4/homework_1/
acs_1423@acs:~$ ls
homework
acs_1423@acs:~$ logout
Connection to 123.57.47.211 closed.
acs@236f0e9d715c:~/homework/lesson_4/homework_1$ ls
main.cpp
acs@236f0e9d715c:~/homework/lesson_4/homework_1$ scp -r main.cpp myserver:homework/lesson_4/homework_1/
main.cpp                                                                                                                                   100%  132    32.1KB/s   00:00    
acs@236f0e9d715c:~/homework/lesson_4/homework_1$ 

#######################################要求3、4,tree可以查看文件结构############################################
acs@236f0e9d715c:~/homework/lesson_4/homework_0$ scp -r myserver:/etc/lsb-release ./dir/
acs@236f0e9d715c:~/homework/lesson_4/homework_0$ scp -r myserver:/etc/lsb-release ./dir/

(2) 进入homework_2文件夹,下列描述中的“本地”均表示当前文件夹,要求:
    [1] 在myserver服务器上创建并清空文件夹:~/homework/lesson_4/homework_2/
    [2] 将本地的dir文件夹上传到myserver中的~/homework/lesson_4/homework_2/目录中。
acs@236f0e9d715c:~/homework/lesson_4/homework_2$ ssh myserver
acs_1423@acs:~$ mkdir -p ~/homework/lesson_4/homework_2/
acs_1423@acs:~$ logout
Connection to 123.57.47.211 closed.
acs@236f0e9d715c:~/homework/lesson_4/homework_2$ ls
dir
acs@236f0e9d715c:~/homework/lesson_4/homework_2$ scp -r dir myserver:homework/lesson_4/homework_2/
c.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
b.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
a.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
c.txt                                                                                                                                      100%    7     1.4KB/s   00:00    
b.txt                                                                                                                                      100%    7     1.6KB/s   00:00    
a.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
c.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
b.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
a.txt                                                                                                                                      100%    7     1.5KB/s   00:00    
acs@236f0e9d715c:~/homework/lesson_4/homework_2$ 

(3) 进入homework_3文件夹,下列描述中的“本地”均表示当前文件夹,要求:
    [1] 在本地创建文件夹dir。
    [2] 将myserver中的/var/lib/locales/supported.d文件夹下载到本地dir文件夹中。
acs@236f0e9d715c:~/homework/lesson_4/homework_3$ mkdir dir
acs@236f0e9d715c:~/homework/lesson_4/homework_3$ ssh myserver
acs@236f0e9d715c:~/homework/lesson_4/homework_3$ scp -r myserver:/var/lib/locales/supported.d ./dir/
en                                                                                                                                         100%  294    63.1KB/s   00:00    
acs@236f0e9d715c:
(4) 进入homework_4文件夹,编写脚本remote_mkdir.sh和remote_rmdir.sh,要求:
    [1] 在myserver服务器上创建并清空文件夹:~/homework/lesson_4/homework_4/
    [2] 本地目录下仅包含remote_mkdir.sh和remote_rmdir.sh
    [3] remote_mkdir.sh和remote_rmdir.sh具有可执行权限
    [4] remote_mkdir.sh接收一个传入参数。格式为 ./remote_mkdir.sh directory_name
        该操作可以在myserver服务器上的~/homework/lesson_4/homework_4/目录下,创建一个名为directory_name的文件夹
    [5] remote_rmdir.sh接收一个传入传输。格式为 ./remote_rmdir.sh directory_name
        该操作可以将myserver服务器上的~/homework/lesson_4/homework_4/目录下的名为directory_name的文件夹删掉。
    [6] 注意:传入的文件参数可能包含空格。两个脚本均不需要判断传入参数的合法性。

acs_1423@iacs:~$ mkdir -p ~/homework/lesson_4/homework_4/
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ touch remote_mkdir.shacs@236f0e9d715c:~/homework/lesson_4/homework_4$ touch remote_rmdir.sh
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ ls
remote_mkdir.sh  remote_rmdir.sh
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ chmod +x remote_mkdir.sh remote_rmdir.sh 
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ ls
remote_mkdir.sh  remote_rmdir.sh

acs@236f0e9d715c:~/homework/lesson_4/homework_4$ cat remote_mkdir.sh 

#! /bin/bash
ssh myserver mkdir -p homework/lesson_4/homework_4/ \"$1\"   ###" "可以避免空格将一个字符串变成两个,从而创造出两个文件夹

acs@236f0e9d715c:~/homework/lesson_4/homework_4$ cat remote_rmdir.sh 

#! /bin/bash
ssh myserver rm -r homework/lesson_4/homework_4/\"$1\"    #在路径下删除路径下的文件用-r

acs@236f0e9d715c:~/homework/lesson_4/homework_4$ 


换行写命令的话需要用\转义,在行末写\ + 回车符即可。
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ rm aa/bb/a.txt -r
删除aa下bb下的a.txt
acs@236f0e9d715c:~/homework/lesson_4/homework_4$ rm aa -r
删除整个文件夹aa
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值