在云服务器终端执行cat ~/.ssh/authorized_keys时提示cat: /root/.ssh/authorized_keys: No such file or directory
时间: 2023-06-16 20:03:04 浏览: 253
这个问题可能是由于您当前使用的用户没有在其主目录下创建.ssh目录和authorized_keys文件。您可以按照以下步骤解决该问题:
1. 在终端中执行以下命令创建.ssh目录:
`mkdir ~/.ssh`
2. 然后,将公钥粘贴到authorized_keys文件中:
`echo "YOUR_PUBLIC_KEY" >> ~/.ssh/authorized_keys`
请注意替换YOUR_PUBLIC_KEY为您自己的公钥。
3. 最后,确保authorized_keys文件的权限设置正确:
`chmod 600 ~/.ssh/authorized_keys`
现在,您应该能够在终端中运行cat ~/.ssh/authorized_keys命令,看到您的公钥已经被添加到该文件中。
相关问题
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys 和chmod 700 ~/.ssh/authorized_keys的意思
这两条命令的含义分别是:
1. `cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys`:将本机的公钥文件`~/.ssh/id_rsa.pub`的内容添加到本机的授权密钥文件`~/.ssh/authorized_keys`中。这样,其他机器使用本机的私钥来连接本机时,就会自动通过验证,从而实现SSH免密登录。
2. `chmod 700 ~/.ssh/authorized_keys`:修改授权密钥文件的权限为`700`,即只有文件所有者有读写执行的权限,其他用户和组没有任何权限。这是为了保证授权密钥文件的安全性,避免他人非法访问或篡改该文件所包含的信息。
总之,这两条命令是SSH免密登录中的关键步骤,可以有效地提高系统的安全性和工作效率。
在客户端使用ssh-keygen命令生成密钥对: # ssh-keygen 在~/.ssh/目录下会生成私钥id_rsa和公钥id_rsa.pub文件 将id_rsa.pub公钥内容添加到认证文件~/.ssh/authorized_keys中即可 # cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys 新创建的认证文件需要修改文件权限,只允许当前用户访问 # chmod 600 ~/.ssh/authorized_keys 验证: # ssh localhost 当前示例使用的同一台主机,即是客户端(client),又是服务器端(server) 如果是在windows客户端和如上一致,在客户端生成密钥对,将公钥添加到服务器端认证文件中,使用私钥登录服务器即可。
在客户端使用ssh-keygen命令生成密钥对时,会在~/.ssh/目录下生成私钥id_rsa和公钥id_rsa.pub文件。要将id_rsa.pub公钥内容添加到认证文件~/.ssh/authorized_keys中,可以使用以下命令:
```
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
```
请注意,新创建的认证文件需要修改文件权限,只允许当前用户访问,可以使用以下命令:
```
chmod 600 ~/.ssh/authorized_keys
```
完成上述操作后,您可以验证密钥是否成功配置,通过执行以下命令来连接到服务器:
```
ssh localhost
```
在这个示例中,我们在同一台主机上既作为客户端(client)又作为服务器端(server)。如果您是在Windows客户端上进行操作,并且和上述步骤一致,在客户端生成密钥对,将公钥添加到服务器端的认证文件中,然后使用私钥登录服务器即可。
阅读全文