FreeBSD RISCV 在QEME中实践-网络配置

在前一篇文章中,我们一起进行了FreeBSD RISCV 在QEME中实践

现在,让我们配置好网络吧!

先上结论:用默认配置启动即可,网络就加载好了,只是不能ping罢了。因为不能ping,以为网络没通,走了一些弯路。这个坑帮大家踩过,大家就放心走吧!

调试坎坷历程

一开始不知道默认网络配置好了,到处看文档找解决方案。

看官方wiki:riscv - FreeBSD Wiki

 当时就疑惑,wiki中给的Quick Start 快速上手例子,如果网不通,这个例子就是失败的啊!当然最后我们知道网络本身就是通的,这个快速上手例子就是一个成功的例子。但是当时不知道,于是继续看文档,选择了更复杂的组网模式:tap组网模式!

tap组网模式实践

首先加载tap 内核

# 加载分流器内核模块(如果未加载):

kldload if_tuntap

FreeBSD13版本里应该是已经加载了,所以会提醒:kldload: can't load if_tuntap: module already loaded or in kernel

 配置网络

主机上的配置如下:

ifconfig tap0 create up
ifconfig bridge0 create up
ifconfig bridge0 addm em0 addm tap0 # em0 might depends of your ethernet devices

# 删除配置的接口用destroy
ifconfig bridge0 destroy
ifconfig tap0 destroy

核心思想就是配置一个tap0分流端口,并把物理端口和tap0端口都放入一个桥(bridge0)里,让二者可以通信。 

配置出来效果如下:

tap0: flags=8943<UP,BROADCAST,RUNNING,PROMISC,SIMPLEX,MULTICAST> metric 0 mtu 1500
	options=80000<LINKSTATE>
	ether 58:9c:fc:10:ff:ac
	inet 192.168.0.247 netmask 0xffffff00 broadcast 192.168.0.255
	groups: tap
	media: Ethernet autoselect
	status: no carrier
	nd6 options=29<PERFORMNUD,IFDISABLED,AUTO_LINKLOCAL>
bridge0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> metric 0 mtu 1500
	ether 58:9c:fc:10:ff:c9
	inet 10.0.2.100 netmask 0xffffff00 broadcast 10.0.2.255
	inet 10.0.2.2 netmask 0xffffff00 broadcast 10.0.2.255
	inet 192.168.0.248 netmask 0xffffff00 broadcast 192.168.0.255
	id 00:00:00:00:00:00 priority 32768 hellotime 2 fwddelay 15
	maxage 20 holdcnt 6 proto rstp maxaddr 2000 timeout 1200
	root id 00:00:00:00:00:00 priority 32768 ifcost 0 port 0
	member: em0 flags=143<LEARNING,DISCOVER,AUTOEDGE,AUTOPTP>
	        ifmaxaddr 0 port 1 priority 128 path cost 2000000
	member: tap0 flags=143<LEARNING,DISCOVER,AUTOEDGE,AUTOPTP>
	        ifmaxaddr 0 port 10 priority 128 path cost 2000000
	member: wlan0 flags=143<LEARNING,DISCOVER,AUTOEDGE,AUTOPTP>
	        ifmaxaddr 0 port 9 priority 128 path cost 370370
	groups: bridge
	nd6 options=9<PERFORMNUD,IFDISABLED>

当然由于当时对tap口还不理解,实践中还手动多配置了一些ip地址,比如给bridge0口配置10.0.2 和192.168.0 两个网段。实际上这也是不需要的。

qemu启动命令里的网络设置

-netdev user,id=net0,ipv6=off,hostfwd=tcp::8022-:22

网络类型为user ,就是普通用户网络模式。这个模式配置简单,功能简单,效率低。 ostfwd=tcp::8022-:22表示将服务器的8022端口映射到QEMU虚拟机里的22端口。

-netdev tap,ifname=tap0,script=no,id=net0 -device virtio-net-device,netdev=net0

网络类型为tap,就是分流模式,可以组建任意网络突破,功能强大,效率高,要求对网络比较了解,配置难度大。而且tap模式还需要root账户权限,不适合传统FreeBSD的管理员习惯。

-netdev tap,ifname=tap0,script=no,id=net0 -device virtio-net-device,netdev=net0

