Files
Home-of-CS/content/post/DEV_2026_05_27_23/index.md
T
2026-05-28 12:43:40 +08:00

9.2 KiB
Raw Blame History

title, description, date, image, math, license, hidden, comments, draft, slug
title description date image math license hidden comments draft slug
试用CLab提供的云服务器,并配置Hyper-V Server 2019 相较于GNU/Linux,基于Win32的服务器并不好用。 2026-05-27T23:41:26+08:00 false false true 00I

创建实例

  • CLab官网登录你的校园网账号。
  • 按照以下配置进行设置:
    • 基础配置:
      • 可用域:nova
      • 规格:x86架构-playgrounds-p4

        这个规格是基于AMD EPYC 7773X虚拟化而来的4个vCPU+4GB内存。

      • 启动源:镜像
      • 操作系统:其他-Hyper-V Server 2019
      • 从云硬盘启动:是 - 创建云硬盘
      • 系统盘:
        • 类型:SSD
        • 容量:100GiB
        • 随云主机删除:
    • 网络配置:
      • 网络:共享网络-pku
      • 虚拟网卡:
        • pku
        • 自动分配地址
      • 安全组:default

        先前往“新建安全组”页面创建一个空的安全组。我的命名为default

    • 系统配置:
      • 名称;
      • 登录凭证:密码

        我一开始选的密钥,但好像对这个系统不起作用捏。

      • 登录密码;
      • 确认密码;
    • 确认配置,确定。
  • 等待实例创建并启动。

实例开机

实例开机后,点击“控制台”便可以使用远程桌面。这相当于一个QEMU窗口的画面。鼠标滑动有点卡,应该是没有安装显卡驱动。 由于我选的密钥,没有创建管理员密码,开机后有个黑框框要我设置管理员密码。
设置完密码之后,便进入了系统。有两个窗口:一个是Windows上正常的cmd.exe,另一个是这个系统独有的sconfig.cmd;后者是一个服务器配置菜单。
菜单有如下内容:

1) 域/工作组:工作组:WORKGROUP
2) 计算机名:SUCROSE
3) 添加本地管理员
4) 配置远程管理
5) Windows 更新设置:仅下载
6) 下载并安装更新
7) 远程桌面:已启用(仅更安全的客户端)
8) 网络设置
9) 日期和时间
10) 遥测设置:未知
11) 注销用户
12) 重新启动服务器
13) 关闭服务器
14) 退出到命令行

最后一行可以输入数字,按回车进行对应的配置。
关于这些配置的含义…我不是很懂捏……让DeepSeek解释了一下:

  1. 域/工作组
  • 作用:把服务器加入 Windows 域,或改回 工作组。
  • 什么时候用:公司内网有域控制器时,加入域可统一管理用户和权限。
  1. 计算机名
  • 作用:修改服务器名称(需要重启)。
  • 什么时候用:刚装好系统,或服务器用途改变时(比如从 SUCROSE 改为 FILE01)。
  1. 添加本地管理员
  • 作用:向本机的 Administrators 组添加用户(可以是本地用户或域用户)。
  • 什么时候用:需要给别人临时管理员权限,又不想直接用默认 Administrator。
  1. 配置远程管理
  • 作用:开启/关闭 WinRM(远程管理服务)。
  • 什么时候用:你想用 Enter-PSSession、Server Manager 或 Ansible 等工具远程管理该服务器时需开启。
  1. Windows 更新设置
  • 作用:设置更新下载与安装模式。
    常见选项:自动下载并安装、仅下载、从不检查等。
  • 什么时候用:控制服务器的重启行为(生产服务器通常不会设为自动安装)。
  1. 下载并安装更新
  • 作用:立即检查并安装 Windows 更新(手动触发)。
  • 什么时候用:补丁准备就绪后,你主动选择安装(即使选项 5 是“仅下载”)。
  1. 远程桌面
  • 作用:开启/关闭 RDP(远程桌面),并选择安全级别(支持 NLA 或全部客户端)。
  • 什么时候用:需要通过 mstsc 登录服务器桌面进行操作时。
  1. 网络设置
  • 作用:修改 IP 地址、子网掩码、网关、DNS 等网络配置。
  • 什么时候用:服务器 IP 需要固定(不要依赖 DHCP)的场景。
  1. 日期和时间
  • 作用:调整时区、系统时间,或配置 NTP 时间同步。
  • 什么时候用:服务器时间不准导致登录失败、日志错乱或认证出错时。
  1. 遥测设置
  • 作用:设置向微软发送的“诊断和使用数据”级别(安全、增强、完整等)。
  • 什么时候用:通常保持默认即可;特殊合规要求下可降低级别。
  1. 注销用户
  • 作用:注销当前控制台登录的用户(回到登录界面)。
  • 什么时候用:别人要用服务器,或你想换账户操作。
  1. 重新启动服务器
  • 作用:重启系统。
  • 什么时候用:更新需要重启、系统出现异常、修改了关键配置后。
  1. 关闭服务器
  • 作用:直接关机。
  • 什么时候用:维护硬件、迁移虚拟机、或不再使用此服务器时。
  1. 退出到命令行
  • 作用:退出 sconfig.cmd,回到普通 cmd 窗口(不重启、不修改任何东西)。
  • 什么时候用:你只是想看一下状态,之后要执行其他命令行操作。

