最近玩VScode的远程开发功能,它可以连接Docker的container,也可连接wsl,window下的container是运行在WSL,那就研究下直接连接WSL,而不让Docker这个二手商赚差价,嘿嘿。
WSL官方文档
WSL基础命令
通过wsl -l -o 命令我们可以看到远程可以安装的镜像列表。
通过 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 完成。
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
通过–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不需要再次输入密码。
# 添加用户并,添加wheel为附加组
adduser -G wheel vsuser
# 设置密码
passwd vsuser
wheel 组是linux默认的一个组,该组成员默认有执行sudo的权限。因为总不能所有人都有权限去执行sudo,那样会带来麻烦,所以在sudo的设置文件中指定一个组使该组成员有执行sudo的权限,而wheel就是这样的组。
在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 rename <container id/name> newName
在linux命令行中 使用如下方法可以引用上一个命令的最后一个参数,快捷键 (Esc . ) 或 (Alt .) 命令参数 !$ 或 $_