当前位置:   article > 正文

qemu 安装ubuntu22.04虚拟机 -纯命令行-可ssh-带网络-编译安装 linux kernel-编译安装 kernel module

qemu 安装ubuntu22.04虚拟机 -纯命令行-可ssh-带网络-编译安装 linux kernel-编译安装 kernel module

1,预备系统盘数据

1.1 下载光盘


注意需要 liver-server

$ wget https://releases.ubuntu.com/22.04.4/ubuntu-22.04.4-live-server-amd64.iso

1.2 挂载并拷贝


 

  1. $ sudo mkdir /mnt/iso_ubuntu-22.04.4-live-server-amd64
  2. $ sudo mount ubuntu-22.04.4-live-server-amd64.iso /mnt/iso_ubuntu-22.04.4-live-server-amd64/ -o loop
  3. $ cp -r /mnt/iso_ubuntu-22.04.4-live-server-amd64 ./iso_ubuntu-220404/

确认文件文件路径

  1. $ ls ./iso_ubuntu-22.04.4-live-server-amd64/casper/initrd
  2. $ ls ./iso_ubuntu-22.04.4-live-server-amd64/casper/vmlinuz


后变安装时会用到。


2,预备构建 qemu 的依赖

2.1 预备普通依赖

  1. sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients virtinst bridge-utils virt-manager virt-viewer
  2. sudo apt-get install libpixman-1-dev


如果系统中没有 ninja,则需要安装
检验:
 

$ ninja --version


2.2 预备网络 -net user 依赖

//slirp 为用户网络配置
 

  1. sudo apt-get install libslirp-dev
  2. sudo apt-get install samba

安装好后可以重启一下
sudo reboot


3,下载 qemu 并编译

3.1 下载源码

  1. $ git clone https://github.com/qemu/qemu.git
  2. $ cd qemu
  3. $ mkdir build
  4. $ cd build


3.2 配置编译选项

3.2.1 无配置选项配置

$ ../configure

3.3.2 带选项配置

$ ../configure --enable-slirp --enable-slirp-smbd --smbd=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00 --enable-kvm --enable-debug --target-list="riscv32-softmmu riscv64-softmmu x86_64-softmmu"

--enable-slirp: 为 -net user,载安装ubuntu时会自动配置网络,并安装成功后,可以ssh访问本虚拟机
--target-list: 指定虚拟的的cpu arch 类型,省略此,会全部编译,时间为3倍长。


提前标注:
开启 -net user 模式的启动配置(安装完后的重启):
 

$ ./qemu/build/qemu-system-x86_64 -hda ubuntu.img -m 1024 -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00

3.3.3 编译 qemu

  1. $ make
  2. $ ls


4,安装虚拟机系统

4.1 加入相关组

  1. sudo usermod -aG kvm $USER
  2. sudo usermod -aG libvirt $USER

4.2 创建硬盘

创建虚拟机的磁盘映像

$ ./qemu/build/qemu-img create ubuntu-220404-kernel-00.qcow2 -f qcow2 50G


4.3 安装虚拟机系统

  1. sudo ./qemu/build/qemu-system-x86_64 -m 32768M -smp 6 -boot c -cpu host \
  2. -hda ubuntu-220404-kernel-00.qcow2 \
  3. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00 \
  4. --enable-kvm --nographic -append console=ttyS0 \
  5. -cdrom ubuntu-22.04.4-live-server-amd64.iso \
  6. -kernel ./ubuntu-220404/iso_ubuntu-22.04.4-live-server-amd64/casper/vmlinuz \
  7. -initrd ./ubuntu-220404/iso_ubuntu-22.04.4-live-server-amd64/casper/initrd

安装完成后关掉当前终端,重开一个终端。

4.4 启动新虚拟机

  1. sudo usermod -aG kvm $USER \
  2. && sudo usermod -aG libvirt $USER \
  3. && sudo ./qemu/build/qemu-system-x86_64 -m 32768M -smp 6 -boot c -cpu host \
  4. -hda ubuntu-220404-kernel-00.qcow2 --enable-kvm --nographic \
  5. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00,hostfwd=tcp::2222-:22

 

直接登陆进来,也可以考虑 ssh进来。

4.5 ssh 链接虚拟机


启动选项 hostfwd=tcp::2222-:22      是为 ssh 预备端口


其中heihei是虚拟机中的用户名;而 10.208.15.202 是宿主机的ip地址
这样,只要能够ssh进宿主机的机器,也能ssh进 heihei的虚拟机,pwd用heihei的。

  1. sudo ./qemu/build/qemu-system-x86_64 -m 32768M -smp 6 -boot c -cpu host \
  2. -hda ubuntu-220404-kernel-00.qcow2 --enable-kvm --nographic \
  3. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00,hostfwd=tcp::2222-:22

至此可以正常使用 虚拟机了。
而且可以在任何机器上 ssh 进虚拟机:


hostfwd=tcp::2222-:22      是为 ssh 预备端口

ssh 链接虚拟机:
ssh -p 2222 user-virtual@host-ip

实例:
 

$ ssh -p2222 heihei@10.208.15.202


5. 虚拟机中编译安装 linux kernel

5.1,下载对应版本的linux kernel源代码

5.1.1 apt 下载对应发型版的 linux kernel

  1. $ apt install linux-source
  2. $ ls /usr/src/

linux-source-5.15.0.tar.bz2 


可以看到多了一个文件夹和软连接文件,指向文件夹内的linux kernel 源码打包文件

拷贝到自己的工作目录下:

  1. $ cp linux-source-5.15.0.tar.bz2 ~/kernel_debug/

查看本机kernel版本:
    uname -a

$ uname  -a


Linux heihei-server 5.15.0-112-generic #122-Ubuntu SMP
所以下载对应版本: 5.15 linux kernel

5.2 编译 debug 版本的vmlinux并安装

5.2.1 解压kernel


 

$ tar -xvjf linux-source-5.15.0.tar.bz2

5.2.2 安装依赖

在虚拟机中安装配置和编译 Linux kernel 的依赖包:

  1. $ sudo apt-get update
  2. # 配置的依赖
  3. $ sudo apt install libncurses-dev
  4. $ sudo apt install build-essential
  5. $ sudo apt install flex bison
  6. # 编译的依赖
  7. $ sudo apt-get install bc
  8. $ sudo apt-get install dwarves
  9. $ sudo apt-get install libssl-dev
  10. $ sudo apt-get install binutils
  11. $ sudo apt-get install libelf-dev

5.2.3 配置 kernel

查看本机kernel配置文件

$ ls /boot/


 将发行版中的configxxx文件,拷贝至解压好的 kernel 目录下:

 配置kernel 开启 debug info,以便可以调试
 

$ make menuconfig

 进入初始界面:

选中:

kernel hacking ->

compile-time checks and compiler options ->

compile the kernel with debug info

如下图,移动到本项后敲空格键

然后移动到 <Save> 回车并保存为 .config

然后一层层  <Exit> 出来

确认验证保存正确:

$ grep -rn  DEBUG_INFO .config

修改一下 .config

CONFIG_SYSTEM_TRUSTED_KEYS="debian/canonical-certs.pem"
CONFIG_SYSTEM_REVOCATION_KEYS="debian/canonical-revoked-certs.pem"

都设置成空字符串,如上图。

否则会报错:

make[1]: *** No rule to make target 'debian/canonical-certs.pem', needed by 'certs/x509_certificate_list'.  Stop.

 反正自己玩,安全性在发行版了再说吧。

5.2.3 编译kernel

安装依赖:

  1. sudo apt-get install libssl-dev
  2. sudo apt-get install binutils
  3. sudo apt-get install libelf-dev

内存够大:
 

  1. $ make -j
  2. $ sudo make modules_install
  3. $ sudo make install

编译完成:

安装内核模块:

安装内核:

更新引导加载程序:

$ sudo update-grub

 重新启动

$ sudo reboot

