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

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

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

相关文章

推荐一款开源电子签章/电子合同系统

文章目录 前言一、项目介绍二、项目地址三、技术架构四、代码结构介绍五、功能模块六、功能界面首页面手写签名面板电子印章制作数字证书生成 总结 前言 大家好&#xff01;我是智航云科技&#xff0c;今天为大家分享一个免费开源的电子签字系统。 一、项目介绍 开放签电子签…

【Python】如何使用 Python 自动发送每日电子邮件报告

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

详解Spring IoCDI(二)

目录 承接上文&#xff1a;详解Spring IoC&DI &#xff08;一&#xff09; 1.IoC详解 1.1方法注解Bean 1.2方法注解要配合类注解使用 1.3定义多个对象 1.4重命名Bean 1.5扫描路径 2.DI详解 2.1DI与IoC的关系 2.2属性注入 2.3构造方法注入 2.4Setter注入 2.5 三…

【Endnote】如何在word界面加载Endnote

如何在word界面加载Endnote 方法1&#xff1a;方法2&#xff1a;从word入手方法3&#xff1a;从CWYW入手参考 已下载EndNote,但Word中没有显示EndNote&#xff0c;应如何加载显示呢&#xff1f; 方法1&#xff1a; 使用EndNote的Configure EndNote.exe 。 具体步骤为&#x…

内网安全:横向传递攻击(PTH || PTK || PTT 哈希票据传递)

内网安全&#xff1a;横向传递攻击. 横向移动就是在拿下对方一台主机后&#xff0c;以拿下的那台主机作为跳板&#xff0c;对内网的其他主机再进行后面渗透&#xff0c;利用既有的资源尝试获取更多的凭据、更高的权限&#xff0c;一步一步拿下更多的主机&#xff0c;进而达到控…

理解AdaBoost算法:简单流程概述(一)【流程理解、无数学推导】

什么是AdaBoost 算法&#xff1f; AdaBoost&#xff08;Adaptive Boosting&#xff09;算法&#xff0c;全称为 自适应提升 &#xff0c;是 一种在机器学习中用作集成方法的提升技术 。它之所以被称为自适应提升&#xff0c;因为每个实例的权重会重新分配&#xff0c;错误分类…

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

题目&#xff1a; 题解&#xff1a; #define max(a, b) ((a) < (b) ? (b) : (a))int maxProfit(int* prices, int pricesSize) {int buy1 -prices[0], sell1 0;int buy2 -prices[0], sell2 0;for (int i 1; i < pricesSize; i) {buy1 max(buy1, -prices[i]);sell…

解决:【无法安装“vue.volar“扩展,因为它与当前 VIsual Studio Code 版本不兼容(版本 1.80.0)】

目录 问题复现问题分析解决步骤1、进入VSCode插件市场&#xff0c;搜索Vue.volar2、点击搜索结果&#xff0c;进入详情页面3、下载.vsix文件完成后&#xff0c;用解压软件打开 4、复制package.json文件&#xff0c;修改vscode版本5、保存package.json文件&#xff0c;并更新.v…

【NPS】微软NPS配置802.1x,验证域账号,动态分配VLAN(有线网络篇)

上两篇中介绍了如何配置NPS和在WLC上如何配置802.1X来实现验证域账号和动态分配VLAN&#xff0c;802.1x协议作为一种成熟的身份验证框架&#xff0c;不仅适用于无线网络&#xff0c;同样也适用于有线网络环境。这里我们将介绍如何在有线网络中部署802.1x认证&#xff0c;以验证…

Visual Studio的桌面快捷方式图标不显示

1.问题描述 以下以Visual Studio 2019举例&#xff0c; 正常图标&#xff1a; 但是当前Visual Studio的桌面快捷方式图标不显示了&#xff1f; 2.问题原因分析 Visual Studio 2019桌面快捷方式图标不显示可能由以下几个原因造成&#xff1a; 图标缓存问题&#xff1a;Windo…

