当前位置: 首页 > news >正文

ARM虚拟机安装OMV

OMV(OpenMediaVault)是基于 Debian GNU/Linux 的网络连接存储(network attached storage,NAS)解决方案。它包含 SSH、(S) FTP、SMB/CIFS、DAAP 媒体服务器、rsync、 BitTorrent 等很多种服务。它可用于 x86-64 和 ARM 平台。

在x86-64平台上,基于x86-64虚拟机安装OMV软件是相对容易的事情,例如使用VirtualBox创建一个x86-64虚拟机,参考官方的x86-64平台安装文档可以轻松搞定。但是基于ARM虚拟机则没有那么容易,因为在x86-64平台上,VirtualBox不支持创建ARM虚拟机,这时就需要用到QEMU了。

根据官方文档,在ARM平台上安装,需要Armbian镜像,这里选用通用的ARM64镜像,而不是用于特定ARM开发板例如树莓派等的镜像。

============================================================

操作流程(基于Ubuntu 24.04 LTS系统):

----------------------------------

安装QEMU:

sudo apt install qemu-system-arm

验证QEMU:

qemu-system-aarch64 -version

----------------------------

下载Armbian 24.2.1 Bookworm CLI(OMV不支持桌面环境,因此下载这个版本):

wget https://dl.armbian.com/uefi-arm64/archive/Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img.xz

解压Armbian镜像:

xz -kd Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img.xz

OMV系统盘和数据盘是分开的,并且要求系统盘可用空间大于4GB。

系统盘就是用Armbian镜像虚拟的硬盘,基本上已经没有多少可用空间了,因此需要先扩容。

给Armbian镜像增加8GB容量用于安装OMV等软件:

qemu-img resize Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img +8G

创建一个qcow2格式的虚拟硬盘作为OMV数据盘:

qemu-img create -f qcow2 omvdata.qcow2 16G

虚拟硬盘是动态分配大小的,因此创建完成后文件大小只有几百KB,不是8GB。

---------------------------

创建虚拟网桥和虚拟网卡:

sudo apt install iproute2(系统默认已经安装)

可选安装:brctl、tunctl、dhclient

sudo apt install bridge-utils

sudo apt install uml-utilities

sudo apt install isc-dhcp-client-ddns

创建虚拟网桥和虚拟网卡:

sudo ip link add br0 type bridge

sudo ip tuntap add dev tap0 mode tap

连接虚拟网桥和虚拟网卡:

sudo ip link set dev tap0 master br0

连接物理网卡(WiFi网卡需要配置4-address 模式支持WDS桥接)到虚拟网桥:

sudo iw dev wlx14cf92fe3d77 set 4addr on

sudo ip link set dev wlx14cf92fe3d77 master br0

启动虚拟网桥:

sudo ip link set dev br0 up

查看网桥连接的网卡:

sudo brctl show br0

清除物理网卡上的IP地址(同时也会清除路由):

sudo ip address flush wlx14cf92fe3d77 dynamic

使用DHCP方式给网桥分配IP(会自动配置网关和DNS):

sudo dhclient br0

或者给网桥配置静态IP,这种情况需要同时需要手动配置网关和DNS(否则无法连接外网):

sudo ip address flush wlx14cf92fe3d77 dynamic

sudo ip address add 192.168.2.99/24 dev br0

sudo ip route add default via 192.168.2.1 dev br0

sudo resolvectl dns br0 192.168.2.1 8.8.8.8

也可以使用brctl和tunctl命令配置网桥更简单:

sudo brctl addbr br0

sudo brctl stp br0 on

sudo tunctl -t tap0

sudo brctl addif br0 tap0

sudo iw dev wlx14cf92fe3d77 set 4addr on

sudo brctl addif br0 wlx14cf92fe3d77

sudo ip link set dev br0 up

sudo ip address flush wlx14cf92fe3d77 dynamic

sudo dhclient br0

使用无线网卡,桥接网络可能不稳定,DHCP获取IP时间也会长一些。如果连接中断,重新连接WiFi,检查网卡是否还连接网桥,重新配置IP地址。

网桥连接有线网卡会稳定一些:

sudo ip link add br0 type bridge

sudo ip tuntap add dev tap0 mode tap

sudo ip link set dev tap0 master br0

sudo ip link set dev enp4s0 master br0

sudo ip link set dev br0 up

也可以使用brctltunctl命令:

sudo brctl addbr br0

sudo brctl stp br0 on

sudo tunctl -t tap0

sudo brctl addif br0 tap0

sudo brctl addif br0 enp4s0

sudo ip link set dev br0 up

 

清除物理网卡上的IP(同时也清除路由),通过DHCP给网桥分配IP

sudo ip address flush enp4s0 dynamic

sudo dhclient br0

如果给网桥配置静态IP,需要同时配置默认路由和DNS(否则无法访问外网):

sudo ip address flush enp4s0 dynamic

sudo ip address add 192.168.2.99/24 dev br0

sudo ip route add default via 192.168.2.1 dev br0

sudo resolvectl dns br0 192.168.2.1 8.8.8.8

