4 ssh
4.1 ssh 登录
4.1.1 基本用法
远程登录服务器:
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
文件中
然后输入密码即可登录到远程服务器中
logout
:退出当前服务器
默认登录端口号为22
,如果想登录某一特定端口:
ssh user@hostname -p 22
4.1.2 配置文件
创建文件~/.ssh/config
然后在文件中输入:
Host myserver1
HostName IP地址或域名
User 用户名
Host myserver2
HostName IP地址或域名
User 用户名
之后再使用服务器时,可以直接使用别名myserver1
、myserver2
4.1.3 密钥登录
创建密钥:
ssh-keygen
然后一直回车即可
执行结束后,~/.ssh/
目录下会多两个文件:
ㅤㅤ●ㅤid_rsa
:私钥
ㅤㅤ●ㅤid_rsa.pub
:公钥
ㅤㅤ之后想免密码登录哪个服务器,就将公钥传给哪个服务器即可。
ㅤㅤ例如,想免密登录myserver
服务器。则将公钥中的内容,复制到myserver
中的~/.ssh/authorized_keys
文件里即可。
ㅤㅤ也可以使用如下命令一键添加公钥:
ㅤㅤssh-copy-id myserver
4.1.4 执行命令
命令格式:
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"
4.2 scp 传文件
4.2.1 基本用法
命令格式:
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/
文件夹复制到本地的当前路径下。
指定服务器的端口号:
scp -P 22 source1 source2 destination
注意: scp
的-r -P
等参数尽量加在source
和destination
之前。
使用scp配置其他服务器的vim和tmux
scp ~/.vimrc ~/.tmux.conf myserver:
4.3 习题课
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
homework_4 里的【5】里面删除文件夹写错了,应该是ssh myserver rm homework/lesson_4/homework_4/"$1" -r
感谢指正~~~
$1是啥呢
请问为什么这个ssh myserver mkdir homework/lesson_4/homework_4/"1\”不能写成sshmyservermkdir /homework/lesson4/homework4/\”1"
可能路径和串中存在歧义 不能直接写
homework_1代码中的[2]最后应该是homework_1。
感谢指正~~~
写的太好了