Spring boot 集成thymeleaf

Spring boot 集成thymeleaf 背景 自己通过Spring boot集成通义千问实现了一个智能问答系统。Spring boot集成通义千问已经完成&#xff0c;现在需要做一个简单的页面展示&#xff0c;作为一个八年没有摸过前端的后端开发人员&#xff0c;不得不又拿起了html和thymeleaf。 Sp…

笔记-docker基于ubuntu22.04安装Jitsi Meet

背景 利用JitsiMeet打造一个可以在线会议的环境&#xff0c;根据躺的坑&#xff0c;做个记录 参考 JitsMeet部署安装说明 开始操作 环境 docker run -it --name ubuntu22.04 ubuntu:22.04 /bin/bash问题 1、安装 openjdk-11 apt install openjdk-11-jdk配置环境变量&…

探索 Ollama: 你的本地 AI 助手

本期推荐的开源项目是 Ollama&#xff0c;它是一款本地大模型运行工具&#xff0c;可以帮助用户轻松下载和运行各种大型语言模型&#xff08;LLM&#xff09;&#xff0c;而无需将数据上传到云端。以下是关于 Ollama 的介绍以及安装和使用教程&#xff1a; Ollama 是什么&#…

深入分析 Android Service (四)

文章目录 深入分析 Android Service (四)1. 使用 Messenger 进行通信2. 详细示例&#xff1a;使用 Messenger 进行通信2.1 创建 MessengerService2.2 在 Activity 中绑定服务并发送消息 3. 使用 AIDL 进行进程间通信3.1 定义 AIDL 接口3.2 实现 AIDL 接口3.3 在客户端绑定 AIDL…

ABAP 自动填充DATAX

问题 经常做BAPI开发的时候&#xff0c;SAP有个什么DATAX的表对应DATA&#xff0c;每次都要写一堆成对的DATA和DATAX&#xff0c;不然就会修改失败&#xff0c;每次复制粘贴也有点麻烦而且容易漏 代码实现 群里大姑刚好写了段代码用来匹配这个DATA和DATAX格式的&#xff0c…

k8s集群的存储卷、pvc和pv

目录 简介 简介 PV 全称叫做 Persistent Volume&#xff0c;持久化存储卷。它是用来描述或者说用来定义一个存储卷的&#xff0c;这个通常都是由运维工程师来定义。 PVC 的全称是 Persistent Volume Claim&#xff0c;是持久化存储的请求。它是用来描述希望使用什么样的或者说…

Spring Cloud | 客户端 “负载均衡器“ : Ribbon

目录: 1. 什么是 "负载均衡" ? ( 通过 "负载均衡" 可以将 "用户请求" "分发" 到 不同的服务器&#xff0c;以此来提高 "性能" 和 "可靠性" )2. "负载均衡" 的 分类 &#xff1f;3. 认识 Ribbon :3.1 R…

[香橙派 AIpro] 性能强劲的昇腾AI开发板,应用广泛,性能出众,遥遥领先!

[香橙派 AIpro] 性能强劲的昇腾AI开发板&#xff0c;应用广泛&#xff0c;性能出众&#xff0c;遥遥领先&#xff01; 开发板简介 香橙派AIpro开发板凭借华为昇腾AI芯片的强大算力、丰富的接口、完善的开发工具等优势&#xff0c;在AI开发板市场具有很高的竞争力&#xff0c;可…

基于模板匹配的信用卡数字识别

文章目录 一、项目介绍二、模板匹配的原理三、模板匹配的步骤模板图片处理信用卡图片处理进行模板匹配 一、项目介绍 模板识别&#xff08;Template Matching&#xff09;是一种基于图像匹配的技术&#xff0c;用于在较大图像中识别和定位小图像&#xff08;模板&#xff09;。…

如何在 llama.cpp 服务器中实现用户登录功能的优化方案?(语言-c++)

&#x1f3c6;本文收录于「Bug调优」专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收藏&&…