注:系统重启之后,这些虚拟网桥、虚拟网卡都没有了,需要再次配置。

配置好虚拟网桥和虚拟网卡之后,后面启动QEMU就可以使用这里配置的虚拟网卡tap0了。

-----------------------

启动Armbian系统,并使用上面准备好的镜像,数据盘和虚拟网卡:

sudo qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G -nographic -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd -drive file=Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img,if=virtio -drive file=omvdata.qcow2,if=virtio -net nic -net tap,ifname=tap0

需要注意的是,这里要指定BIOS,可以使用QEMU自带的BIOS,默认路径/usr/share/qemu-efi-aarch64/QEMU_EFI.fd。

如果在第一次启动之前就将系统镜像扩容,进入系统后根分区会自动扩容。如果根分区没有扩容,使用resize2fs命令扩容根分区:

resize2fs /dev/vda2

注:使用网桥比使用user网络或者user网络加端口转发启动QEMU,下面的操作要省事很多。

---------------------------------

以下操作在Armbian系统上执行:

第一次启动Armbian系统,根据提示创建root密码,并创建一个普通用户alpha:

配置完成后,系统已经自动分配了IP(跟网桥同一个网段,跟外网直通):

注:登录界面也可以看到IP地址(但这些IP信息可能是过时的),如果系统没有自动获取到IP,可以手动配置IP,并确保能ping通网桥IP,能连接外网。这时主机上root和新建的普通用户都可以通过ssh登录Armbian系统。

查看系统盘(vda)和数据盘(vdb)也都正常:

先安装两个工具软件:

sudo apt install vim

sudo apt install net-tools

查看系统的TCP端口,可以看到sshd服务已经打开:

netstat -antp

注:虽然sshd服务已经打开,但不要通过ssh连接安装OMV,否则可能安装不完整,安装完成后,进入OMV的web管理页面,左边栏目什么条目都没有。

安装OMV软件:

安装前的工作:

检查systemd-networkd.service,如果是指向/dev/null的符号连接,将其删除:

ls -al /etc/systemd/system/systemd-networkd.service

删除systemd-networkd.service文件:

rm /etc/systemd/system/systemd-networkd.service

修改armbian-ramlog.service服务文件:

vi /etc/systemd/system/sysinit.target.wants/armbian-ramlog.service

将默认的TimeoutStartSec=30sec

改为TimeoutStartSec=180sec

安装OMV keyring:

apt-get install --yes gnupg

wget --quiet --output-document=- https://packages.openmediavault.org/public/archive.key | gpg --dearmor --yes --output "/usr/share/keyrings/openmediavault-archive-keyring.gpg"

添加OMV官方的软件源:

cat <<EOF >> /etc/apt/sources.list.d/openmediavault.list

deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://packages.openmediavault.org/public sandworm main

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://downloads.sourceforge.net/project/openmediavault/packages sandworm main

## Uncomment the following line to add software from the proposed repository.

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://packages.openmediavault.org/public sandworm-proposed main

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://downloads.sourceforge.net/project/openmediavault/packages sandworm-proposed main

## This software is not part of OpenMediaVault, but is offered by third-party

## developers as a service to OpenMediaVault users.

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://packages.openmediavault.org/public sandworm partner

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://downloads.sourceforge.net/project/openmediavault/packages sandworm partner

EOF

OMV软件源也可以用清华大学的软件源:

cat <<EOF > /etc/apt/sources.list.d/openmediavault.list

deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/public sandworm main

deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/packages sandworm main

## Uncomment the following line to add software from the proposed repository.

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/public sandworm-proposed main

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/packages sandworm-proposed main

## This software is not part of OpenMediaVault, but is offered by third-party

## developers as a service to OpenMediaVault users.

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/public sandworm partner

# deb [signed-by=/usr/share/keyrings/openmediavault-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/OpenMediaVault/packages sandworm partner

EOF

安装OMV软件包:

export LANG=C.UTF-8

export DEBIAN_FRONTEND=noninteractive

export APT_LISTCHANGES_FRONTEND=none

apt-get update

apt-get --yes --auto-remove --show-upgraded \

--allow-downgrades --allow-change-held-packages \

--no-install-recommends \

--option DPkg::Options::="--force-confdef" \

--option DPkg::Options::="--force-confold" \

install openmediavault

执行这个命令之后,开始从OMV源下载软件版安装。

软件下载和安装需要较长时间,耐心等待安装完毕。

安装失败问题解决:

Failed to preset unit, unit /etc/systemd/system/systemd-networkd.service is masked.

/usr/bin/deb-systemd-helper: error: systemctl preset failed on systemd-networkd.service: No such file or directory

dpkg: error processing package openmediavault (--configure):

installed openmediavault package post-installation script subprocess returned error exit status 1

Processing triggers for libc-bin (2.36-9+deb12u4) ...

Processing triggers for rsyslog (8.2302.0-1) ...

Processing triggers for man-db (2.11.2-2) ...

Processing triggers for dbus (1.14.10-1~deb12u1) ...

Processing triggers for initramfs-tools (0.142) ...

update-initramfs: Generating /boot/initrd.img-6.6.16-current-arm64

