在 macOS 上通过 lima 使用 docker

1,220 阅读3分钟

原始文章发表在 从现在开始的个人博客,欢迎阅读,谢谢大家

为什么要使用 lima

目前在 macOS 上如果想使用 docker,那么最直接的就是使用 官方推出的 docker-desktop

docker-desktop 带有 gui 进行管理。然鹅我不想要,想要的是直接在命令行中就可以操作 docker 的方案。然后经过搜索有这么几种: podmanlima

像一些基于 lima 的产品就不列出来了

实验了podman 也挺好。之所以最终没有选择podman,纯粹是由于公司用的黑苹果,cpu 是奔腾,然后使用 qemu 时内核恐慌。podman 没法定义 cpuType(后面不知道是否可以了)。而 lima 提供了自定义 cpuType 的选项,在文章最后的常见问题中有说明

lima 是什么

Linux virtual machines, typically on macOS, for running containerd

Motivation The goal of Lima is to promote containerd including nerdctl (contaiNERD ctl) to Mac users, but Lima can be used for non-container applications as well.

在我看来,就是在 macOS 上搞容器,合我心意就开始实践

如何使用 lima

安装

macOS 就不多说了,直接 brew 一把梭

brew install lima

开始创建实例

macOS 和 Windows 无法直接运行 docker,都是通过虚拟化技术来实现的。简单来说就是建一个虚拟机,在虚拟机里面装 docker。

lima 提供了更多的选择,除了可以建docker,还可以建 k3s、k8s、podman等等。通过 template 进行选择。

模版列表:

limactl start --list-templates

新建一个实例名称为 default 的 docker 实例(不指定 name 的话就是 docker):

limactl start --name=default template://docker

这里只介绍一下 docker 的使用,其他的类型各位看官可以自行摸索。

使用 docker 实例

刚开始使用比较别扭,需要通过

limactl shell docker docker ps

类似这样的进行操作。这肯定不行的,最好还是直接使用 docker [options] command,所以想想办法

首先,alias 大法好,直接上来一把梭,但是发现是可以直接执行。但是补全无法使用了。这里大家也可以试一下。

然后,我就照着 lima 默认有个 nerdctl.lima 命令。写了个 docker

vim bin/docker

#!/bin/sh
set -eu
exec limactl shell docker docker "$@"

注意:bin 要加入 PATH中,方便任何地方都可以使用。然后记得 chmod +x 添加执行权限

做到这里,就比较丝滑了。直接 docker 一把梭。 image-1661051591145

常见问题

如何在局域网中暴露端口

默认只能主机访问,如果需要暴露端口,那么就需要更改监听地址为 0.0.0.0 然后可以查看这个讨论: Expose Lima Machine Ports Lan

关键配置在端口转发这里:

portForwards:
- guestPortRange: [1, 65535]
  guestIPMustBeZero: true
  hostIP: 0.0.0.0

注意:这样配置之后,默认 -p 就是 0.0.0.0 (可以看上面讨论链接详情,由于博主英语太差,就不贴图献丑了)

cpuType 的问题

其实这个我也拿不准,但是的确是通过自定义 cpuType 解决了。

qemu-system-x86_64 -cpu help

然后我选择了 kvm64,根据 自定义架构的cpu类型 进行调整yaml 配置文件

cpuType:
  # 🟢 Builtin default: "cortex-a72" (or "host" when running on aarch64 host)
  aarch64: null
  # 🟢 Builtin default: "qemu64" (or "host" when running on x86_64 host)
  x86_64: "kvm64"

然后重新启动 docker 实例即可

至此,仅仅在命令行中操作 docker 就诞生了,命令补全什么的都可以使用,无论什么东西,用的舒服就好