E486: 找不到模式: usr
时间: 2024-02-04 09:02:01 浏览: 22
看起来你可能遇到了一个 Vim 编辑器的错误。错误信息 "E486: 找不到模式: usr" 表示 Vim 在尝试查找一个名为 "usr" 的模式时失败了。
通常情况下,这种错误可能是由以下几个原因引起的:
1. 你输入了一个无效的正则表达式模式。
2. 你在命令中使用了一个不存在的模式。
请检查你的命令,确保你使用的是正确的模式。如果你可以提供更多的上下文信息或者具体的命令行代码,我可以更详细地帮助你解决这个问题。
相关问题
sudo:未找到命令
当在Linux系统中使用sudo命令时,如果提示"command not found"错误,可能是因为sudo命令的环境变量中没有包含所要执行的命令的路径。这种情况下,可以按照以下步骤解决问题:
1. 首先,确认系统是否已经安装了sudo命令。可以执行以下命令检查/etc/sudoers.d文件是否存在:
`find /etc/sudoers.d`
2. 如果返回"No such file or directory",表示系统没有安装sudo命令。可以使用以下命令安装sudo:
`apt-get install sudo`
如果安装过程中提示"E: Unable to locate package sudo"错误,可以先执行以下命令更新软件包列表:
`apt-get update`
然后再执行sudo apt-get install命令安装sudo。
3. 如果/etc/sudoers.d文件存在,说明系统已经安装了sudo,但是可能没有正确配置环境变量。
在使用sudo执行程序时,为了安全考虑,该程序将在一个新的、最小化的环境中执行。因此,在sudo命令下,诸如PATH这样的环境变量已被重置为默认状态。
当一个刚初始化的PATH变量中不包含要执行的程序所在的目录时,使用sudo命令执行会提示"command not found"错误。
要更改sudo会话中的PATH初始值,请按照以下步骤编辑/etc/sudoers文件:
- 执行命令打开/etc/sudoers文件:
`vi /etc/sudoers`
- 找到"secure_path"一行,该行包含了在执行sudo命令时作为默认PATH变量使用的路径。
- 进入插入模式(按下"i"键),在"secure_path"下面添加所需的路径(例如:/usr/local/bin):
`Defaults secure_path = /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin`
- 切换到命令行模式(按下"ESC"键),输入":wq"保存并退出编辑。
这样就可以解决sudo命令提示"command not found"错误。
另外,使用完整的脚本文件路径而不是仅仅通过脚本名称来执行sudo命令也是解决问题的一种方法:
`sudo /home/fdl/bin/connect.sh`
这些方法可以帮助您解决"sudo:未找到命令"的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [sudo 找不到命令 command not found 解决方案](https://blog.csdn.net/weixin_45798993/article/details/125780047)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* [sudo: command not found 的解决方法](https://blog.csdn.net/yzlaitouzi/article/details/128948831)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
shell逐条解释注释 ``` getenforce setenforce 0 cp /usr/lib/systemd/system/sshd.service /usr/lib/systemd/system/sshd.old.service sed -i -e 's/^Type=.*/Type=simple/g' -e '/ExecStart=/{s/\/usr\/sbin\/sshd/\/usr\/local\/sbin\/sshd/g}' /usr/lib/systemd/system/sshd.service sed -i "s/GSSAPIAuthentication/#GSSAPIAuthentication/" /etc/ssh/sshd_config sed -i "s/GSSAPICleanupCredentials/#GSSAPICleanupCredentials/" /etc/ssh/sshd_config sed -i "s/#PermitRootLogin yes/PermitRootLogin yes/" /etc/ssh/sshd_config sed -i "s/#UsePAM yes/UsePAM yes/" /etc/ssh/sshd_config chmod 600 /etc/ssh/ssh_host_rsa_key chmod 600 /etc/ssh/ssh_host_ecdsa_key chmod 600 /etc/ssh/ssh_host_ed25519_key mv /usr/local/sbin/sshd /usr/local/sbin/sshd.old202211 mv /lib64/libcrypto.so.1.1 /lib64/libcrypto.so.1.1.old202211 mv /srv/libcrypto.so.1.1 /lib64/ mv /srv/sshd /usr/local/sbin/ chmod 755 /usr/local/sbin/sshd chmod 755 /lib64/libcrypto.so.1.1 systemctl daemon-reload systemctl restart sshd.service source /etc/profile sshd -V useradd secure echo 'Ofm#6%3%fm0IWH'|passwd --stdin secure echo "secure ALL=(ALL) ALL" >> /etc/sudoers sed -i "s/PermitRootLogin yes/PermitRootLogin no/" /etc/ssh/sshd_config service sshd restart systemctl daemon-reload systemctl restart sshd.service sed -i "s/secure ALL=(ALL) ALL/secure ALL=(ALL) NOPASSWD: ALL/" /etc/sudoers chage -M 99999 secure sleep 2 useradd aqassoc echo 'dAxgDt^7LT' | passwd --stdin aqassoc mkdir /batshell chown -R aqassoc:aqassoc /batshell echo 'aqassoc ALL=(ALL) NOPASSWD:ALL,!/bin/su,!/sbin/init,!/sbin/shutdown,!/sbin/halt,!/sbin/reboot,!/usr/sbin/visudo,!/usr/bin/passwd' >> /etc/sudoers sh /srv/script.sh sleep 2 tar -xvf /srv/ssl-1.1.1o* -C /srv/ mv /usr/bin/openssl /usr/bin/openssl.old mv /usr/include/openssl /usr/include/openssl.old cp /etc/ld.so.conf /etc/ld.so.conf.old ln -s /srv/ssl-1.1.1o/bin/openssl /usr/bin/openssl ln -s /srv/ssl-1.1.1o/include/openssl /usr/include/openssl srvlib=`cat /etc/ld.so.conf | grep '/srv/ssl-1.1.1o/lib/' | wc -l` if [ $srvlib -eq 0 ];then sed -i 's/\/srv/#\/srv/'g /etc/ld.so.conf echo '/srv/ssl-1.1.1o/lib/' >> /etc/ld.so.conf else echo 'ssl-1.1.1n is ok!' fi ldconfig -v |grep ssl openssl version rm -rf /srv/root_password.sh rm -rf /srv/ssl-1.1.1o_7.tar.gz curl --connect-timeout 10 -# http://133.64.86.246/iso/shell/initialization.sh -o /tmp/initialization.sh # 只有两个参数 dcn/dmz netbond/netskip baseline/baseskip sh /tmp/initialization.sh dcn netbond/netskip baseline/baseskip ```
这段脚本的作用是进行一系列操作来配置和安装SSH服务,并创建用户和设置权限。
以下是每个命令的解释:
1. `getenforce`:显示SELinux的执行模式。
2. `setenforce 0`:禁用SELinux。
3. `cp /usr/lib/systemd/system/sshd.service /usr/lib/systemd/system/sshd.old.service`:备份sshd.service文件。
4. `sed -i -e 's/^Type=.*/Type=simple/g' -e '/ExecStart=/{s/\/usr\/sbin\/sshd/\/usr\/local\/sbin\/sshd/g}' /usr/lib/systemd/system/sshd.service`:修改sshd.service文件中的Type和ExecStart路径。
5. `sed -i "s/GSSAPIAuthentication/#GSSAPIAuthentication/" /etc/ssh/sshd_config`:注释掉sshd_config文件中的GSSAPIAuthentication行。
6. `sed -i "s/GSSAPICleanupCredentials/#GSSAPICleanupCredentials/" /etc/ssh/sshd_config`:注释掉sshd_config文件中的GSSAPICleanupCredentials行。
7. `sed -i "s/#PermitRootLogin yes/PermitRootLogin yes/" /etc/ssh/sshd_config`:取消注释sshd_config文件中的PermitRootLogin行。
8. `sed -i "s/#UsePAM yes/UsePAM yes/" /etc/ssh/sshd_config`:取消注释sshd_config文件中的UsePAM行。
9. `chmod 600 /etc/ssh/ssh_host_rsa_key`:设置ssh_host_rsa_key文件的权限为600。
10. `chmod 600 /etc/ssh/ssh_host_ecdsa_key`:设置ssh_host_ecdsa_key文件的权限为600。
11. `chmod 600 /etc/ssh/ssh_host_ed25519_key`:设置ssh_host_ed25519_key文件的权限为600。
12. `mv /usr/local/sbin/sshd /usr/local/sbin/sshd.old202211`:备份sshd可执行文件。
13. `mv /lib64/libcrypto.so.1.1 /lib64/libcrypto.so.1.1.old202211`:备份libcrypto.so.1.1库文件。
14. `mv /srv/libcrypto.so.1.1 /lib64/`:将备份的libcrypto.so.1.1库文件移动到/lib64/目录下。
15. `mv /srv/sshd /usr/local/sbin/`:将备份的sshd可执行文件移动到/usr/local/sbin/目录下。
16. `chmod 755 /usr/local/sbin/sshd`:设置sshd可执行文件的权限为755。
17. `chmod 755 /lib64/libcrypto.so.1.1`:设置libcrypto.so.1.1库文件的权限为755。
18. `systemctl daemon-reload`:重新加载systemd配置。
19. `systemctl restart sshd.service`:重启sshd服务。
20. `source /etc/profile`:加载/etc/profile文件中的环境变量。
21. `sshd -V`:显示sshd的版本信息。
22. `useradd secure`:创建用户secure。
23. `echo 'Ofm#6%3%fm0IWH'|passwd --stdin secure`:设置用户secure的密码。
24. `echo "secure ALL=(ALL) ALL" >> /etc/sudoers`:允许用户secure以任何用户执行任何命令。
25. `sed -i "s/PermitRootLogin yes/PermitRootLogin no/" /etc/ssh/sshd_config`:将sshd_config文件中的PermitRootLogin设置为no,禁止root登录。
26. `service sshd restart`:重启sshd服务。
27. `systemctl daemon-reload`:重新加载systemd配置。
28. `systemctl restart sshd.service`:重启sshd服务。
29. `sed -i "s/secure ALL=(ALL) ALL/secure ALL=(ALL) NOPASSWD: ALL/" /etc/sudoers`:将用户secure的权限更改为无需输入密码执行任意命令。
30. `chage -M 99999 secure`:设置用户secure的密码有效期限为99999天。
31. `sleep 2`:延迟2秒。
32. `useradd aqassoc`:创建用户aqassoc。
33. `echo 'dAxgDt^7LT' | passwd --stdin aqassoc`:设置用户aqassoc的密码。
34. `mkdir /batshell`:创建/batshell目录。
35. `chown -R aqassoc:aqassoc /batshell`:将目录/batshell的所有权和组设置为aqassoc。
36. `echo 'aqassoc ALL=(ALL) NOPASSWD:ALL,!/bin/su,!/sbin/init,!/sbin/shutdown,!/sbin/halt,!/sbin/reboot,!/usr/sbin/visudo,!/usr/bin/passwd' >> /etc/sudoers`:允许用户aqassoc以任何用户执行任何命令,但不包括/bin/su、/sbin/init、/sbin/shutdown、/sbin/halt、/sbin/reboot、/usr/sbin/visudo和/usr/bin/passwd命令。
37. `sh /srv/script.sh`:运行/srv/script.sh脚本。
38. `sleep 2`:延迟2秒。
39. `tar -xvf /srv/ssl-1.1.1o* -C /srv/`:解压缩/srv/目录下的ssl-1.1.1o文件。
40. `mv /usr/bin/openssl /usr/bin/openssl.old`:备份/usr/bin/openssl可执行文件。
41. `mv /usr/include/openssl /usr/include/openssl.old`:备份/usr/include/openssl目录。
42. `cp /etc/ld.so.conf /etc/ld.so.conf.old`:备份/etc/ld.so.conf文件。
43. `ln -s /srv/ssl-1.1.1o/bin/openssl /usr/bin/openssl`:将openssl软链接到/srv/ssl-1.1.1o/bin/openssl。
44. `ln -s /srv/ssl-1.1.1o/include/openssl /usr/include/openssl`:将openssl目录软链接到/srv/ssl-1.1.1o/include/openssl。
45. `srvlib=`cat /etc/ld.so.conf | grep '/srv/ssl-1.1.1o/lib/' | wc -l``:检查/etc/ld.so.conf文件中是否包含/srv/ssl-1.1.1o/lib/路径。
46. `if [ $srvlib -eq 0 ];then sed -i 's/\/srv/#\/srv/'g /etc/ld.so.conf echo '/srv/ssl-1.1.1o/lib/' >> /etc/ld.so.conf else echo 'ssl-1.1.1n is ok!' fi`:如果/etc/ld.so.conf文件中不包含/srv/ssl-1.1.1o/lib/路径,则将/srv/路径注释掉,然后在/etc/ld.so.conf文件末尾添加/srv/ssl-1.1.1o/lib/路径。
47. `ldconfig -v |grep ssl`:刷新动态链接库缓存,并显示包含"ssl"字符串的库。
48. `openssl version`:显示OpenSSL的版本信息。
49. `rm -rf /srv/root_password.sh`:删除/srv/root_password.sh文件。
50. `rm -rf /srv/ssl-1.1.1o_7.tar.gz`:删除/srv/ssl-1.1.1o_7.tar.gz文件。
51. `curl --connect-timeout 10 -# http://133.64.86.246/iso/shell/initialization.sh -o /tmp/initialization.sh`:从指定URL下载initialization.sh脚本到/tmp/initialization.sh。
52. `sh /tmp/initialization.sh dcn netbond/netskip baseline/baseskip`:运行/tmp/initialization.sh脚本,并传递参数dcn、netbond/netskip和baseline/baseskip。