值得注意的是,这个系统并没有explorer.exe,不支持桌面环境。(把Windows 10的explorer.exe复制进去不知道有没有用😂大概是没用的吧……)
但还可以用notepad大法😋cmd.exe输入notepad,点文件-打开,就可以看到经典的GUI文件选取界面啦。里面进行系统目录的浏览会更方便。

配置sshd

这个系统并不自带sshd,需要手动安装,才能通过SSH连接。
先输入powershell打开PowerShell。

Get-WindowsCapability -Online | Where-Object Name -like 'OpenSSH.Server*'

返回State: Not Present,说明没安装,需要手动安装。
能否通过Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0自动安装捏?不行😋
因为这个实例和我们手上的设备一样,连校园网之后需要到its.pku.edu.cn上面登录,才能访问外网。而这个系统连Internet Explorer都没有(甚至因此用不了curl……),自然无法登录。
没有外网连接,没有sshd(不能scp),是不是没法传输文件捏……并非如此。这个服务器有10.0.0.0/8地址,可以访问内网用户。
在我的联网Mac上访问https://github.com/PowerShell/Win32-OpenSSH/releases,下载预编译版的OpenSSH-Win64.zip(注意时效性)到我的~/Downloads目录,然后打开终端:

cd ~/Downloads
python3 -m http.server 8000

建立了一个简易文件服务器。

在实例上:(复制时注意占位符)

Invoke-WebRequest -Uri "http://<我的内网IP地址>:8000/OpenSSH-Win64.zip" -OutFile "C:\OpenSSH-Win64.zip"
Expand-Archive C:\OpenSSH-Win64.zip C:\
cd C:\OpenSSH-Win64
./install-sshd.ps1

即可安装完成sshd

netsh advfirewall firewall add rule name=SSH dir=in action=allow protocol=TCP localport=22
start-service sshd
set-service sshd -startuptype automatic
get-service sshd

看到Running就行,配置完成。此时Mac上输入ssh Administrator@<实例内网IP地址>,再输入密码,即可连接。

通过VSCode Remote SSH连接

Mac上配置SSH配置文件:打开~/.ssh/config

Host Windows
  HostName <实例内网IP地址>
  Port 22
  User Administrator

点击连接,输入管理员密码即可。

我这还出现了一个神秘报错:ServerFailedToStart │ Error: ServerFailedToStart (VS Code 服务器启动失败)
仔细看log

[37724 ms] Failed to download VS Code Server (https://update.code.visualstudio.com/commit:f6cfa2ea2403534de03f069bdf160d06451ed282/server-win32-x64/stable): SHA mismatch, actual 951b7fb277243c389a9a683c9c2e5a21d3fbf01e8b29573ee9b4cadb5e63986a != expected 

解决方法:Mac终端执行:

rm -rf ~/.vscode-server
rm -rf ~/.vscode-remote-containers

清理本地的.vscode-server文件夹缓存文件即可。

配置密钥登录

Mac上输入:

ssh-keygen -t ed25519

第一次回车出现Enter file in which to save the key,设置一个易于辨识的名字(如Windows_server)。后面两个直接回车就行。
不像Linux服务器,在客户机上通过ssh-copy-id发送公钥到服务器,Windows服务器是需要在服务器上执行命令的。
先获取文本形式的公钥:Mac上执行:

cat ~/.ssh/Windows_server.pub

复制得到<公钥文本>之后,在服务器上输入:(复制时注意占位符)

Add-Content -Force -Path "$env:ProgramData\ssh\administrators_authorized_keys" -Value <公钥文本>
Restart-Service sshd

即可通过SSH密钥登录。
记得修改~/.ssh/config

Host Windows
  HostName 10.129.80.39
  Port 22
  User Administrator
  IdentityFile ~/.ssh/Windows_server
  AddKeysToAgent yes
  UseKeychain yes     

由于命令不是POSIX标准,而是冗长的PowerShell格式,很多macOS/Linux下的实用工具(如htop)也不适配Windows,也由于这个系统无法运行常规的GUI程序(缺少大量动态链接库),其做虚拟机宿主的主要功能也不符合我的使用场景,我没有再继续使用,到此删除了实例。