网路这块一开始很困惑,因为一开始对qemu的网络拓扑不清楚,而且虚拟机里默认是无法ping通外面的,这样一直误以为网络不通,走了弯路。

后来看文档:Documentation/Networking - QEMU  

才知道客户机默认无法ping通外面。

运行qemu

第一个是默认网络,第二个是tap网络。

qemu-system-riscv64 -machine virt -m 2048M -smp 2 -nographic \
    -bios /usr/local/share/opensbi/lp64/generic/firmware/fw_jump.elf \
    -kernel /usr/local/share/u-boot/u-boot-qemu-riscv64/u-boot.bin \
    -drive file=FreeBSD-15.0-CURRENT-riscv-riscv64.raw,format=raw,id=hd0 -device virtio-blk-device,drive=hd0 \
    -netdev user,id=net0,ipv6=off,hostfwd=tcp::8022-:22 -device virtio-net-device,netdev=net0
qemu-system-riscv64 -machine virt -m 2048M -smp 2 -nographic -bios /usr/local/share/opensbi/lp64/generic/firmware/fw_jump.elf -kernel /usr/local/share/u-boot/u-boot-qemu-riscv64/u-boot.bin -drive file=FreeBSD-14.0-RELEASE-riscv-riscv64.raw,format=raw,id=hd0 -device virtio-blk-device,drive=hd0 -netdev tap,ifname=tap0,script=no,id=net0,ipv6=off,hostfwd=tcp::8022-:22 -device virtio-net-device,netdev=net0

ssh登录

 QEMU启动后就出现了login交互界面,可以直接用root登录,默认root没有密码。

在宿主主机也可以使用命令ssh 127.0.0.1 -p 8022 登录客户端。注意需要在虚拟机打开sshd服务,用命令:

service sshd onestart

还需要创建个普通账户方便登录,命令:adduser 

创建好用户之后就可以使用ssh登录了。

最终选择了user用户模式组网,就是因为它简单而且不需要root权限。

user用户组网模式实践

整个过程非常简单命令如下:

# 安装所需的软件包,root账户下
pkg install opensbi u-boot-qemu-riscv64 qemu glib
 
# 以下都在个人用户下
# 下载映像
wget -c http://mirrors.ustc.edu.cn/freebsd/releases/VM-IMAGES/14.0-RELEASE/riscv64/Latest/FreeBSD-14.0-RELEASE-riscv-riscv64.raw.xz
# 解压映像
xz --decompress  FreeBSD-14.0-RELEASE-riscv-riscv64.raw.xz
# 扩展映像
truncate -s 10G FreeBSD-14.0-RELEASE-riscv-riscv64.raw
 
# 启动qemu模拟器 2核 2G内存
qemu-system-riscv64 -machine virt -m 2048M -smp 2 -nographic -bios /usr/local/share/opensbi/lp64/generic/firmware/fw_jump.elf -kernel /usr/local/share/u-boot/u-boot-qemu-riscv64/u-boot.bin -drive file=FreeBSD-14.0-RELEASE-riscv-riscv64.raw,format=raw,id=hd0 -device virtio-blk-device,drive=hd0 -netdev user,id=net0,ipv6=off,hostfwd=tcp::8022-:22 -device virtio-net-device,netdev=net0

启动后尝试pkg安装软件

root登录后,发现系统里pkg都没有,需要上网下载安装,但是默认的地址,反正我这里是报错的。

尝试用ports安装pkg

下载ports

 fetch https://download.freebsd.org/snapshots/riscv/riscv64/14.1-PRERELEASE/ports.txz

解压ports

tar -xzvf ports.txz

当然如果解压目录没有到/usr/ports,可以手工挪一下位置。

编译安装pkg

root@freebsd:/usr/ports # cd ports-mgmt/pkg
root@freebsd:/usr/ports/ports-mgmt/pkg # make install clean

速度较慢,大约几个小时后,终于编译安装好了。但是pkg update还是报错:

Unable to update repository FreeBSD
Error updating repositories!
从网上查了下,发现目前大约是没有现成的pkg包,如果安装的话,就需要自己ports编译安装,或者交叉编译安装。

附录

qemu的拓扑图

Tap分流网络


分流网络后端使用主机中的分流网络设备。它提供了非常好的性能,可以配置为创建几乎任何类型的网络拓扑。不幸的是,它需要在主机中配置该网络拓扑,这往往因您使用的操作系统而异。一般来说,它还要求您具有root权限。

-netdev tap,id=mynet0

 怪不得当时普通用户配置tap的时候报错。

FreeBSD pkg 镜像配置

# To disable this repository, instead of modifying or removing this file,
# create a /usr/local/etc/pkg/repos/FreeBSD.conf file:
#
#   mkdir -p /usr/local/etc/pkg/repos
#   echo "FreeBSD: { enabled: no }" > /usr/local/etc/pkg/repos/FreeBSD.conf
可惜现在没有riscv的镜像,别说镜像,我连主服务器上也没找到(主服务器直接给我解析到镜像了)

关于FreeBSD riscv qemu映像

riscv qemu映像放置在snapshot目录,这个目录国内大部分镜像站点都没有,或者即使有,里面也没有放映像文件。 所以只能从官方的几个站点找,下载速度慢。

FreeBSD pkg和 download网址

FreeBSD pkg网址:http://pkg.freebsd.org/

但是这个网址会自动解析到镜像:pkg0.kwc.FreeBSD.org 

这个pkg站里没有riscv的pkg 包

安装盘download网址:download.FreeBSD.org 

这个网址也是自动解析到日本了。

这个网址里有iso等FreeBSD的安装镜像,有 riscv的安装盘。

中科大镜像:https://mirrors.ustc.edu.cn/freebsd/releases/

 163镜像:https://mirrors.163.com/freebsd/

FreeBSD riscv pkg临时站:http://beefy7.nyi.freebsd.org/

 这个站连不上,不知道是不是废弃了。

 FreeBSD riscv支持相关文档

riscv - FreeBSD Wiki  QEMU网络配置:Documentation/Networking - QEMU

调试

执行kldload if_tuntap时报错:


kldload: can't load if_tuntap: module already loaded or in kernel

文心一言说:kldload: can't load if_tuntap: module already loaded or in kernel 这个错误表明 if_tuntap 模块已经加载到内核中了,或者它本身就是内核的一部分(也就是说,它是静态编译进内核的,而不是作为一个可加载模块)。 

qemu启动后默认路由是10.0.2.2 

Destination        Gateway            Flags     Netif Expire
default            10.0.2.2           UGS      vtnet0

虚拟机自己的ip是10.0.2.15
给bridge0 配置上10.0.2.2 ip ,竟然能ping通,能解析dns,但是无法上网。

能ping通10.0.2.2 但是无法ping通外网。

后来才明白,默认就是无法ping通外网,其实这时候网络已经通了。

为了qemu能上网,尝试-netdev tap,ifname=tap0

qemu-system-riscv64 -machine virt -m 2048M -smp 2 -nographic -bios /usr/local/share/opensbi/lp64/generic/firmware/fw_jump.elf -kernel /usr/local/share/u-boot/u-boot-qemu-riscv64/u-boot.bin -drive file=FreeBSD-14.0-RELEASE-riscv-riscv64.raw,format=raw,id=hd0 -device virtio-blk-device,drive=hd0 -netdev tap,ifname=tap0,script=no,id=net0 -device virtio-net-device,netdev=net0

但是报错:qemu-system-riscv64: -netdev tap,ifname=tap0,script=no,id=net0: could not open /dev/tap0: Permission denied


先搁置,去看文档,发现前面无法ping通是正常现象。

后来也从手册里看到了,使用tap的话,需要root账户,而我们使用的不是root账户,怪不得会报错Permission denied 。不习惯用root账户启动,所以放弃tap组网,还是使用user用户组网。

pkg update报错

Bootstrapping pkg from pkg+http://pkg.FreeBSD.org/FreeBSD:14:riscv64/quarterly, please wait...
pkg: Error fetching http://pkg.FreeBSD.org/FreeBSD:14:riscv64/quarterly/Latest/pkg.txz: Not Found
A pre-built version of pkg could not be found for your system.
Consider changing PACKAGESITE or installing it from ports: 'ports-mgmt/pkg'.
直接去http://pkg.freebsd.org/

发现被重定向到日本的镜像了,而且该服务器里没有riscv64的相关软件(没有这个目录FreeBSD:14:riscv64),我晕。而且我找不到有riscv包的站.....

下载映像的网址这里有:download.FreeBSD.org

默认也是跑到日本镜像了,不过这里有snapshots/  ,也就是有riscv的版本。重新下载15的zfs版本试试:https://download.freebsd.org/snapshots/VM-IMAGES/15.0-CURRENT/riscv64/Latest/FreeBSD-15.0-CURRENT-riscv-riscv64-zfs.raw.xz

希望这个15版本里有pkg的地址。 15版本估计是zfs的缘故,无法成功启动。暂时放弃15版本。

尝试下载ports

fetch https://download.freebsd.org/snapshots/riscv/riscv64/14.1-PRERELEASE/ports.txz

解压 tar -xzvf ports.txz 

尝试用ports安装pkg

cd /usr/ports/ports-mgmt/pkg 

make install clean

ports编译安装pkg很慢

 riscv就是很慢的啦!

怪不得大家都会用交叉编译.....明天就学

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/596827.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

linux文件夹权限查看以及设置

1.linux给文件夹和子文件夹开权限 2.查询当前文件夹权限

java 泛型题目讲解

泛型的知识点 泛型仅存在于编译时期&#xff0c;编译期间JAVA将会使用Object类型代替泛型类型&#xff0c;在运行时期不存在泛型&#xff1b;且所有泛型实例共享一个泛型类 public class Main{public static void main(String[] args){ArrayList<String> list1new Arra…

ASP.NET网上图书订阅系统的设计

摘 要 网上图书订阅系统基于 Microsoft SQL Server 2000和ASP.NET平台&#xff0c;以C#为编程语言开发,实现了网上图书预订和借阅&#xff0c;订阅信息查询&#xff0c;图书和用户信息的修改&#xff0c;借阅排行和新到图书的查询等功能&#xff0c;这样不但可将管理员从繁重…

Linux基础之makefile/make

目录 一、背景 二、makefile和make的讲解 2.1 使用方法 2.2 伪目标文件 2.3 文件的属性以及属性的更新 2.4 makefile的自动推导 一、背景 这里会提及为什么要使用makefile和make&#xff0c;以及他们是什么和作用。 会不会写makefile&#xff0c;从一个侧面说明了一个人是…

宝兰德通过广东教育行业信创适配认证,拓展教育信创生态圈

近日&#xff0c;由宝兰德自主研发的多款中间件产品通过广东省教育行业信创适配中心的适配测试。测试表明&#xff0c;宝兰德四款中间件产品&#xff08;分布式缓存软件V3.0、应用服务器软件V9.5、消息中间件软件 V2.1、Web服务器软件V3.1&#xff09; 与当前主流国产操作系统统…

memory consistency

memory consistency model 定义了对于programmer和implementor来说&#xff0c;访问shared memory system的行为&#xff1b; 对于programmer而言&#xff0c;他知道期望值是什么&#xff0c; 知道会返回什么样的数据&#xff1b;&#xff1b; 对于implementro而言&#xff0c;…

数据结构——链表专题1

文章目录 一、移除链表元素二、反转链表三、合并两个有序链表四、链表的中间节点五、环形链表的约瑟夫问题六、分割链表 一、移除链表元素 原题链接&#xff1a;移除链表元素 一个解法是遍历原链表&#xff0c;将与val相等的结点抛弃&#xff0c;链接后一个结点 另一个解法是…

corefBERT论文阅读

CorefBERT是清华大学团队发表的&#xff0c;继SpanBERT之后另一针对共指消解的BERT模型。共指消解任务对于文本理解、智能问答等其他NLP子任务起到至关重要的作用。 为了提高语言模型的共指推理能力&#xff0c;一个简单的解决方案是使用有监督的共指解析数据在bert等模型进行…

论文笔记ColdDTA:利用数据增强和基于注意力的特征融合进行药物靶标结合亲和力预测

ColdDTA发表在Computers in Biology and Medicine 的一篇一区文章 突出 • 数据增强和基于注意力的特征融合用于药物靶点结合亲和力预测。 • 与其他方法相比&#xff0c;它在 Davis、KIBA 和 BindingDB 数据集上显示出竞争性能。 • 可视化模型权重可以获得可解释的见解。 …

Linux网络部分——DNS域名解析服务

目录 1. 域名结构 2. 系统根据域名查找IP地址的过程 3.DNS域名解析方式 4.DNS域名解析的工作原理【☆】 5.域名解析查询方式 6.搭建主从DNS域名服务器 ①初始化操作主服务器和从服务器&#xff0c;安装BIND软件 ②修改主服务器的主配置文件、区域配置文件、区域数…

【c1】数据类型,运算符/循环,数组/指针,结构体,main参数,static/extern,typedef

文章目录 1.数据类型&#xff1a;编译器&#xff08;compiler&#xff09;与解释器&#xff08;interpreter&#xff09;&#xff0c;中文里的汉字和标点符号是两个字节&#xff0c;不能算一个字符&#xff08;单引号&#xff09;2.运算符/循环&#xff1a;sizeof/size_t3.数组…

基于java的CRM客户关系管理系统的设计与实现(论文 + 源码 )

【免费】基于Java的CRM客户关系管理系统的设计和实现.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89273409 基于Java的CRM客户关系管理系统的设计与实现 摘 要 随着互联网的高速发展&#xff0c;市场经济的信息化&#xff0c;让企业之间的竞争变得&#xff0…

复写零(双指针)

下面的解法需要手动画图&#xff0c;举例去体会&#xff0c;只有自己手动去做了&#xff0c;才会有所收获。 class Solution {public void duplicateZeros(int[] arr) {int n arr.length;//先找到最后一个元素的位置;//至于为什么要直接先设dest 为-1&#xff0c;这是经过研究…

CNN笔记详解

CNN(卷积神经网络) 计算机视觉&#xff0c;当你们听到这一概念的是否好奇计算机到底是怎样知道这个图片是什么的呢&#xff1f;为此提出了卷积神经网络&#xff0c;通过卷积神经网络&#xff0c;计算机就可以识别出图片中的特征&#xff0c;从而识别出图片中的物体。看到这里充…

分布式与一致性协议之ZAB协议(四)

ZAB协议 ZooKeeper是如何选举领导者的。 首先我们来看看ZooKeeper是如何实现成员身份的&#xff1f; 在ZooKeeper中&#xff0c;成员状态是在QuorumPeer.java中实现的&#xff0c;为枚举型变量 public enum ServerState { LOOKING, FOLLOWING, LEADING, OBSERVING }其实&…

为何美国多IP服务器是全自动内容采集站的最佳选择?

为何美国多IP服务器是全自动内容采集站的最佳选择? 在建设全自动内容采集站时&#xff0c;选择合适的服务器至关重要。而在众多选项中&#xff0c;美国多IP服务器被认为是最佳选择&#xff0c;究竟为何呢?本文将从多个方面进行深入探讨。 为何美国多IP服务器是全自动内容采集…

分享8000网剧资源

兄弟们&#xff0c;前段时间搞短剧&#xff0c;收集了8500多部网剧资源。搞了整整两个月就赚3块两毛八&#xff0c;电费都不够。还不如进厂打螺丝。果断放弃这项目。 资源在手里面也没啥用。分享出来&#xff0c;大家看着玩。 有其他好的网络项目也可以分享分享。也可也一起…

真希望我父母读过这本书的笔记(二)

系列文章目录 真希望我父母读过这本书的笔记&#xff08;一&#xff09; 真希望我父母读过这本书的笔记&#xff08;二&#xff09; 文章目录 系列文章目录PART 5 培养心理健康的孩子亲子关系决定心理健康互动及来回交流如何开始交流互看游戏交流恐惧症 若遇棘手之际&#xff0…

9.Admin后台系统

9. Admin后台系统 Admin后台系统也称为网站后台管理系统, 主要对网站的信息进行管理, 如文字, 图片, 影音和其他日常使用的文件的发布, 更新, 删除等操作, 也包括功能信息的统计和管理, 如用户信息, 订单信息和访客信息等. 简单来说, 它是对网站数据库和文件进行快速操作和管…

[Flutter]创建一个私有包并使用

在Flutter中创建一个自己的私有组件&#xff08;通常称为包或库&#xff09;&#xff0c;并通过Dart的包管理工具pub进行使用。 一、创建一个新的Flutter包 1.使用命令行创建 使用Flutter命令行工具来创建一个新的包&#xff1a; $ flutter create --templatepackage my_pri…