Processing triggers for php8.2-cli (8.2.18-1~deb12u1) ...

Processing triggers for php8.2-fpm (8.2.18-1~deb12u1) ...

Processing triggers for php8.2-cgi (8.2.18-1~deb12u1) ...

Errors were encountered while processing:

openmediavault

E: Sub-process /usr/bin/dpkg returned an error code (1)

失败原因是/etc/systemd/system/systemd-networkd.service文件是指向/dev/null的软连接:

root@uefi-arm64:~# ls -al /etc/systemd/system/systemd-networkd.service

lrwxrwxrwx 1 root root 9 Feb 13 18:45 /etc/systemd/system/systemd-networkd.service -> /dev/null

解决办法是删除该文件,然后执行修复安装:

rm /etc/systemd/system/systemd-networkd.service

apt install -f

也可以在安装之前先删除这个文件,这样就不会有这个问题了。

安装最后的update-initramfs步骤需要花较长时间:

update-initramfs: Generating /boot/initrd.img-6.6.16-current-arm64

启动失败问题解决:

重启之后,查看TCP端口,并没有发现web服务(workbench)的80端口。

回头检查启动过程的日志,可以发现nginx.service服务启动失败:

[FAILED] Failed to start nginx.serv…server and a reverse proxy server.

See 'systemctl status nginx.service' for details.

失败原因是/var/log/nginx/error.log文件不存在,实际上/var/log/nginx目录不存在。

再往前看,还有两个失败:

一个是 systemd-networkd-wait-online.service启动失败:

[ *] Job systemd-networkd-wait-online.se…ice/start running (49s / no limit)

[FAILED] Failed to start systemd-ne…Wait for Network to be Configured.

See 'systemctl status systemd-networkd-wait-online.service' for details.

这个失败可以忽略。

另外一个是armbian-ramlog.service启动失败:

[ 58.738034] systemd[1]: armbian-ramlog.service: Main process exited, code=killed, status=15/TERM

[ 59.154114] systemd[1]: armbian-ramlog.service: Failed with result 'timeout'.

[FAILED] Failed to start armbian-ra… Armbian memory supported logging.

See 'systemctl status armbian-ramlog.service' for details.

这个失败原因是启动超时。

armbian-ramlog.service服务负责创建和恢复/var/log/nginx目录和日志,启动失败导致nginx日志目录和文件无法创建。

检查服务安装情况:

dpkg -s "nginx" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "apache2" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "samba" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "cron-apt" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "proftpd-basic" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "lighttpd" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

dpkg -s "unattended-upgrades" 2>/dev/null | awk -F": " '/^Status/ {print $2}'

这些服务需要在/var/log/目录创建子目录保存日志,而/var/log/目录的内容是保存在内存中的,是用zram内存区域虚拟的硬盘(Mounting /dev/zram1 as /var/log),重启之后数据丢失,需要重新创建子目录。/usr/lib/armbian/armbian-ramlog负责系统启动后自动创建这些子目录(以及从硬盘恢复日志数据),通过armbian-ramlog.service服务运行

解决办法:

armbian-ramlog.service服务启动需要一分多钟,默认30s无法完成启动,因此需要等待长一点时间(例如3分钟,如果改为0s,则不检测超时)。

修改armbian-ramlog.service服务文件:

vi /etc/systemd/system/sysinit.target.wants/armbian-ramlog.service

将默认TimeoutStartSec=30sec

改为TimeoutStartSec=180sec

保存后重启系统

armbian-ramlog.service服务启动时间也可以在安装OMV软件之前就修改

注:

如果在QEMU终端修改,默认vi窗口大小只有23行76列,看起来不舒服甚至显示错乱,可以通过stty命令修改终端大小,例如:

stty rows 36 cols 140

需要注意的是,窗口大小不要超过虚拟终端行列大小(主机上可以通用stty -a查看),不然vi窗口显示也会错乱。

打开OMV管理页面(workbench):

系统重启之后,在登录界面可以看到系统IP,以及OMV管理web的用户名和密码:

使用浏览器打开这个web页面:

可以使用IPv4地址:

也可以使用IPv6地址(需要将IPv6地址放在方括号内):

输入用户名和密码登录后,可以看到WEB管理页面:

配置普通用户ssh登录:

安装完OMV软件后,Armbian系统第一次启动时创建的普通用户不能ssh登录(在安装OMV之前是可以登录的)。

可以通过OMV管理界面,编辑用户信息,将用户加入_ssh组,保存并应用之后就可以了。

配置SMB服务:

配置SMB服务有几个主要的步骤:

1、使用OMV数据盘创建文件系统并挂载。

2、在上面挂载的文件系统上创建共享文件夹。

3、配置共享文件夹权限。

4、用前面创建的共享文件夹配置SMB/CIFS服务共享。

5、在用户管理页面,创建用户,给用户配置访问共享文件夹的权限。

6、通过系统创建的用户,需要使用smbpasswd命令将用户配置为samba用户。可以使用pdbedit -L命令查询samba用户列表。

打开存储器配置界面,创建EXT4文件系统,选择OMV数据盘(/dev/sdb),保存:

然后挂载该文件系统,保存并应用:

成功之后可以看到挂载的文件系统:

打开共享文件夹页面创建共享文件夹

配置好共享文件夹的名称、路径、权限,保存并应用:

成功后可以看到刚才创建的共享文件夹:

配置共享文件夹权限,给用户和用户组增加读写权限,保存并应用:

进入SMB/CIFS服务,配置共享:

选择刚才创建的共享文件夹,保存并应用:

成功之后,在SMB/CIFS共享页面,可以看到刚才创建的SMB共享文件夹:

可以在OMV系统上使用netstat -antp命令看到smbd服务端口139已经开启。

此时,在文件管理器输入smb://192.168.3.191可以打开SMB服务器,看到共享文件夹,但是无法访问该文件夹。

将用户添加到sambashare组,保存并应用:

但这个时候仍然无法打开共享文件夹,并且使用smbclient命令浏览共享文件夹也可能会失败:

smbclient --user=alpha -L 192.168.3.191

Password for [WORKGROUP\alpha]:

session setup failed: NT_STATUS_LOGON_FAILURE

系统创建的用户,无法通过WEB配置访问SMB服务,需要在系统上通过smbpasswd命令将用户配置为samba用户才可以:

sudo smbpasswd alpha

执行该命令后,用户可以正常打开OMV共享目录了。

通过OMV的用户管理创建的用户,按照上面的配置,直接可以访问SMB共享文件夹。

例如创建一个名为samba的用户,用户组为sambashare,保存并应用:

在用户权限管理页面,配置用户访问SMB共享文件夹的权限,保存并应用,就可以访问SMB共享文件夹了:

电脑打开smb://192.168.3.191访问共享文件夹:

连接在同一个网络手机也可以访问SMB共享文件夹,通过文件管理的网络邻居扫描网络邻居,可以找个OMV主机,使用前面配置的samba用户(alpha或者samba两个用户),就可以打开共享文件夹了。

========================================================

测试定位问题过程参考:

下载Armbian镜像(qemu-uboot-arm64镜像):

从https://www.armbian.com/download/入口,选择qemu,aarch64,就可以找到qemu-uboot-arm64镜像了。

下载Armbian Noble Minimal (U-boot bin):

https://github.com/armbian/os/releases/download/24.5.0-trunk.558/Armbian_24.5.0-trunk.558_Qemu-uboot-arm64_noble_current_6.6.30_minimal.u-boot.bin.xz

下载Armbian Noble Minimal (QCOW2):

https://github.com/armbian/os/releases/download/24.5.0-trunk.558/Armbian_24.5.0-trunk.558_Qemu-uboot-arm64_noble_current_6.6.30_minimal.img.qcow2.xz

下载uefi-arm64镜像:

从https://www.armbian.com/download/入口,选择ARM,aarch64,找到uefi-arm64镜像:

下载Armbian 24.2.1 Bookworm CLI(OMV不支持桌面环境,因此下载这个版本):

https://dl.armbian.com/uefi-arm64/archive/Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img.xz

或者

https://dl.armbian.com/uefi-arm64/archive/Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16_minimal.img.xz

启动Armbian系统(uefi-arm64镜像):

先解压Armbian镜像:

xz -kd Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img.xz

带GUI启动Armbian系统:

qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G-drive file=Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img,if=virtio -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd

运行命令后会显示QEMU窗口,将View菜单切换到serial0项可以看到系统输出:

不带GUI启动Armbian系统:

qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G -drive file=Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img,if=virtio -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd -nographic

启动uefi-arm64镜像需要指定-bios参数,可以使用qemu安装的BIOS,默认路径/usr/share/qemu-efi-aarch64/QEMU_EFI.fd。

启动虚拟加上端口转发,以便可以在主机上访问虚拟机上的服务

qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G -drive file=Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img,if=virtio -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd -nographic -nic user,model=virtio-net-pci,hostfwd=tcp::20022-:22,hostfwd=tcp::20080-:80,hostfwd=tcp::20139-:139

增加数据盘:

先创建一个qcow2格式的虚拟硬盘:

qemu-img create -f qcow2 omvdata.qcow2 16G

把这个硬盘加到系统上:

qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G -drive file=Armbian_24.2.1_Uefi-arm64_bookworm_current_6.6.16.img,if=virtio -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd -nographic -nic user,model=virtio-net-pci,hostfwd=tcp::20022-:22,hostfwd=tcp::20080-:80,hostfwd=tcp::20139-:139 -drive file=omvdata.qcow2,if=virtio

创建SMB共享目录,使用端口转发的方式不能访问在主机访问共享目录。

使用连接网桥的虚拟网卡启动系统:

sudo qemu-system-aarch64 -machine virt -cpu cortex-a57 -smp 8 -m 8G -drive file=Armbian_24.2.1_U

efi-arm64_bookworm_current_6.6.16.img,if=virtio -bios /usr/share/qemu-efi-aarch64/QEMU_EFI.fd -nographic -drive file=omvdata.qcow2,if=virtio -net nic -net tap,ifname=tap0

启动Armbian系统(qemu-uboot-arm64镜像):

TODO

