最近玩VScode的远程开发功能,它可以连接Docker的container,也可连接wsl,window下的container是运行在WSL,那就研究下直接连接WSL,而不让Docker这个二手商赚差价,嘿嘿。

WSL官方文档

WSL基础命令

通过wsl -l -o 命令我们可以看到远程可以安装的镜像列表。

DOCKER Home assistant加载项_docker

通过 Microsoft Store下载镜像总是下载不下来,命令行也不行,可能是这里的网络有问题(有时候又是可以下载的,(╯‵□′)╯︵┻━┻),根据官网提示,可以通过docker来自己制作一个tar文件然后导入到wsl中,WSL文档,而且我也想装个CentOS试试。

没有人运行操作系统只是为了运行操作系统

# 拉取centos 镜像
docker pull centos
# 创建容器,
docker run -it centos 
# 列出所有容器找到刚刚创建的 centOS 的容器ID
docker container ls -a
# 导出 发行版
docker export c9e89339e9d2 > e:\centos.tar
# 导入发行版到到wsl,命令格式 wsl --import <Distro> <InstallLocation> <FileName> 
# 记得创建对应文件夹
wsl --import CentOS E:\wslDistroStorage\CentOS e:\centos.tar
# 查看安装的wsl 
wsl -l -v
# 启动并进入该系统
wsl -d CentOS
# 完成了,
# 扩展下,指定默认的分发版, wsl --setdefault(-s) <DistributionName>  
wsl -s CentOS
# 指定默认分发版之后,可以直接输入,wsl 默认就会进入CentOS这个分发版。

OK 完成。

移动WSL的位置
C:\Users\Administrator> wsl --l -v
  NAME                   STATE           VERSION
* docker-desktop         Running         2
  docker-desktop-data    Running         2
# 导出,将wsl导出到指定的文件
  C:\Users\Administrator> wsl --export docker-desktop-data "D:\Docker\wsl\data\docker-desktop-data.tar"
  # 移除原有虚拟机,删除之后会清除所有信息
C:\Users\Administrator> wsl --unregister docker-desktop-data
  # 生成新虚拟机,即在指定位置导入虚拟机,--version 2 是指定 wsl
  # 的版本,如果已经吧wsl2 设置为默认值,那么就不需要再指定一次了,
  # 如果没有特殊需求,还是使用新的吧,
C:\Users\Administrator> wsl --import docker-desktop-data "D:\Docker\wsl\data" "D:\Docker\wsl\data\docker-desktop-data.tar" --version 2
WSL 用户

通过–import导入的分发版,默认会使用root用户运行系统,权限太高了不太好,

刚刚把root 用户的path变量搞坏了,连vi,cat 命令都不能用了,还好连着vscode,通过vscode编辑修改回来了。

接下来设置个自己的用户账户。由于安装的是一个极简的CentOS系统,连sudo都没有,所以要先安装一下sudo和密码设置工具passwd 首先安装

# 更新DNF,,dnf就是之前的yum的升级版,新版的centos中yum命令最终调用的还是dnf命令
dnf update -y
# 安装sudo 和 passwd 
dnf install passwd sudo -y

root 用户会显示# (root用户横竖都是二(*^▽^*));普通用户显示 $(普通用户很有钱。\(^o^)/~)

关于sudo 在sudo于1980年前后被写出之前,一般用户管理系统的方式是利用su切换为超级用户(linux自带的就是这个)。但是使用su的缺点之一在于必须要先告知超级用户的密码。 sudo使得一般用户不需要知道超级用户的密码即可获得权限。首先超级用户将普通用户的名字、可以执行的特定命令、按照哪种用户或用户组的身份执行等信息,登记在特殊的文件中(通常是/etc/sudoers),即完成对该用户的授权(此时该用户称为“sudoer”);在一般用户需要取得特殊权限时,其可在命令前加上“sudo”,此时sudo将会询问该用户自己的密码(以确认终端机前的是该用户本人),回答后系统即会将该命令的进程以超级用户的权限运行。之后的一段时间内(默认为5分钟,可在/etc/sudoers自定义),使用sudo不需要再次输入密码。

添加vsuser用户并将其附加组设置为 wheel
# 添加用户并,添加wheel为附加组
adduser -G wheel vsuser
# 设置密码 
passwd vsuser

wheel 组是linux默认的一个组,该组成员默认有执行sudo的权限。因为总不能所有人都有权限去执行sudo,那样会带来麻烦,所以在sudo的设置文件中指定一个组使该组成员有执行sudo的权限,而wheel就是这样的组。

设置wsl 启动时默认的登录账户

在window下可以通过这个命令 <DistributionName> config --default-user <Username>来修改,如果已经登录了wsl系统,那么可以在wsl内部,通过下面的命令设置,设置之后重启wsl系统即可。关于wsl.conf

# -e 是要解析转义字符,不要直接输出个 \n 而是输出换行,也可通过vi/vim 编辑这个文件
echo -e "[user]\ndefault=vsuser" >> /etc/wsl.conf
docker

重命名docker 容器

docker rename <container id/name> newName

在linux命令行中 使用如下方法可以引用上一个命令的最后一个参数,快捷键 (Esc . ) 或 (Alt .) 命令参数 !$ 或 $_