Mac使用docker下的两个冷知识

1.Mac下的docker无法直接访问宿主机网络或本地服务

在 macOS 上,Docker 容器无法像 Linux 一样直接访问宿主机网络或某些本地服务,如果我们要访问本地数据库或者本地容器内的数据库该怎么办呢?

我之前使用的是这种方式:

创建了一个wenjunxiao/mac-docker-connector:latest(镜像名称同容器名称)的容器,这个容器的作用就是让容器里的程序可以访问你 Mac 上的服务(反向打通网络)。

通过启动 mac-docker-connector 容器这种方式比较麻烦,虽然可以设置自动启动,但是每次 docker ps 之后看见他总感觉怪怪的,前两天我就不记得这个容器是干嘛用的了。

推荐大家另一种方式:

如果你的两个服务都是容器启动,比如我的nacos要连接mysql,那就让这两个容器加入同一个网络

ps:如果本地已经搭建了docker-compose或者k8s那自然容器都在同一网络下,可以直接通过容器名称互访。

命令如下:

bash 复制代码
# 创建网络
docker network create mdx-net

# mysql8 这个容器加入这个网络
docker network connect mdx-net mysql8

# nacos2.1.2-slim 这个容器加入这个网络
docker network connect mdx-net nacos2.1.2-slim

# 查看加入情况
docker network inspect mdx-net

执行 docker network inspect mdx-net 后如果能看见下图这些内容那就成功了。

然后nacos就可以通过容器名称直接连接mysql了

2.Mac重启导致docker异常中断无法再次启动容器

今天遇见了一个问题,电脑更新系统重启后,docker异常退出了,导致再次启动mysql容器的时候失败了

报错 :

sh 复制代码
chown: changing ownership of '/var/lib/mysql/mysql.sock': No such file or directory

问题原因就是,我的mysql容器挂载了宿主机的data目录,然后在上次容器异常退出的时候容器没有及时清理 mysql.sock 、 *.pid 和临时文件,所以新容器再启动时容易误判或触发权限异常。这些都属于运行时文件,如果容器正常退出大概率是会被清理的。

解决方案:

如果不想删除掉容器映射到主机上的持久化数据的情况下,可以执行如下命令:

bash 复制代码
docker rm -f mysql8
find /Users/jiagang/dev-jag/docker/mysql/data -name '.DS_Store' -delete
rm -f /Users/jiagang/dev-jag/docker/mysql/data/mysql.sock
rm -f /Users/jiagang/dev-jag/docker/mysql/data/*.pid
xattr -dr com.docker.grpcfuse.ownership /Users/jiagang/dev-jag/docker/mysql/data
相关推荐
程序员老赵9 小时前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua11114 小时前
LM Studio Docker 部署——本地大模型一键启动
docker
曲幽2 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
武子康3 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
元Y亨H4 天前
MacBook Air 开发神器:IDEA 与 PyCharm 极简安装及环境配置
macos
yuanyxh5 天前
macOS 应用 - 纯对话生成
前端·macos·ai编程
AI创界者6 天前
PilotTTS 一键整合包(Win/Mac):8G 显存畅跑,实测解锁情绪与副语言的精准控制
人工智能·macos·aigc·音视频
Alsn866 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
2601_961875247 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj7 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes