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

相关推荐
欧云服务器5 天前
怎么让脚本命令可以同时在centos、debian、ubuntu执行?
ubuntu·centos·debian
智渊AI5 天前
Ubuntu 20.04/22.04 下通过 NVM 安装 Node.js 22(LTS 稳定版)
ubuntu·node.js·vim
The️5 天前
Linux驱动开发之Read_Write函数
linux·运维·服务器·驱动开发·ubuntu·交互
再战300年5 天前
Samba在ubuntu上安装部署
linux·运维·ubuntu
qwfys2005 天前
How to install golang 1.26.0 to Ubuntu 24.04
ubuntu·golang·install
木尧大兄弟5 天前
Ubuntu 系统安装 OpenClaw 并接入飞书记录
linux·ubuntu·飞书·openclaw
小虾爬滑丫爬5 天前
ubuntu上设置Tomcat 开机启动
ubuntu·tomcat·开机启动
老师用之于民5 天前
【DAY25】线程与进程通信:共享内存、同步机制及实现方案
linux·c语言·ubuntu·visual studio code
小虾爬滑丫爬5 天前
Ubuntu 上设置防火墙
ubuntu·防火墙
林开落L6 天前
解决云服务器内存不足:2 分钟搞定 Ubuntu swap 交换区配置(新手友好版)
运维·服务器·ubuntu·swap交换区