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的权限,需确保镜像来源可信。

相关推荐
神筆&『馬良』18 小时前
Foundation_pose在自己的物体上复现指南:实现任意物体6D位姿检测(利用realsense_D435i和iphone_16pro手机)
目标检测·ubuntu·机器人·视觉检测
liuniu081820 小时前
VMware虚拟机安装ubuntu2022
ubuntu·ros
xfddlm21 小时前
边缘计算_ubuntu环境下使用瑞芯微RK3576NPU推理LLM
人工智能·ubuntu·边缘计算
EHagSJVNpTY1 天前
MATLAB 中基于最大重叠离散小波变换的心电信号处理探索
ubuntu
.小墨迹1 天前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
技术路上的探险家1 天前
Ubuntu下Docker与NVIDIA Container Toolkit完整安装教程(含国内源适配)
linux·ubuntu·docker
无证驾驶梁嗖嗖1 天前
用Plex打造随身私人影院告别影音杂乱,必须加上cpolar突破地域限制!
ubuntu
Sheep Shaun1 天前
揭开Linux的隐藏约定:你的第一个文件描述符为什么是3?
linux·服务器·ubuntu·文件系统·缓冲区
生活很暖很治愈1 天前
Linux——环境变量PATH
linux·ubuntu
予枫的编程笔记1 天前
【Linux入门篇】Ubuntu和CentOS包管理不一样?apt与yum对比实操,看完再也不混淆
linux·人工智能·ubuntu·centos·linux包管理·linux新手教程·rpm离线安装