4.SSH
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文件中。
然后输入密码即可登录到远程服务器中。
默认登录端口号为22。如果想登录某一特定端口:
ssh user@hostname -p 22
配置文件
创建文件~/.ssh/config
然后在文件中输入:
Host myserver1
HostName IP地址或域名
User 用户名
Host myserver2
HostName IP地址或域名
User 用户名
之后再使用服务器时,可以直接使用别名myserver1、myserver2
密钥登录
创建密钥:
ssh-keygen
然后一直回车即可
执行结束后,~/.ssh/目录下会多两个文件:
ㅤㅤ●ㅤid_rsa:私钥
ㅤㅤ●ㅤid_rsa.pub:公钥
ㅤㅤ之后想免密码登录哪个服务器,就将公钥传给哪个服务器即可。
ㅤㅤ例如,想免密登录myserver服务器。则将公钥中的内容,复制到myserver中的~/.ssh/authorized_keys文件里即可。
ㅤㅤ也可以使用如下命令一键添加公钥:
ssh-copy-id myserver
执行命令
命令格式:
ssh user@hostname command
例如:
ssh user@hostname ls -a
或者
#单引号中的$i可以求值
ssh myserver 'for ((i = 0; i < 10; i ++ )) do echo $i; done'
或者
#双引号中的$i不可以求值
ssh myserver "for ((i = 0; i < 10; i ++ )) do echo $i; done"ㅤㅤ
SCP传文件
基本用法
命令格式:
scp source destination
将source路径下的文件复制到destination中
一次复制多个文件:
scp source1 source2 destination
复制文件夹:
将本地家目录中的tmp文件夹复制到myserver服务器中的/home/acs/目录下。
scp -r ~/tmp myserver:/home/acs/
将本地家目录中的tmp文件夹复制到myserver服务器中的~/homework/目录下。
scp -r ~/tmp myserver:homework/
将myserver服务器中的~/homework/文件夹复制到本地的当前路径下。
scp -r myserver:homework .
指定服务器的端口号:
scp -P 22 source1 source2 destination
注意: scp的-r -P等参数尽量加在source和destination之前。
使用scp配置其他服务器的vim和tmux
scp ~/.vimrc ~/.tmux.conf myserver:
习题
homework_0
进入 homework_0 文件夹,要求:
ㅤㅤ[1] 该文件夹内容为空
ㅤㅤ[2] 配置服务器账号的密钥登陆方式。服务器信息可以通过如下命令获得:
ㅤㅤ homework 4 getinfo
ㅤㅤ将服务器账号的名称(Host)配置成:myserver
配置服务器别名
在~/.ssh目录下创建文件:config
cd ~/.ssh
vim config
内容:
Host myserver
HostName 123.57.47.211
User acs_2102
配置密钥登录
ssh-keygen
ssh-copy-id myserver
homework_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 中。
# myserver
ssh myserver
[1] mkdir homework/lesson_4/homework_1 -p # -p 不存在则创建
# acs
cd homework/lesson_4/homework_1
[2] scp main.cpp myserver:homework/lesson_4/homework_1
[3] mkdir dir
[4] scp myserver:/etc/lsb-release dir
homework_2
进入 homework_2 文件夹,下列描述中的 本地 均表示当前文件夹,要求:
ㅤㅤ[1] 在 myserver 服务器上创建并清空文件夹:~/homework/lesson_4/homework_2/
ㅤㅤ[2] 将本地的 dir 文件夹上传到 myserver 中的 ~/homework/lesson_4/homework_2/ 目录中。
# myserver
[1] mkdir homework/lesson_4/homework_2 -p
# acs
cd homework_2
[2] scp -r dir myserver:homework/lesson_4/homework_2
homework_3
进入 homework_3 文件夹,下列描述中的 本地 均表示当前文件夹,要求:
ㅤㅤ[1] 在本地创建文件夹 dir。
ㅤㅤ[2] 将 myserver 中的 /var/lib/locales/supported.d 文件夹下载到本地 dir 文件夹中。
cd homework_3
[1] mkdir dir
[2] scp -r myserver:/var/lib/locales/supported.d dir
homework_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] 注意:传入的文件参数可能包含空格。两个脚本均不需要判断传入参数的合法性。
# myserver
[1] mkdir homework/lesson_4/homework_4
# acs
[2] vim remote_mkdir.sh vim remote_rmdir.sh
[3] chmod +x remote_mkdir.sh chmod +x remote_rmdir.sh
[4] # remote_mkdir.sh
#! /bin/bash
ssh myserver mkdir homework/lesson_4/homework_4/\"$1\"
[5] # remote_rmdir.sh
#! /bin/bash
ssh myserver rm homework/lesson_4/homework_4/\"$1\" -r