如何解决在 Powershell 中重定向 WSL 输入
我一直在尝试编写一个 powershell 脚本来自动化我的 Windows 工作区设置和配置,但目前我在第一次执行它时试图将输入重定向到 WSL。问题的核心是 Ubuntu 首次启动时提示输入用户名和密码,然后登录到 bash shell。我尝试将输入行写到文本文件中,如下所示:
Username
Password
Password
exit
然后,我尝试将 wsl 的输入重定向到文件:
Start-Process ubuntu2004.exe -RedirectStandardInput stdin.txt -NoNewWindow -Wait
上述内容不起作用,因为执行 WSL 只是开始发送垃圾邮件 Enter new UNIX username: adduser: only one or two names allowed
。我尝试在 CMD 中使用 <
输入重定向做同样的事情,但结果是一样的。
解决方法
这不完全是您问题的答案,但在我看来,ansible
更适合这样的任务。
我自己最近对在 wsl 中组装工作区感兴趣,而 ansible 在我看来是最好的解决方案。
在开始构建之前,您需要执行最少的步骤(创建一个用户并安装几个包,所有这些都可以放在自述文件中),但之后将没有任何限制。
你可以通过 github 上的 ansible 找到几个现成的 wsl 汇编示例。
在新的 Ubuntu WSL 实例中设置用户名/密码的一些想法:
-
首先,"PowerShell sendkeys" via COM or Interop 可能适用于此。这可能是最接近您实际要求的行为。
-
第二,也许是最有希望的,我只是尝试使用从商店安装的新 Debian WSL(因为我不想弄乱我的 Ubuntu 安装)。
当运行
debian.exe
(如ubuntu2004.exe
)时,我让它运行安装,然后当它开始要求默认用户名/密码时我 Ctrl+C 退出它。此时,WSL 实例已安装,但只有 root。我假设您的脚本可以让命令运行一段时间,然后终止进程以复制它。从您的脚本中,您应该能够运行
wsl -u root useradd --create-home --user-group --groups adm,dialout,cdrom,floppy,sudo,audio,dip,video,plugdev,netdev --password "encryptedPassword" username
(请参阅 here 以创建加密密码)。我认为这会让你成为一个普通的 Ubuntu 用户,就像 WSL 设置的那样。然后您需要创建一个
/etc/wsl.conf
文件 (instructions),让实例知道该用户是默认用户,或者 LxRunOffline 将此列为其功能之一。 -
但我还要指出,您可能只想保留您开始的现有 WSL 实例的“备份”。执行
wsl --export <distroname> <imagename.tgz>
,然后您可以在设置新的 Windows 主机时通过复制tgz
并执行wsl --import <DistroName> <DirectoryWhereYouwantItToLive> <imagename.tgz>
来导入它。如果需要,您可以使用所需的 WSL 配置使此映像保持最新,以便在重建 Windows 主机时不必重新创建它。也就是说,这是我遵循@Mystic 的建议,即使用 Ansible 存储我的 WSL“配置即代码”的地方。它让我不仅可以重新创建我的 WSL 实例,还可以在我设置(或重置)Linode 主机或其他 Linux 系统时重新创建相同的配置。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。