/*************************

5.3 开启debug虚拟机模式

未完待续。。。

这块再整理一篇新的log吧

5.3.1 开机debug

  1. sudo ./qemu/build/qemu-system-x86_64 -m 32768M -smp 6 -boot c -cpu host \
  2. -hda ubuntu-220404-kernel-00.qcow2 --enable-kvm --nographic \
  3. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00,hostfwd=tcp::2222-:22 \
  4. -s -S -append "nokaslr init=/init console=ttyAMA0"


会卡在这里不动,

5.3.2 gdb 链接qemu

宿主机中:
 

  1. $ gdb
  2. (gdb) show configuration # 关注--host以及--target参数
  3. (gdb) file ./vmlinux # 加载kernel符号表
  4. (gdb) target remote :1234 # 链接qemu中的gdb-server
  5. (gdb) b start_kernel # 设置断点
  6. (gdb) c

***********************/

6,编译安装用户自定义 kenrel module

6.1,示例代码

6.2,编译安装

6.3,验证效果

7, 遇到的问题汇总

Could not find '/usr/sbin/smbd', please install it
$ sudo apt-get install samba


防火墙设置:
检查虚拟机的防火墙设置,确保没有规则阻止 SSH 连接。你可以暂时禁用防火墙来测试连接:
sudo ufw disable
或者,确保 22 端口(或你为 SSH 配置的其他端口)是开放的:
sudo ufw allow 22

查看 sshd 端口:
sudo cat /etc/ssh/sshd_config | grep Port

查看 启动 重启 sshd 的命令

sudo systemctl status sshd
sudo systemctl start sshd
sudo systemctl restart sshd

私用命令备忘:

装机:

  1. sudo ./qemu/build/qemu-system-x86_64 -m 196608M -smp 15 -boot c -cpu host \
  2. -hda ubuntu-220404-kernel-00.qcow2 \
  3. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00 \
  4. --enable-kvm --nographic -append console=ttyS0 \
  5. -cdrom ubuntu-22.04.4-live-server-amd64.iso \
  6. -kernel ./ubuntu-220404/iso_ubuntu-22.04.4-live-server-amd64/casper/vmlinuz \
  7. -initrd ./ubuntu-220404/iso_ubuntu-22.04.4-live-server-amd64/casper/initrd

开机:

  1. sudo ./qemu/build/qemu-system-x86_64 -m 196608M -smp 12 -boot c -cpu host \
  2. -hda ubuntu-220404-kernel-00.qcow2 --enable-kvm --nographic \
  3. -net nic -net user,smb=/home/hipper/ex_ubuntu-22.4.4-live-server_qemu/smba_00,hostfwd=tcp::2222-:22

host 中需要执行的安装:
 

  1. sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients virtinst bridge-utils virt-manager virt-viewer
  2. sudo apt-get install libpixman-1-dev


虚拟机中需要执行的安装:

  1. sudo apt install linux-source && \
  2. sudo apt install libncurses-dev && \
  3. sudo apt install build-essential && \
  4. sudo apt install flex bison && \
  5. sudo apt-get install libssl-dev && \
  6. sudo apt-get install binutils && \
  7. sudo apt-get install libelf-dev
  8. sudo apt-get install openssh-server
  9. sudo apt-get install vim
  10. sudo apt-get install bc
  11. sudo apt-get update
  12. sudo apt-get install dwarves

bash shell 配色:

vim ~/.bashrc
最后边加入如下内容:

  1. alias ls='ls --color=always'
  2. alias ll='ls -all --color=always'
  3. #alias dir='dir --color=always'
  4. #alias vdir='vdir --color=auto'
  5. alias grep='grep --color=always'
  6. alias fgrep='fgrep --color=always'
  7. alias egrep='egrep --color=always'
  8. export PS1="\e[0;35m\u\e[0;34m@\e[0;32m\h:\e[0;34m\w\e[0;38m$ "
  9. export LS_COLORS="rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=00:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.zst=01;31:*.tzst=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=01;31:*.wim=01;31:*.swm=01;31:*.dwm=01;31:*.esd=01;31:*.jpg=01;35:*.jpeg=01;35:*.mjpg=01;35:*.mjpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.webp=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.m4a=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.oga=00;36:*.opus=00;36:*.spx=00;36:*.xspf=00;36:"

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Li_阴宅/article/detail/743485
推荐阅读
相关标签
  

闽ICP备14008679号