langgenius/dify-sandbox:0.2.12启动崩溃

文章目录

一. 发现问题

昨天博主参照官方教程搞了Dify测试用例,想着跑一跑熟悉一下各个组件的作用。结果点运行以后,报了sandbox运行不正常的错误,随后进服务器一看,发现sandbox这个容器在频繁重启。

bash 复制代码
CONTAINER ID   IMAGE                                       COMMAND                  CREATED         STATUS                     PORTS                                                                              NAMES
0d9992d583c0   langgenius/dify-sandbox:0.2.12              "/main"                  2 minutes ago   Restart (2) 2 seconds ago 

看了看日志,发现容器启动崩溃,出现以下错误:

bash 复制代码
runtime/cgo: pthread_create failed: Operation not permitted
SIGABRT: abort
PC=0xffffbd067dc0 m=0 sigcode=18446744073709551610

goroutine 0 gp=0x2cf3fa0 m=0 mp=0x2cf4ba0 [idle]:
runtime: g 0 gp=0x2cf3fa0: unknown pc 0xffffbd067dc0
stack: frame={sp:0xfffff0a1d4a0, fp:0x0} stack=[0xfffff021e000,0xfffff0a1d990)
0x0000fffff0a1d3a0:  0x0000ffffbd1e0640  0x0000fffff0a1d830 
0x0000fffff0a1d3b0:  0x0000000002cdc000  0x0000000002cf3fa0 
0x0000fffff0a1d3c0:  0x0000fffff0a1d400  0x0000fffff0a1d430 
runtime: g 0 gp=0x2cf3fa0: unknown pc 0xffffbd067dc0
stack: frame={sp:0xfffff0a1d4a0, fp:0x0} stack=[0xfffff021e000,0xfffff0a1d990)
0x0000fffff0a1d3a0:  0x0000ffffbd1e0640  0x0000fffff0a1d830 
0x0000fffff0a1d3b0:  0x0000000002cdc000  0x0000000002cf3fa0 
0x0000fffff0a1d590:  0x5d1e3267b19f7f89  0xc018e9598504b33d 

goroutine 1 gp=0x40000021c0 m=0 mp=0x2cf4ba0 [running]:
runtime.systemstack_switch()
	/home/runner/go/pkg/mod/golang.org/toolchain@v0.0.1-go1.23.3.linux-arm64/src/runtime/asm_arm64.s:201 +0x8 fp=0x4000204740 sp=0x4000204730 pc=0x83ba8
runtime.main()
	/home/runner/go/pkg/mod/golang.org/toolchain@v0.0.1-go1.23.3.linux-arm64/src/runtime/proc.go:172 +0x70 fp=0x40002047d0 sp=0x4000204740 pc=0x48820
runtime.goexit({})
	/home/runner/go/pkg/mod/golang.org/toolchain@v0.0.1-go1.23.3.linux-arm64/src/runtime/asm_arm64.s:1223 +0x4 fp=0x40002047d0 sp=0x40002047d0 pc=0x860d4

二. 解决问题

经过一番折腾,发现这个问题是sandbox在执行任何底层操作时,因为权限不足被系统拒绝,而导致的进程崩溃。

博主这里有两种方法来解决这个问题。

法一:sh脚本启动

添加 --privileged 参数

bash 复制代码
#!/usr/bin/sh
docker run -d --name dify-sandbox --restart=always --privileged --security-opt seccomp=unconfined --security-opt apparmor=unconfined langgenius/dify-sandbox:0.2.12

法二:docker-compose启动

  1. docker-compose.yaml中添加 privileged: true 参数。
bash 复制代码
# The DifySandbox
  sandbox:
    image: langgenius/dify-sandbox:0.2.12
    restart: always
    privileged: true
    environment:
      ......
 
  1. 使用 docker-compose config --services来查看sandbox对应的服务名称
bash 复制代码
[root@localhost docker]# docker-compose config --services
ssrf_proxy
plugin_daemon
sandbox
....
  1. 使用 docker-compose up -d sandbox 来启动
相关推荐
金銀銅鐵8 小时前
n^5 和 n 的个位数是否总相等?
python·数学
用户018349301698 小时前
用Zustand管理AI多会话状态
人工智能
武子康10 小时前
调查研究-198 Agent 到底该记住什么?读懂《What Must Generalist Agents Remember?》
人工智能·openai·agent
aqi0011 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵11 小时前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
武子康12 小时前
调查研究-197 FAISS vs Elasticsearch 全面对比:从向量检索、全文搜索到 RAG 选型指南
人工智能·elasticsearch·agent
青禾网络13 小时前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
用户2527362781413 小时前
【技术实战】用 Spring Boot + Vue3 + LM Studio 在本地跑通 RAG 知识库
人工智能
用户51914958484513 小时前
VBScript随机数生成器内部机制:从时间种子到密码令牌破解
人工智能·aigc