在 MacOS 上通过 Lima 使用 Docker

2023-03-19 17:50:27 浏览数 (2)

为什么要使用 lima

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

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

像一些基于 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 一把梭

代码语言:javascript复制
brew install lima

开始创建实例

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

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

模版列表:

代码语言:javascript复制
limactl start --list-templates

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

代码语言:javascript复制
limactl start --name=default template://docker

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

使用 docker 实例

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

代码语言:javascript复制
limactl shell docker docker ps

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

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

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

代码语言:javascript复制
vim bin/docker

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

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

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

常见问题

如何在局域网中暴露端口

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

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

代码语言:javascript复制
portForwards:
- guestPortRange: [1, 65535]
  guestIPMustBeZero: true
  hostIP: 0.0.0.0

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

cpuType 的问题

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

代码语言:javascript复制
qemu-system-x86_64 -cpu help

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

代码语言:javascript复制
cpuType:
  # 


	

0 人点赞