Build sandboxing disabled due to nsjail error

该错误通常与编译环境权限或配置问题有关,主要出现在Ubuntu 24.04或Docker容器中编译AOSP时。

  1. 在 Ubuntu24.04 上编译
    根据链接 https://groups.google.com/g/android-building/c/DbDKuaIik3M 所说,ubuntu24.04上的一些修改,会导致编译时遇到这个错误。

    临时解法是执行这个命令sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0
    如果想持久化生效的话,可以编辑文件/usr/lib/sysctl.d/10-apparmor.conf,将上面的key value添加进去,使用sysctl -p /usr/lib/sysctl.d/10-apparmor.conf 或者重启生效

解决方案

方案1:Ubuntu 24.04系统修复

临时生效(重启后失效):

复制代码
sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0

永久生效

  1. 编辑配置文件:

    复制代码
    sudo nano /usr/lib/sysctl.d/10-apparmor.conf
  2. 添加以下内容:

    复制代码
    kernel.apparmor_restrict_unprivileged_userns=0
  3. 应用配置:

    复制代码
    sudo sysctl -p /usr/lib/sysctl.d/10-apparmor.conf # 或重启系统
  1. 在Docker里面编译
    在Docker里面编译可能会遇到这个错误,解决办法是创建容器时,添加一个 --privileged 参数

    docker run --privileged -it
    --user (id -u {USER}):(id -g {USER})
    -v $PWD:/home/builder/code
    -v /etc/passwd:/etc/passwd:ro
    -v /etc/group:/etc/group:ro
    android_mm_build:latest /bin/bash

⚠️ 注意:此参数会赋予容器接近主机root的权限,需确保镜像来源可信。

相关推荐
哆啦A梦——19 小时前
Ubuntu 虚拟机 Docker 与 MySQL 8.0.42 部署指南
mysql·ubuntu·docker
上天_去_做颗惺星 EVE_BLUE20 小时前
【新 Linux 服务器上手全攻略】系统巡检、存储规划与开发环境初始化
linux·运维·服务器·ubuntu·macos·centos
das2m20 小时前
WSL2 Ubuntu 配置完美版 docker compose 指南
linux·ubuntu·docker
MIXLLRED20 小时前
Ubuntu 22.04 + ROS2 Humble 上部署 ScaRF‑SLAM指南
ubuntu·slam·ros2·离线建图
FlyWIHTSKY21 小时前
JavaScript 和 TypeScript 分别是什么,可以相互写吗
javascript·ubuntu·typescript
iRayCheung21 小时前
virtualbox安装的ubuntu系统跑numpy报错
linux·ubuntu·numpy
丑过三八线1 天前
Systemd Cgroup 驱动详解
linux·ubuntu·容器
指尖在键盘上舞动1 天前
RKNN 模型部署:onnx转rknn后精度下降 —— 精度调优与问题排查
python·ubuntu·rk3588·rknn·onnx·npu
2601_961194021 天前
考研专业课在哪里参加考试|考点|流程|资料已整理
linux·考研·ubuntu·缓存·centos·负载均衡
dust_and_stars1 天前
ubuntu24 suspend以后重新打开,桌面打不开了
ubuntu