M1Mac开启x86_64命令行archlinux虚拟机的最佳实践(qemu)

news/2024/7/8 1:34:33

categories: [Tips]
tags: Linux MacOS

写在前面

UTM 虚拟机可以卸载了, 命令行才是永远滴神, M1 MacBook Air 又能再战了!

之前一直用 UTM 的虚拟化开启 x86_64 的 Linux 虚拟机的, 但是我发现 UTM 好像不是必须的, 只要有qemu 就可以了, 下面就看看如何不通过图形界面前端(UTM)开启虚拟化支持, 这里主要用到的软件就是 iterm, Mac 下最强的终端模拟器.

准备工作

brew

最强包管理器, 安装

brew install qemu

下载 qcow2 格式的 archlinux 虚拟机磁盘文件

下载链接:

archlinux-images-latest安装包下载_开源镜像站-阿里云;

这里要注意, 这个虚拟机开启之后是需要密码登录的, 参考:

  • Arch Linux / arch-boxes · GitLab;
  • qcow2 image password ? / Newbie Corner / Arch Linux Forums;

用户名: arch

密码: arch

配置 ★ \bigstar

#!/usr/bin/env bash

if [ $# -ne 1 ]; then
	echo "USAGE: $0 disk"
	echo " e.g.: $0 Archlinux.qcow2"
	exit 1
fi

if [ ! -f $1 ]; then
	echo "could not open $1 : no such file"
	exit 1
fi

nohup qemu-system-x86_64 \
	-m 2G \
	-smp cores=3,threads=1,sockets=1,maxcpus=3 \
	-display none \
	-nographic \
	-drive file=$1,if=virtio,cache=none \
	-nic user,hostfwd=tcp::60022-:22 \
	-accel tcg \
	-cpu qemu64 \
	-machine q35 \
	-D archlinux-vm.log \
	-monitor tcp:127.0.0.1:60023,server,nowait &

下面详细解释一下脚本中的一些参数:

  • 使用方法就是脚本名./run.sh archlinux.qcow2 默认用nohup 执行, log 输出到archlinux-vm.log 中, 启动的BOOT提示在nohup.out

  • -m: 内存, 默认单位是 MB, 可以指定为2G

  • -smp: CPU 核数, 设置需要参考下面的公式:

    qemu-system-x86_64: Invalid CPU topology: product of the hierarchy must match maxcpus:

    sockets (1) * dies (1) * cores (2) * threads (2) != maxcpus (2)

  • -display: 显示设置, 默认的话会开一个新的窗口, 应该是 MacOS 下的 cocoa 窗口, 这个其实类似于 UTM 界面的设置, 我感觉没必要, 就关闭了

    -display none
    select display backend type
    The default display is equivalent to
    “-display cocoa”

  • -nographic: 不显示图形化, 将内容重定向到 IO

    disable graphical output and redirect serial I/Os to console

  • -drive: 指定磁盘文件, 这里就用镜像站下载的 qcow2 文件即可, 使用 virtio 开启网卡虚拟化, 并且禁用缓存(wiki 说的, 不知道为什么)

  • -nic: 网卡配置, 设置端口转发, 用于之后的 ssh 连接, 将客户机(虚拟机)的 22 端口暴露到宿主机(物理机)的60022 端口(Mac 需要开启防火墙)

  • -accel: 硬件加速, Mac 仅 tcg 模式可用

  • -cpu: qemu64 型号

  • -machine: 默认就是 q35

  • -D: 日志

  • -monitor: 监视器, 用于命令行操控虚拟机, 并可以在虚机运行中修改某些虚拟机配置的参数, 具体可以参考:

    QEMU Monitor — QEMU documentation;

    Qemu Monitor;(中文)

ssh 连接

一般来说, 开启之后只要不报错, 就可以静候佳音了, 在 CPU 占用率降低之后, 虚拟机就开起来了, 此时可以用:

lsof  -iTCP:60022

检查端口监听情况, 然后连接:

ssh arch@127.0.0.1 -p 60022

monitor 连接

nc 127.0.0.1 60023 # 端口需要和配置中的保持一致

其他踩坑

(可能遇到的问题) 安装包时提示签名有问题

[SOLVED] Problem with pacman update - Signature is unknown trust / Newbie Corner / Arch Linux Forums;

sudo rm -rf /etc/pacman.d/gnupg
pacman-key --init
pacman-key --populate archlinux

ssh连接

ssh 连接提示: kex_exchange_identification: read: Connection reset by peer

参考:

ssh - How can I fix “kex_exchange_identification: read: Connection reset by peer”? - Stack Overflow;

关闭全局代理/防火墙试试


http://lihuaxi.xjx100.cn/news/1615903.html

相关文章

ubuntu20.04 vins-fusion 运行记录

过程记录 环境: ubuntu20.04 opencv4.2.0(此次使用) 3.3.1(其他程序在使用) vins-fusion vision_opencv 1.下载VINS-Fusion和cv_bridge,并进行修改,方便使用opencv4.2.0和对应的cv_bridge。 mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src…

机器人命令表设计

演算命令 CLEAR 将数据 1 上被指定的编号以后的变数的内容,以及数据 2 上仅被指定的个数都清除至 0。 INC 在被指定的变数内容上加上 1。 DEC 在被指定的变数内容上减掉 1。 SET 在数据 1 上设定数据 2。 ADD 将数据 1 和数据 2 相加,得出的结果保存在数…

【Power BI】Power BI 入门指南:版本、下载和报表创建的步骤

文章目录 一、前言二、了解 Power BI 版本三、下载 Power BI Desktop四、如何开始使用 Power BI Desktop五、在 Power BI Desktop 中创建报表六、文末总结 一、前言 Power BI 是微软于 2013 年推出的产品,为一款商业智能与数据可视化工具。它通过引人注目的视觉效果…

BAT学习——计算当前路径下指定格式文件的MD5值,将文件名与MD5值写入文本

将以下内容粘贴到bat脚本中,双击运行,生成MD5.txt文件,需要其他格式,修改循环中的.rar 多个格式使用or分开 *.rar or *.bat脚本内容 echo off setlocal enabledelayedexpansionrem 设置输出文件名 set "outputFileMD5.txt&…

SLAM从入门到精通(camera数据读取)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 实际ros开发的时候,现场有很多特征都可以用来进行采集和标定。比如说地面,对于外资企业或者管理比较规范的企业来说&#x…

OpenCV项目开发实战--详细介绍如何进行图像平移和旋转含原理讲解+实现源码

如今,图像编辑变得越来越流行,因为手机具有这种内置功能,可以让您对图像进行裁剪、旋转和执行更多操作。在这篇博文中,我们将使用 OpenCV 探索图像转换和图像旋转。 基本图像转换操作 图像平移和旋转是图像编辑中最基本的操作之一。两者都属于更广泛的仿射变换类别。因此…

React之事件机制与事件绑定

一,时间机制 #是什么 React基于浏览器的事件机制自身实现了一套事件机制,包括事件注册、事件的合成、事件冒泡、事件派发等 在React中这套事件机制被称之为合成事件 #合成事件(SyntheticEvent) 合成事件是 React模拟原生 DOM…

MySQL建表操作和用户权限

1.创建数据库school,字符集为utf8 mysql> create database school character set utf8; 2.在school数据库中创建Student和Score表 mysql> create table school.student( -> Id int(10) primary key, -> Stu_id int(10) not null, -> C_n…