无法编辑/etc/ssh/sshd_config
时间: 2023-06-28 20:04:57 浏览: 198
如果您无法编辑`/etc/ssh/sshd_config`文件,可能是因为您没有足够的权限来编辑该文件。您可以尝试使用超级用户权限编辑该文件,方法如下:
1. 打开终端或控制台。
2. 输入以下命令以获取超级用户权限:
```
sudo su
```
3. 输入超级用户密码。
4. 输入以下命令以编辑`/etc/ssh/sshd_config`文件:
```
nano /etc/ssh/sshd_config
```
或者您可以使用其他文本编辑器(如 vi 或 emacs)。
5. 在编辑器中修改配置文件。
6. 保存并关闭文件。
7. 退出超级用户模式:
```
exit
```
请记住,在更改`/etc/ssh/sshd_config`文件之前,一定要备份该文件以防止意外更改导致的问题。
相关问题
if grep -q "PASS_MIN_DAYS" /etc/login.defs then sed -i '/PASS_MIN_DAYS/s/^#//' /etc/login.defs sed -i "s/PASS_MIN_DAYS.*/PASS_MIN_DAYS 6/g" /etc/login.defs fi if grep -q "PASS_MIN_LEN" /etc/login.defs then sed -i '/PASS_MIN_LEN/s/^#//' /etc/login.defs sed -i "s/PASS_MIN_LEN.*/PASS_MIN_LEN 8/g" /etc/login.defs fi if grep -q "PASS_MAX_DAYS" /etc/login.defs then sed -i '/PASS_MAX_DAYS/s/^#//' /etc/login.defs sed -i "s/PASS_MAX_DAYS.*/PASS_MAX_DAYS 90/g" /etc/login.defs fi if grep -q "PASS_WARN_AGE" /etc/login.defs then sed -i '/PASS_WARN_AGE/s/^#//' /etc/login.defs sed -i "s/PASS_WARN_AGE.*/PASS_WARN_AGE 7/g" /etc/login.defs fi if grep -q "Protocol" /etc/ssh/sshd_config then sed -i '/Protocol/s/^#//' /etc/ssh/sshd_config sed -i "s/Protocol.*/Protocol 2/g" /etc/ssh/sshd_config else echo 'Protocol 2' >> /etc/ssh/sshd_config fi
以下是将这些命令转换为Python代码的示例:
```python
import subprocess
login_defs_file = '/etc/login.defs'
ssh_config_file = '/etc/ssh/sshd_config'
# Update PASS_MIN_DAYS in login.defs file
if subprocess.call('grep -q "PASS_MIN_DAYS" /etc/login.defs', shell=True) == 0:
subprocess.call("sed -i '/PASS_MIN_DAYS/s/^#//' /etc/login.defs", shell=True)
subprocess.call("sed -i 's/PASS_MIN_DAYS.*/PASS_MIN_DAYS 6/g' /etc/login.defs", shell=True)
# Update PASS_MIN_LEN in login.defs file
if subprocess.call('grep -q "PASS_MIN_LEN" /etc/login.defs', shell=True) == 0:
subprocess.call("sed -i '/PASS_MIN_LEN/s/^#//' /etc/login.defs", shell=True)
subprocess.call("sed -i 's/PASS_MIN_LEN.*/PASS_MIN_LEN 8/g' /etc/login.defs", shell=True)
# Update PASS_MAX_DAYS in login.defs file
if subprocess.call('grep -q "PASS_MAX_DAYS" /etc/login.defs', shell=True) == 0:
subprocess.call("sed -i '/PASS_MAX_DAYS/s/^#//' /etc/login.defs", shell=True)
subprocess.call("sed -i 's/PASS_MAX_DAYS.*/PASS_MAX_DAYS 90/g' /etc/login.defs", shell=True)
# Update PASS_WARN_AGE in login.defs file
if subprocess.call('grep -q "PASS_WARN_AGE" /etc/login.defs', shell=True) == 0:
subprocess.call("sed -i '/PASS_WARN_AGE/s/^#//' /etc/login.defs", shell=True)
subprocess.call("sed -i 's/PASS_WARN_AGE.*/PASS_WARN_AGE 7/g' /etc/login.defs", shell=True)
# Update Protocol in sshd_config file
if subprocess.call('grep -q "Protocol" /etc/ssh/sshd_config', shell=True) == 0:
subprocess.call("sed -i '/Protocol/s/^#//' /etc/ssh/sshd_config", shell=True)
subprocess.call("sed -i 's/Protocol.*/Protocol 2/g' /etc/ssh/sshd_config", shell=True)
else:
subprocess.call("echo 'Protocol 2' >> /etc/ssh/sshd_config", shell=True)
```
上述代码首先检查是否存在`/etc/login.defs`文件中的`PASS_MIN_DAYS`行,如果存在,则将其注释去除,并将`PASS_MIN_DAYS`的值设置为6。接着,检查是否存在`PASS_MIN_LEN`行,如果存在,则将其注释去除,并将`PASS_MIN_LEN`的值设置为8。然后,检查是否存在`PASS_MAX_DAYS`行,如果存在,则将其注释去除,并将`PASS_MAX_DAYS`的值设置为90。最后,检查是否存在`PASS_WARN_AGE`行,如果存在,则将其注释去除,并将`PASS_WARN_AGE`的值设置为7。
然后,检查是否存在`/etc/ssh/sshd_config`文件中的`Protocol`行,如果存在,则将其注释去除,并将其值设置为2。如果不存在,则在文件末尾添加一行`Protocol 2`。
请确保你具有足够的权限来执行这些操作,并将需要修改的文件路径正确添加到`login_defs_file`和`ssh_config_file`变量中。运行代码后,命令将被执行。
/etc/ssh/ssh_config: line 47: Bad configuration option: permitrootlogin /etc/ssh/ssh_config: line 48: Bad configuration option: permitemptypasswords /etc/ssh/ssh_config: terminating, 2 bad configuration option
这个错误信息表明您的SSH配置文件(/etc/ssh/ssh_config)中存在无效的配置选项。具体来说,第47行和第48行都有错误的配置选项:permitrootlogin和permitemptypasswords。
这些选项在SSH服务器的配置文件(/etc/ssh/sshd_config)中是有效的,但在客户端的配置文件中是无效的。
要解决这个问题,请打开SSH客户端的配置文件(/etc/ssh/ssh_config),找到并删除这两个无效的选项。然后保存文件并重新启动SSH服务。您可以使用以下命令来重新启动SSH服务:
```
sudo service ssh restart
```
这应该会解决这个问题。
阅读全文