===================================================================

参考:

Armbian(默认用户名/密码):https://docs.armbian.com/

OMV硬件要求:https://docs.openmediavault.org/en/stable/prerequisites.html

OMV安装指导:https://docs.openmediavault.org/en/stable/installation/index.html

OMV安装指导:https://docs.openmediavault.org/en/stable/installation/on_debian.html

OMV 版本:Releases — openmediavault 7.x.y documentation

OMV清华源:https://mirrors.tuna.tsinghua.edu.cn/help/openmediavault/

OMV 编译与安装:一起NAS吧!开源NAS系统Openmediavault 编译与安装过程 - 哔哩哔哩

修改vi窗口大小:https://superuser.com/questions/598877/vi-only-show-16-lines-how-to-show-full-screen

zRAM 内存压缩机制:https://cloud.tencent.com/developer/article/2335437

systemd和TimeoutStartSechttps://www.freedesktop.org/software/systemd/man/latest/systemd.service.html

虚拟网桥和虚拟网卡配置:Documentation/Networking - QEMU

虚拟网桥和虚拟网卡配置:https://blog.csdn.net/qq_38505969/article/details/129645659

虚拟网桥和虚拟网卡配置:https://unix.stackexchange.com/questions/714921/adding-a-physical-ethernet-interface-to-kvm-qemu-bridge

相关文章:

ARM虚拟机安装OMV

OMV(OpenMediaVault)是基于 Debian GNU/Linux 的网络连接存储&#xff08;network attached storage&#xff0c;NAS&#xff09;解决方案。它包含 SSH、(S) FTP、SMB/CIFS、DAAP 媒体服务器、rsync、 BitTorrent 等很多种服务。它可用于 x86-64 和 ARM 平台。 在x86-64平台上&…...

【协议开发系列】梳理关于TCP和UDP两种协议的区别和使用场景

起源 前二天项目上在核对外部对接服务的五元组列表的时候&#xff0c;有一位客户提问对于同样的服务同时支持tcp和udp二种方式&#xff0c;有什么优点和缺点&#xff0c;应该如何选择&#xff1f;这个问题突然让我愣了一下&#xff0c;确实好久没有“温故”了&#xff0c;相关…...

vue blob实现自定义多sheet数据导出到excel文件

背景&#xff1a;最近vue项目遇到一个需求&#xff0c;就是需要将多个表格分成不同sheet页并导出&#xff0c;之前的工具类只能导出一个sheet页&#xff0c;所以在原有的基础上&#xff0c;调整一下&#xff0c;让它支持多sheet导出。 vue blob文件流&#xff0c;这个肯定要的…...

Python—面向对象小解(3)

一、多态 多态指的是一类事物的多中形态 相同的方法&#xff0c;产生不同的执行结果 运算符 * 的多态 int int 加法计算 str str 字符串拼接 list list 列表的数据合并 在python中可以使用类实现一个多态效果 在python中使用重写的方式实现多态 &#xff08;1&#xff09;定…...

Nginx超时时间

Nginx是一款自由、开源、高性能的HTTP和反向代理服务器&#xff0c;它可以通过不同的设置来提高网站的性能和安全性。其中&#xff0c;设置Nginx超时时间非常重要&#xff0c;因为它将直接影响网站的响应速度和用户体验。本文将从多个方面详细阐述Nginx超时时间的设置方法与注意…...

Imgs,GT,Edge,Gradient_all,Gradient_Foreground

保存一下&#xff1a; 做个记录&#xff1a; import cv2 import os import numpy as np# 对整张图片做canny检测 得到纹理图 def canny_all(input_path, output_path):# 遍历文件夹中的所有文件for filename in os.listdir(input_path):# 构造完整的文件路径image_path os.p…...

自学成才Flutter 弹性布局、线性布局

本文我们要介绍 Flutter 中布局 Widget&#xff0c;包括弹性布局、线性布局 流式布局和层叠布局。 Flutter中文网 Flutter开发 一、弹性布局--Flex Flex 类似 Android 中的 FlexboxLayout&#xff0c;和 Expanded 配合使用可以实现子Widget 按照一定比例来分配父容器空间。 使…...

Part 3.1 深度优先搜索

深度优先搜索&#xff08;DFS&#xff09;&#xff0c;即按照深度优先的顺序搜索的算法。 深度优先搜索一般使用栈来实现。 [USACO1.5] 八皇后 Checker Challenge 题目描述 一个如下的 6 6 6 \times 6 66 的跳棋棋盘&#xff0c;有六个棋子被放置在棋盘上&#xff0c;使得…...

前端Vue小兔鲜儿电商项目实战Day03

一、Home - 整体结构搭建和分类实现 1. 页面结构 ①按照结构新增5个组件&#xff0c;准备最简单的模板&#xff0c;分别在Home模块的入口组件中引入 src/views/Home/components/ HomeCategory.vue HomeBanner.vue HomeNew.vue HomeHot.vue HomeProduct.vue <script …...

ORACLE 查询SQL优化

1 使用EXPLAIN PLAN 使用EXPLAIN PLAN查看查询的执行计划&#xff0c;这可以帮助你理解查询是如何被Oracle执行的。基于执行计划&#xff0c;你可以确定是否存在索引缺失、不必要的全表扫描等问题。 以下是几种使用EXPLAIN PLAN的方法&#xff1a; 使用EXPLAIN PLAN FOR: 你可以…...

Ansible03-Ansible Playbook剧本详解

目录 写在前面5. Ansible Playbook 剧本5.1 YAML语法5.1.1 语法规定5.1.2 示例5.1.3 YAML数据类型 5.2 Playbook组件5.3 Playbook 案例5.3.1 Playbook语句5.3.2 Playbook1 分发hosts文件5.3.3 Playbook2 分发软件包&#xff0c;安装软件包&#xff0c;启动服务5.3.3.1 任务拆解…...

Qt-qrencode生成二维码

Qt-qrencode开发-生成二维码&#x1f4c0; 文章目录 Qt-qrencode开发-生成二维码&#x1f4c0;[toc]1、概述&#x1f4f8;2、实现效果&#x1f4bd;3、编译qrencode&#x1f50d;4、在QT中引入编译为静态库的QRencode5、在Qt中直接使用QRencode源码6、在Qt中使用QRencode生成二…...

长安链使用Golang编写智能合约教程(三)

本篇主要介绍长安链Go SDK写智能合约的一些常见方法的使用方法或介绍 资料来源&#xff1a; 官方文档官方示例合约库 官方SDK接口文档 教程一&#xff1a;智能合约编写1 教程二&#xff1a;智能合约编写2 一、获取参数、获取状态、获取历史记录的方法解析 注意&#xff01; …...

Vercel deploy- Nextjs project error-URL link-env variable

Vercel deploy- Nextjs project error-URL link-env variable Error Check Database URL Check next-auth URL NEXTAUTH_URLhttps://yourappname.vercel.app/ 依次排查可能性 Application error: a server-side exception has occurred (see the server logs for more in…...

Java | Leetcode Java题解之第123题买卖股票的最佳时机III

题目&#xff1a; 题解&#xff1a; class Solution {public int maxProfit(int[] prices) {int n prices.length;int buy1 -prices[0], sell1 0;int buy2 -prices[0], sell2 0;for (int i 1; i < n; i) {buy1 Math.max(buy1, -prices[i]);sell1 Math.max(sell1, b…...

Ubuntu22.04之扩展并挂载4T硬盘(二百三十三)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…...

Redis实现延迟队列

最近用到一个延迟消息的功能&#xff0c;第一时间想到使用MQ或者MQ的插件&#xff0c;因为数据量不大&#xff0c;所以尝试使用Redis来实现了&#xff0c;毕竟Redis也天生支持类似MQ的队列消费&#xff0c;所以&#xff0c;在这里总结了一下Redis实现延迟消息队列的方式。 一、…...

如何准确查找论文数据库?

在学术研究过程中&#xff0c;查找相关论文是获取最新研究成果、支持自己研究的重要途径。准确查找论文数据库不仅可以节省时间&#xff0c;还能确保找到高质量的学术资源。本文将介绍一些有效的方法和策略&#xff0c;帮助您准确查找论文数据库。 1. 选择合适的数据库 不同的…...

翻译《The Old New Thing》- What a drag: Dragging a virtual file (IStream edition)

What a drag: Dragging a virtual file (IStream edition) - The Old New Thing (microsoft.com)https://devblogs.microsoft.com/oldnewthing/20080319-00/?p23073 Raymond Chen 2008年03月19日 拖拽虚拟文件&#xff08;IStream 版本&#xff09; 上一次&#xff0c;我们看…...

【FPGA】Verilog语言从零到精通

接触fpga一段时间&#xff0c;也能写点跑点吧……试试系统地康康呢~这个需要耐心但是回报巨大的工作。正原子&&小梅哥 15_语法篇&#xff1a;Verilog高级知识点_哔哩哔哩_bilibili 1Verilog基础 Verilog程序框架&#xff1a;模块的结构 类比&#xff1a;c语言的基础…...

unity打包的WebGL部署到IIS问题

部署之后会出错&#xff0c;我遇到的有以下几种&#xff1b; 进度条卡住不动 明明已经部署到了IIS上&#xff0c;为什么浏览网页的时候还是过不去或者直接报错。 进度条卡住不动的问题其实就是wasm和data的错误。 此时在浏览器上按F12进入开发者模式查看错误&#xff08;下图…...

GPT-4o:人工智能的新里程碑

GPT-4o&#xff0c;作为OpenAI最新推出的人工智能技术&#xff0c;无疑在人工智能领域掀起了新一轮的浪潮。这款新型的语言模型不仅继承了GPT系列的核心优势&#xff0c;更在多个方面实现了突破性的进展。以下&#xff0c;我们将从版本间的对比分析、GPT-4o的技术能力以及个人整…...

发现一个ai工具网站

网址 https://17yongai.com/ 大概看了下&#xff0c;这个网站收集的数据还挺有用的&#xff0c;有很多实用的ai教程。 懂ai工具的可以在这上面找找灵感。...

