参考: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 用户名
之后再使用服务器时,可以直接使用别名myserver1
、myserver2
有端口的话就是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
等参数尽量加在source
和destination
之前。
使用scp
配置其他服务器的vim
和tmux
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