登陸 登陸伺服器 ssh user@hostname user: 用戶名 hostname :IP地址或功能變數名稱 第一次登陸會提示 The authenticity of host '123.57.47.211 (123.57.47.211)' can't be established. ECDSA k ...
登陸
-
登陸伺服器
-
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
中。 -
退出登陸:CTRL + D,或者手動輸入 exit。
配置文件
-
為方便登陸伺服器,給伺服器取別名。
-
創建文件夾
:~$ mkdir .ssh
-
創建文件
vim config
-
輸入
-
Host myserver1 HostName IP地址或功能變數名稱 User 用戶名 Host myserver2 HostName IP地址或功能變數名稱 User 用戶名
-
-
則可使用別名myserver1, myserver2。
免密登錄
- 輸入命令
ssh-keygen
,回車跳過詢問。 - 這樣, ~/.ssh 中會有文件
- id_rsa : 私鑰
- id_rsa.pub : 公鑰
- 如果想要免密登錄某個伺服器,就要將公鑰傳給它。
- 將公鑰中的文段複製,進入伺服器中。
- 粘貼到
~/.ssh/authorized_keys
。(若沒有,則創建)
- 也可以這條命令一鍵添加:
ssh-copy-id myserver
執行命令
-
命令格式
ssh user@hostname command
。 -
例如:
-
ssh user@hostname ls -a
,將伺服器家目錄下所有文件夾列印出。 -
a=1 ssh myserver "echo $a" ssh myserver 'echo $a'
-
雙引號是在本地伺服器進行轉義,所以傳過去的命令不是
echo $a
,而是echo 1
;單引號傳過去的是echo $a
。
-
SCP
- 功能:本地與伺服器之間傳文件,伺服器與伺服器之間傳送需要許可權完整,可以讓本地終端成為媒介。
- 將source路徑下的文件複製到destination中
scp source destination
- 複製多個文件
scp source1 source2 destination
- 複製文件夾
- 將本地家目錄中的tmp文件夾複製到myserver伺服器中的
~/homework/
目錄下。 scp -r ~/tmp myserver:homework/
- 將本地家目錄中的tmp文件夾複製到myserver伺服器中的
- 指定埠號
scp -P 22 source1 source2 destination
- 傳輸作業
- 在作業文件夾的目錄下,如
~/CSAPP/homework1
- 命令
scp -P 22 * user@hostname:~/homework1
。
- 在作業文件夾的目錄下,如
本文來自博客園,作者:江水為竭,轉載請註明原文鏈接:https://www.cnblogs.com/Az1r/p/17021056.html