第二十五章新增H5基础(以及视频~兼容)

1.HTML5中新增布局标签 HTML5新增了页眉&#xff0c;页脚&#xff0c;内容块等文档结构相关标签&#xff0c;可以使文档结构更加清晰明了。 1.新增的结构标签 1、<header>标签 定义文档或者文档中内容块的页眉。通常可以包含整个页面或一个内容区域的标题&#xff0c…...

[英语单词] production quality

Our goal is to implement a production quality switch platform that supports standard management interfaces and opens the forwarding functions to programmatic extension and control. 说在openswitch的文档里有说这两词&#xff0c;含义是产品质量。是production修…...

windows安装nodeJs,以及常用操作

1. 官网(Node.js — Run JavaScript Everywhere (nodejs.org))下载想要安装的node版本 的安装包完成安装 2.环境变量设置&#xff1a; 系统变量&#xff1a; Path新增&#xff1a;D:\Program Files\nodejs (node安装目录) 3.设置淘宝源&#xff1a; npm config set registr…...

MySql part1 安装和介绍

MySql part1 安装和介绍 数据 介绍 什么是数据库&#xff0c;数据很好理解&#xff0c;一般来说数据通常是我们所认识的 描述事物的符号记录&#xff0c; 可以是数字、 文字、图形、图像、声音、语言等&#xff0c;数据有多种形式&#xff0c;它们都以经过数字化后存入计算机…...

SpringBoot打war包并配置外部Tomcat运行

简介 由于其他原因&#xff0c;我们需要使用SpringBoot打成war包放在外部的Tomcat中运行,本文就以一个案例来说明从SpringBoot打war包到Tomcat配置并运行的全流程经过 环境 SpringBoot 2.6.15 Tomcat 8.5.100 JDK 1.8.0_281 Windows 正文 一、SpringBoot配置打war包 第一步&a…...

2024.5.31每日一题

LeetCode 找出缺失的重复数字 题目链接&#xff1a;2965. 找出缺失和重复的数字 - 力扣&#xff08;LeetCode&#xff09; 题目描述 给你一个下标从 0 开始的二维整数矩阵 grid&#xff0c;大小为 n * n &#xff0c;其中的值在 [1, n2] 范围内。除了 a 出现 两次&#xff…...

Oracle 数据库 varchar2 从 4000 扩展到 32k

Oracle 数据库 varchar2 从 4000 扩展到 32k 0. 引言1. 扩展 varchar2 支持长度2. 测试 0. 引言 今天来个项目需求&#xff0c;有1个字段的存储内容大概1万字。 当然其中1个方法是将这个字段的内容切分成几个字段&#xff0c;还有1个方法就是将 varchar2 默认支持 4000 的能力…...

postgressql——事务提交会通过delayChkpt阻塞checkpoint(9)

事务提交会通过delayChkpt阻塞checkpoint Postgresql事务在事务提交时&#xff08;执行commit的最后阶段&#xff09;会通过加锁阻塞checkpoint的执行&#xff0c;尽管时间非常短&#xff0c;分析为什么需要这样做&#xff1a; 首先看提交堆栈 #1 0x0000000000539175 in Co…...

开发者工具-sources(源代码选项)

一、概要说明 源代码面板从视觉效果上分为三个区域&#xff1a;菜单区、内容区、监听区。 菜单区里面有5个子分类&#xff1a; 网页(Page)&#xff1a;指页面源&#xff0c;包含了该页面中所有的文件&#xff0c;即使多个域名下的文件也都会展示出来&#xff0c;包括iframe…...

没有 rr 头的 kamailio 路由脚本

分享下笔者最近编写的 kamailio 路由脚本 不用 rr 模块&#xff0c;因为有些 sip 协议栈不支持 rr 头处理 sip 注册直接回 200 OK&#xff0c;这部分目前不是重点更换 contact 头&#xff0c;换成 kamailio 自己目前只支持 sip transport 为 udp&#xff0c;以后可能支持 tcp&…...

mysql 分区

目标 给一个表&#xff08;半年有800万&#xff09;增加分区以增加查询速度 约束 分区不能有外键否则会报错 https://blog.csdn.net/yabingshi_tech/article/details/52241034 主键 按照时间列进行分区 https://blog.csdn.net/winerpro/article/details/135736454 参看以…...

在龙芯安装docker compose

安装过程报错&#xff1a;pynacl无法安装 原因&#xff1a;未知 解决尝试&#xff1a;单独安装pynacl 执行&#xff1a;pip install pynacl 报错&#xff1a; 再次执行dockerscompose撒谎啥 少了头文件 dev&#xff0c;表示c编译器有问题 python是c编写的 喵的 搞了半天是我…...

纯C++做多项式拟合

一、多项式拟合用途 当前有一组对应的x、y数据&#xff0c;希望通过这些数据点做出近似的多项式曲线&#xff1a;YnX^2mXc 其中多项式最高次数可调&#xff0c;返回各个参数及曲线的拟合度R^2 二、函数实现 参数中的order为设置的多项式最高次次数&#xff0c;coefficients为…...

vulnhub靶场之FunBox-9

