当我尝试在模拟器上运行我的Android应用程序时,我得到这个错误:

/dev/kvm权限被拒绝。

我检查了权限,并将我当前登录的用户添加到kvm组。怎么了?


当前回答

/dev/kvm权限被拒绝

[主板]在BIOS中设置VT(虚拟化技术),安装虚拟机

其他回答

如果你用sudo打开你的ide。你不会遇到这个问题。

在Ubuntu下,/dev/kvm的权限通常是这样的:

$ ls -l /dev/kvm
crw-rw---- 1 root kvm 10, 232 May 24 09:54 /dev/kvm

运行Android模拟器的用户(即您的用户)需要访问此设备。

因此,基本上有两种访问方式:

确保您的用户是kvm组的一部分(更改后需要您的用户重新登录) 扩大该设备的权限,以便您的用户可以访问(需要更改udev守护进程配置)

将用户添加到KVM组

检查您的用户是否已经是kvm组的一部分,例如:

$ id 
uid=1000(juser) gid=1000(juser) groups=1000(juser),10(wheel)

如果不是,那就加上例如:

$ sudo usermod --append --groups kvm juser

更改之后,您必须注销并再次登录以使组更改生效(再次检查id)。

扩大权限

或者,您也可以扩大/dev/kvm设备的权限。

例子:

echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' \
    | sudo tee /etc/udev/rules.d/99-kvm4all.rules
sudo udevadm control --reload-rules
sudo udevadm trigger --name-match=kvm

FWIW,这是其他发行版(如Fedora和CentOS)的默认设置。

使用另一个ls检查上述命令的有效性。你应该看到类似的输出:

$ ls -l /dev/kvm
crw-rw-rw-. 1 root kvm 10, 232 2020-05-16 09:19 /dev/kvm

最大的优势:您不需要注销并再次登录才能使此更改生效。

没有办法的办法

calling chmod and chown directly on /dev/kvm - 1) these changes aren't persistent over reboots and 2) since /dev/kvm permissions are controlled by the udev daemon, it can 'fix' its permissions at any time, e.g. after each emulator run adding executable permissions to /dev/kvm - your emulator just requires read and write permissions changing permissions recursively on /dev/kvm - I don't know what's up with that - looks like cargo cult installing extra packages like qemu - you already have your emulator installed - you just need to get access to the /dev/kvm device

打开终端,以管理员身份登录

sudo su

进入dev文件夹

cd /dev/

切换kvm模式

chmod 777 -R kvm

使用该命令提供适当的权限

sudo chmod 777 -R /dev/kvm

/dev/kvm权限被拒绝

[主板]在BIOS中设置VT(虚拟化技术),安装虚拟机