一.环境搭建 1.靶场描述 Its a box for beginners, but not easy. Gather careful !!! Hint: Dont waste your time ! Every BruteForce-Attack at all ports can be stopped after 1500 trys per account. Enjoy the game and WYSIWYG ! This works better with VirtualBox…...

C# 变量与参数详解

在C#编程中&#xff0c;变量和参数是构建程序逻辑的基础。本篇博客将深入探讨C#中的变量作用域、参数传递方式、以及一些高级特性&#xff0c;如in、ref、out参数&#xff0c;params修饰符&#xff0c;可选参数和命名参数等。 变量作用域 在C#中&#xff0c;变量的作用域分为…...

CentOS7.9部署安装OpenGauss 5.0.2企业版

1、更新系统: yum update -y 2、更改主机名&#xff1a; hostnamectl set-hostname opendb01 3、关闭透明页&#xff1a; echo never > /sys/kernel/mm/transparent_hugepage/enabled echo never > /sys/kernel/mm/transparent_hugepage/defrag# 加入开机自启动 echo …...

java基础-chapter15(io流)

io流&#xff1a;存储和读取数据的解决方案 I:input O:output io流的作用&#xff1a;用于读写数据&#xff08;本地文件,网络&#xff09; io流按照流向可以分为&#xff1a; 输出流&#xff1a;程序->文件 输入流&#xff1a;文件->程序 io流按照操作文件…...

mysql去除重复数据

需求描述 doc表有很多重复的title,想去除掉重复的记录 表结构 CREATE TABLE doc (id INT PRIMARY KEY,title VARCHAR(255),content TEXT );去重SQL -- 创建临时表 CREATE TEMPORARY TABLE temp_doc AS SELECT * FROM doc WHERE 10;-- 插入唯一的记录&#xff08;每个title最…...

MySQL基础索引知识【索引创建删除 | MyISAM InnoDB引擎原理认识】

博客主页&#xff1a;花果山~程序猿-CSDN博客 文章分栏&#xff1a;MySQL之旅_花果山~程序猿的博客-CSDN博客 关注我一起学习&#xff0c;一起进步&#xff0c;一起探索编程的无限可能吧&#xff01;让我们一起努力&#xff0c;一起成长&#xff01; 目录 一&#xff0c;索引用…...

SJ601-II垂直法阻燃性能测试仪

一、主要用途 主要用于有阻燃要求的纺织品如机织物、针织物、涂层产品、层压产品、服装织物、装饰织物、帐篷织物、窗帘幕布、建材装饰织物等材料阻燃性能的测定。并用于窗帘幕布阻燃等级的测定和防火封堵材料的型式过证。 二、仪器特征 1、脉冲自动点火&#xff0c;安全可靠…...

瑞吉外卖项目学习笔记(二)后台系统的员工管理业务开发

一、完善登录功能 1.1 问题分析 1.2 代码实现 package com.itheima.reggie.filter;//这是一个过滤器类 //登录检查过滤器import com.alibaba.fastjson.JSON; import com.itheima.reggie.common.R; import lombok.extern.slf4j.Slf4j; import org.slf4j.Logger; import org.slf…...

Unity OutLine 模型外描边效果

效果展示&#xff1a; 下载链接...

CRLF注入漏洞

1.CRLF注入漏洞原理 Nginx会将 $uri进行解码&#xff0c;导致传入%0a%0d即可引入换行符&#xff0c;造成CRLF注入漏洞。 执行xss语句 2.漏洞扩展 CRLF 指的是回车符(CR&#xff0c;ASCII 13&#xff0c;\r&#xff0c;%0d) 和换行符(LF&#xff0c;ASCII 10&#xff0c;\n&am…...

理解接口回调及其在 RabbitMQ 中的实际运用

介绍 接口回调是一种常见的编程模式&#xff0c;它在异步编程中发挥着重要作用。本文将通过一个简单的示例介绍接口回调的概念和原理&#xff0c;并探讨它在 RabbitMQ 中的实际应用。 接口回调的概念 接口回调是一种编程模式&#xff0c;用于在异步编程中实现回调机制。它允许…...

大模型日报2024-05-31

大模型日报 2024-05-31 大模型资讯 Anthropic揭示Claude大语言模型的内部机制 摘要: 研究人员将大语言模型的活动模式与特定概念关联起来&#xff0c;并展示了他们可以通过调整这些模式来控制AI模型的行为。 Mistral AI开源新款代码语言模型Codestral 摘要: 人工智能初创公司Mi…...

HarmonyOS 鸿蒙DevEco:导入无法运行提示Sync failed

场景&#xff1a;导入官网下载的案例后导入发现无法运行模拟机&#xff0c;Notifications提示Sync failed... 解决&#xff1a;查看Cause发现是版本问题&#xff0c;通过修改相关内容来解决该问题 1、打开案例地址找到hvigor文件夹 2、打开hvigor-config.json5&#xff0c;将&…...

kafka的安装

windows下kafka的安装 【Kafka】Windows下安装Kafka&#xff08;图文记录详细步骤&#xff09;_windows安装kafka-CSDN博客 kafka生产消息 kafka消费消息...