minio集群部署

最近接触到minio, 将本地集群部署,分别在ubuntu、centos stream9上进行了搭建,目前看里面的小坑不小,记录以下教程,以备忘、以供他人借鉴。

#### 准备

1、因新版本的minio要求,集群部署必须使用挂载非 root 盘的目录,所以这里使用系统盘之外的磁盘

2、各类限制、创建目录等

2.1 防火墙关闭

systemctl stop firewalld

systemctl disable firewalld

systemctl status firewalld

2.2 如果用centos桌面版需要将规则关闭访问控制机制 SELinux(Security-Enhanced Linux)

编辑SELinux的配置文件/etc/selinux/config,将SELINUX设置为disabled

重启后查看状态 getenforce 显示为disabled

2.3 各节点创建 /etc/minio目录,并给权限

2.4 如果是虚机添加磁盘,需先分区再格式化,创建数据目录,挂载,mount -a

2.5 下载minio执行文件为https://dl.min.io/server/minio/release/linux-amd64/minio (注:不要用商用版)

2.6 使用命令测试,最后用sh脚本启动 (注:不用写到配置文件里的形式)

2.7 集群所有节点,命令测试启动成功后,登录后台创建bucket并创建Access Keys,并设置access keys为public

2.8 启动时添加上环境变量,两命令export MINIO_ACCESS_KEY= "accesskeys" export MINIO_SECRET_KEY="xxxxx"

2.9 创建/data/minio/data01目录,需要查看所有者,生产环境权限有限。find ./目录名 -ls

2.9.1 cannot open /dev/sdb1: Device or resource busy 这个错误表明设备

/dev/sdb1正在被某个进程或操作使用,因此无法打开。

sudo fuser -m /dev/sdb1

2.9.2 查询minio错误日志

journalctl -u minio.service

/var/log/message

执行步骤参看以下命令

```
root@wolf-Parallels-Virtual-Platform:~# fdisk -l  或 lsblk
Disk /dev/loop0:4 KiB,4096 字节,8 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop1:61.96 MiB,64970752 字节,126896 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop2:163.29 MiB,171225088 字节,334424 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop3:400.8 MiB,420265984 字节,820832 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop4:91.69 MiB,96141312 字节,187776 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop5:45.86 MiB,48091136 字节,93928 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop6:46.96 MiB,49242112 字节,96176 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/loop7:284 KiB,290816 字节,568 个扇区
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节


Disk /dev/sda:64 GiB,68719476736 字节,134217728 个扇区   #这个是系统盘
Disk model: Ubuntu Linux2-0
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 4096 字节
I/O 大小(最小/最佳):4096 字节 / 4096 字节
磁盘标签类型:gpt
磁盘标识符:DC11A4D4-0F37-4E41-8F16-4689EBC57DB4

设备          起点      末尾      扇区  大小 类型
/dev/sda1     2048      4095      2048    1M BIOS 启动
/dev/sda2     4096   1054719   1050624  513M EFI 系统
/dev/sda3  1054720 134215679 133160960 63.5G Linux 文件系统


Disk /dev/sdb:64 GiB,68719476736 字节,134217728 个扇区   #这个是我新增加的磁盘
Disk model: Ubuntu Linux2-3
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 4096 字节
I/O 大小(最小/最佳):4096 字节 / 4096 字节


Disk /dev/sdc:64 GiB,68719476736 字节,134217728 个扇区   #这个也是我新增加的磁盘
Disk model: Ubuntu Linux2-4
单元:扇区 / 1 * 512 = 512 字节
扇区大小(逻辑/物理):512 字节 / 4096 字节
I/O 大小(最小/最佳):4096 字节 / 4096 字节
```

对磁盘进行格式化并挂载,在格式化之前先对磁盘进行分区,这里我直接分一个区

```
root@wolf-Parallels-Virtual-Platform:~# fdisk /dev/sdb

欢迎使用 fdisk (util-linux 2.37.2)。
更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。

设备不包含可识别的分区表。
创建了一个磁盘标识符为 0x5c7bcbc7 的新 DOS 磁盘标签。

命令(输入 m 获取帮助): n #输入n
分区类型
   p   主分区 (0 primary, 0 extended, 4 free)
   e   扩展分区 (逻辑分区容器)
选择 (默认 p): p  #选择主分区,下面就一直回车即可
分区号 (1-4, 默认  1):
第一个扇区 (2048-134217727, 默认 2048):
Last sector, +/-sectors or +/-size{K,M,G,T,P} (2048-134217727, 默认 134217727):

创建了一个新分区 1,类型为“Linux”,大小为 64 GiB。

命令(输入 m 获取帮助): w #保存
分区表已调整。
将调用 ioctl() 来重新读分区表。
正在同步磁盘。
root@wolf-Parallels-Virtual-Platform:~# fdisk /dev/sdc #第二个磁盘

欢迎使用 fdisk (util-linux 2.37.2)。
更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。

设备不包含可识别的分区表。
创建了一个磁盘标识符为 0x87a1d682 的新 DOS 磁盘标签。

命令(输入 m 获取帮助): n
分区类型
   p   主分区 (0 primary, 0 extended, 4 free)
   e   扩展分区 (逻辑分区容器)
选择 (默认 p): p
分区号 (1-4, 默认  1):
第一个扇区 (2048-134217727, 默认 2048):
Last sector, +/-sectors or +/-size{K,M,G,T,P} (2048-134217727, 默认 134217727):

创建了一个新分区 1,类型为“Linux”,大小为 64 GiB。

命令(输入 m 获取帮助): w
分区表已调整。
将调用 ioctl() 来重新读分区表。
正在同步磁盘。
```

格式化

```
root@wolf-Parallels-Virtual-Platform:~# mkfs.xfs /dev/sdb1 #没有mkfs.xfs 那就安装即可
找不到命令 “mkfs.xfs”,但可以通过以下软件包安装它:
apt install xfsprogs
root@wolf-Parallels-Virtual-Platform:~# apt install xfsprogs
root@wolf-Parallels-Virtual-Platform:~# mkfs.xfs /dev/sdb1 #格式化
meta-data=/dev/sdb1              isize=512    agcount=4, agsize=4194240 blks
         =                       sectsz=4096  attr=2, projid32bit=1
         =                       crc=1        finobt=1, sparse=1, rmapbt=0
         =                       reflink=1    bigtime=0 inobtcount=0
data     =                       bsize=4096   blocks=16776960, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0, ftype=1
log      =internal log           bsize=4096   blocks=8191, version=2
         =                       sectsz=4096  sunit=1 blks, lazy-count=1
realtime =无                    extsz=4096   blocks=0, rtextents=0
Discarding blocks...Done.
root@wolf-Parallels-Virtual-Platform:~# mkfs.xfs /dev/sdc1
meta-data=/dev/sdc1              isize=512    agcount=4, agsize=4194240 blks
         =                       sectsz=4096  attr=2, projid32bit=1
         =                       crc=1        finobt=1, sparse=1, rmapbt=0
         =                       reflink=1    bigtime=0 inobtcount=0
data     =                       bsize=4096   blocks=16776960, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0, ftype=1
log      =internal log           bsize=4096   blocks=8191, version=2
         =                       sectsz=4096  sunit=1 blks, lazy-count=1
realtime =无                    extsz=4096   blocks=0, rtextents=0
Discarding blocks...Done.
```

挂载到系统里

```
root@wolf-Parallels-Virtual-Platform:~# mkdir /data/minio/{data01,data02} -p
root@wolf-Parallels-Virtual-Platform:~# chown wolf:wolf /data/minio -R #给挂载的目录授权
root@wolf-Parallels-Virtual-Platform:~# ls -l /data/minio
总计 12
drwxr-xr-x 3 wolf wolf   24  9月 29 15:59 data01
drwxr-xr-x 3 wolf wolf   24  9月 29 15:59 data02
root@wolf-Parallels-Virtual-Platform:~# mount /dev/sdb1 /data/minio/data01 #临时挂在,重启失效
root@wolf-Parallels-Virtual-Platform:~# mount /dev/sdc1 /data/minio/data02
root@wolf-Parallels-Virtual-Platform:~# blkid #查看磁盘的id
/dev/sda3: UUID="f11cdc00-8283-42d8-99ac-f260516112ac" BLOCK_SIZE="4096" TYPE="ext4" PARTUUID="ec38747c-6bad-4db4-9264-0d0d8b6ecba9"
/dev/loop1: TYPE="squashfs"
/dev/sdb1: UUID="04d19afa-3c2b-4fe1-89c8-f44ecdd98c30" BLOCK_SIZE="4096" TYPE="xfs" PARTUUID="5c7bcbc7-01"
/dev/loop6: TYPE="squashfs"
/dev/loop4: TYPE="squashfs"
/dev/loop2: TYPE="squashfs"
/dev/loop0: TYPE="squashfs"
/dev/sdc1: UUID="5abe4743-d0e8-47ea-b87d-941536e79cdf" BLOCK_SIZE="4096" TYPE="xfs" PARTUUID="87a1d682-01"
/dev/loop7: TYPE="squashfs"
/dev/sda2: UUID="C6C5-DEF7" BLOCK_SIZE="512" TYPE="vfat" PARTLABEL="EFI System Partition" PARTUUID="3f5a0baa-261f-40bf-8d29-6f8fc2392ebf"
/dev/sda1: PARTUUID="6d53a19e-91c2-4016-8006-2df8d723705f"
/dev/loop5: TYPE="squashfs"
/dev/loop3: TYPE="squashfs"
root@wolf-Parallels-Virtual-Platform:~# cat /etc/fstab #在启动文档里把挂在的盘加进去
# /etc/fstab: static file system information.
#
# Use 'blkid' to print the universally unique identifier for a
# device; this may be used with UUID= as a more robust way to name devices
# that works even if disks are added and removed. See fstab(5).
#
# <file system> <mount point>   <type>  <options>       <dump>  <pass>
# / was on /dev/sda3 during installation
UUID=f11cdc00-8283-42d8-99ac-f260516112ac /               ext4    errors=remount-ro 0       1
# /boot/efi was on /dev/sda2 during installation
UUID=C6C5-DEF7  /boot/efi       vfat    umask=0077      0       1
/swapfile                                 none            swap    sw              0       0
UUID=04d19afa-3c2b-4fe1-89c8-f44ecdd98c30 /data/minio/data01 xfs default 0 0 #对应的/dev/sdb1
UUID=5abe4743-d0e8-47ea-b87d-941536e79cdf /data/minio/data02 xfs default 0 0 #对应的/dev/sdc1
```

验证一下挂载的磁盘

```
root@wolf-Parallels-Virtual-Platform:~# mount
sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime)
proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)
udev on /dev type devtmpfs (rw,nosuid,relatime,size=965252k,nr_inodes=241313,mode=755,inode64)
devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000)
tmpfs on /run type tmpfs (rw,nosuid,nodev,noexec,relatime,size=200496k,mode=755,inode64)
/dev/sda3 on / type ext4 (rw,relatime,errors=remount-ro)
securityfs on /sys/kernel/security type securityfs (rw,nosuid,nodev,noexec,relatime)
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,inode64)
tmpfs on /run/lock type tmpfs (rw,nosuid,nodev,noexec,relatime,size=5120k,inode64)
cgroup2 on /sys/fs/cgroup type cgroup2 (rw,nosuid,nodev,noexec,relatime,nsdelegate,memory_recursiveprot)
pstore on /sys/fs/pstore type pstore (rw,nosuid,nodev,noexec,relatime)
bpf on /sys/fs/bpf type bpf (rw,nosuid,nodev,noexec,relatime,mode=700)
systemd-1 on /proc/sys/fs/binfmt_misc type autofs (rw,relatime,fd=29,pgrp=1,timeout=0,minproto=5,maxproto=5,direct,pipe_ino=5906)
hugetlbfs on /dev/hugepages type hugetlbfs (rw,relatime,pagesize=2M)
debugfs on /sys/kernel/debug type debugfs (rw,nosuid,nodev,noexec,relatime)
tracefs on /sys/kernel/tracing type tracefs (rw,nosuid,nodev,noexec,relatime)
mqueue on /dev/mqueue type mqueue (rw,nosuid,nodev,noexec,relatime)
fusectl on /sys/fs/fuse/connections type fusectl (rw,nosuid,nodev,noexec,relatime)
configfs on /sys/kernel/config type configfs (rw,nosuid,nodev,noexec,relatime)
ramfs on /run/credentials/systemd-sysusers.service type ramfs (ro,nosuid,nodev,noexec,relatime,mode=700)
/var/lib/snapd/snaps/bare_5.snap on /snap/bare/5 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/firefox_1635.snap on /snap/firefox/1635 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/core20_1587.snap on /snap/core20/1587 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/gnome-3-38-2004_112.snap on /snap/gnome-3-38-2004/112 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/gtk-common-themes_1535.snap on /snap/gtk-common-themes/1535 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/snapd_16292.snap on /snap/snapd/16292 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/snap-store_582.snap on /snap/snap-store/582 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/var/lib/snapd/snaps/snapd-desktop-integration_14.snap on /snap/snapd-desktop-integration/14 type squashfs (ro,nodev,relatime,errors=continue,threads=single,x-gdu.hide)
/dev/sda2 on /boot/efi type vfat (rw,relatime,fmask=0077,dmask=0077,codepage=437,iocharset=iso8859-1,shortname=mixed,errors=remount-ro)
tmpfs on /run/user/127 type tmpfs (rw,nosuid,nodev,relatime,size=200492k,nr_inodes=50123,mode=700,uid=127,gid=133,inode64)
portal on /run/user/127/doc type fuse.portal (rw,nosuid,nodev,relatime,user_id=127,group_id=133)
tmpfs on /run/snapd/ns type tmpfs (rw,nosuid,nodev,noexec,relatime,size=200496k,mode=755,inode64)
gvfsd-fuse on /run/user/127/gvfs type fuse.gvfsd-fuse (rw,nosuid,nodev,relatime,user_id=127,group_id=133)
nsfs on /run/snapd/ns/snapd-desktop-integration.mnt type nsfs (rw)
tmpfs on /run/user/1000 type tmpfs (rw,nosuid,nodev,relatime,size=200492k,nr_inodes=50123,mode=700,uid=1000,gid=1000,inode64)
gvfsd-fuse on /run/user/1000/gvfs type fuse.gvfsd-fuse (rw,nosuid,nodev,relatime,user_id=1000,group_id=1000)
portal on /run/user/1000/doc type fuse.portal (rw,nosuid,nodev,relatime,user_id=1000,group_id=1000)
/dev/sdb1 on /data/minio/data01 type xfs (rw,relatime,attr2,inode64,logbufs=8,logbsize=32k,noquota) # 这两个是挂载的磁盘
/dev/sdc1 on /data/minio/data02 type xfs (rw,relatime,attr2,inode64,logbufs=8,logbsize=32k,noquota)
```

配置minio集群的启动

```
root@wolf-Parallels-Virtual-Platform:~# chmod +x /usr/local/bin/minio
#注意,如果执行在用普通用户执行会出现没有权限写入,如果执行了,需要把/data/minio/data01和/data/minio/data02的隐藏文件删除在用普通用户执行
root@wolf-Parallels-Virtual-Platform:~# minio server --config-dir /etc/minio --console-address :9001         --address :9000         http://10.211.55.9/data/minio/data01  http://10.211.55.9/data/minio/data02 http://10.211.55.10/data/minio/data01 http://10.211.55.10/data/minio/data02
.............................................................
Automatically configured API requests per node based on available memory on the system: 19
All MinIO sub-systems initialized successfully in 1.865853508s
WARNING: Detected default credentials 'minioadmin:minioadmin', we recommend that you change these values with 'MINIO_ROOT_USER' and 'MINIO_ROOT_PASSWORD' environment variables
MinIO Object Storage Server
Copyright: 2015-2023 MinIO, Inc.
License: GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>
Version: RELEASE.2023-08-09T23-30-22Z (go1.19.12 linux/amd64)

Status:         4 Online, 0 Offline.
S3-API: http://10.211.55.9:9000  http://127.0.0.1:9000
RootUser: minioadmin
RootPass: minioadmin

Console: http://10.211.55.9:9001 http://127.0.0.1:9001
RootUser: minioadmin
RootPass: minioadmin
```

测试启动通过,下面设置开机自启动

```
root@wolf-Parallels-Virtual-Platform:~# vim /etc/default/minio.sh
#!/bin/bash
minio server --config-dir /etc/minio --console-address :9001         --address :9000         http://10.211.55.9/data/minio/data01  http://10.211.55.9/data/minio/data02 http://10.211.55.10/data/minio/data01 http://10.211.55.10/data/minio/data02
root@wolf-Parallels-Virtual-Platform:~# chmod +x /etc/default/minio.sh
root@wolf-Parallels-Virtual-Platform:~# vim /usr/lib/systemd/system/minio.service
[Unit]
Description=Minio service
Documentation=https://docs.minio.io/

[Service]
User=wolf
Group=wolf
ExecStart=/etc/default/minio.sh
Restart=on-failure
RestartSec=5

[Install]
WantedBy=multi-user.target
root@wolf-Parallels-Virtual-Platform:~# chmod +x  /usr/lib/systemd/system/minio.service
root@wolf-Parallels-Virtual-Platform:~# chown wolf:wolf -R /etc/default/
```

使用普通用户启动

```
wolf@wolf-Parallels-Virtual-Platform:~$ sudo systemctl daemon-reload
[sudo] wolf 的密码:
wolf@wolf-Parallels-Virtual-Platform:~$ sudo systemctl restart minio
wolf@wolf-Parallels-Virtual-Platform:~$ sudo systemctl status minio
● minio.service - Minio service
     Loaded: loaded (/lib/systemd/system/minio.service; enabled; vendor preset: enabled)
     Active: active (running) since Sun 2024-09-29 16:39:15 CST; 6s ago
       Docs: https://docs.minio.io/
   Main PID: 2667 (minio.sh)
      Tasks: 9 (limit: 2262)
     Memory: 150.7M
        CPU: 486ms
     CGroup: /system.slice/minio.service
             ├─2667 /bin/bash /etc/default/minio.sh
             └─2668 minio server --config-dir /etc/minio --console-address :9001 --address :9000 http://10.211.55.9/dat>

Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: MinIO Object Storage Server
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: Copyright: 2015-2023 MinIO, Inc.
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: License: GNU AGPLv3 <https://www.gnu.org/licenses/agpl->
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: Version: RELEASE.2023-08-09T23-30-22Z (go1.19.12 linux/>
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: Status:         4 Online, 0 Offline.
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: S3-API: http://10.211.55.9:9000  http://127.0.0.1:9000
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: Console: http://10.211.55.9:9001 http://127.0.0.1:9001
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]: Documentation: https://min.io/docs/minio/linux/index.ht>
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]:  You are running an older version of MinIO released 1 y>
Sep 29 16:39:16 wolf-Parallels-Virtual-Platform minio.sh[2668]:  Update: Run `mc admin update`

wolf@wolf-Parallels-Virtual-Platform:~$ ls -l /usr/lib/systemd/system/minio.service
-rwxr-xr-x 1 root root 204 Sep 29 16:38 /usr/lib/systemd/system/minio.service
```

验证

在其中一个节点里创建一个文件,看另一个节点是否有,如果有说明成功

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

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

相关文章

AAA Mysql与redis的主从复制原理

一 &#xff1a;Mysql主从复制 重要的两个日志文件&#xff1a;bin log 和 relay log bin log&#xff1a;二进制日志&#xff08;binnary log&#xff09;以事件形式记录了对MySQL数据库执行更改的所有操作。 relay log&#xff1a;用来保存从节点I/O线程接受的bin log日志…

Java中System类和RunTime类的Api

目录 System 类 1)out 2)err 3)in 4)currentTimeMillis() 5)nanoTime() 6)arraycopy(Object 要从里面复制东西的数组, int 要从里面复制东西数组的索引起始位置, Object 获得复制元素的数组, int 获得复制元素数组的起始索引, int 要复制东西的个数) 7)gc() 8)exit(int status)…

51单片机的无线通信智能车库门【proteus仿真+程序+报告+原理图+演示视频】

1、主要功能 该系统由AT89C51/STC89C52单片机LCD1602显示模块红外传感器光照传感器时钟模块步进电机蓝牙按键、LED、蜂鸣器等模块构成。适用于智能车库自动门、无线控制车库门等相似项目。 可实现功能: 1、LCD1602实时显示北京时间和自动/手动模式&#xff0c;以及验证是否成…

【Arduino IDE安装】Arduino IDE的简介和安装详情

目录 &#x1f31e;1. Arduino IDE概述 &#x1f31e;2. Arduino IDE安装详情 &#x1f30d;2.1 获取安装包 &#x1f30d;2.2 安装详情 &#x1f30d;2.3 配置中文 &#x1f30d;2.4 其他配置 &#x1f31e;1. Arduino IDE概述 Arduino IDE&#xff08;Integrated Deve…

使用 Go 和 Gin 框架构建简单的用户和物品管理 Web 服务

使用 Go 和 Gin 框架构建简单的用户和物品管理 Web 服务 在本项目中&#xff0c;我们使用 Go 语言和 Gin 框架构建了一个简单的 Web 服务&#xff0c;能够管理用户和物品的信息。该服务实现了两个主要接口&#xff1a;根据用户 ID 获取用户名称&#xff0c;以及根据物品 ID 获…

模拟实现消息队列(基于SpringBoot实现)

项目代码 提要&#xff1a;此处的消息队列是仿照RabbitMQ实现&#xff08;参数之类的&#xff09;&#xff0c;实现一些基本的操作&#xff1a;创建/销毁交互机&#xff08;exchangeDeclare&#xff0c;exchangeDelete&#xff09;&#xff0c;队列&#xff08;queueDeclare&a…

【电路笔记】-求和运算放大器

求和运算放大器 文章目录 求和运算放大器1、概述2、反相求和放大器3、同相求和放大器4、减法放大器5、应用5.1 音频混合器5.2 数模转换器 (DAC)6、总结1、概述 在我们之前有关运算放大器的大部分文章中,仅将一个输入应用于反相或非反相运算放大器的输入。在本文中,将讨论一种…

Python:条件分支 if 语句全讲解

Python&#xff1a;条件分支 if 语句全讲解 如果我拿出下面的代码&#xff0c;阁下该做何应对&#xff1f; if not reset_excuted and (terminated or truncated):... else:...---- 前言&#xff1a; 消化论文代码的时候看到这个东西直接大脑冻结&#xff0c;没想过会在这么…

5个免费ppt模板网站推荐!轻松搞定职场ppt制作!

每次过完小长假&#xff0c;可以明显地感觉到&#xff0c;2024这一年很快又要结束了&#xff0c;不知此刻的你有何感想呢&#xff1f;是满载而归&#xff0c;还是准备着手制作年终总结ppt或年度汇报ppt呢&#xff1f; 每当说到制作ppt&#xff0c;很多人的第一反应&#xff0c…

ElasticSearch备考 -- Multi match

一、题目 索引task有3个字段a、b、c&#xff0c;写一个查询去匹配这三个字段为mom&#xff0c;其中b的字段评分比a、c字段大一倍&#xff0c;将他们的分数相加作为最后的总分数 二、思考 通过题目要求对多个字段进行匹配查询&#xff0c;可以考虑multi match、bool query操作。…

vivo全新AI战略“蓝心智能”发布 原系统5亮相开发者大会

​10月10日&#xff0c;2024 vivo开发者大会在深圳国际会展中心举办&#xff0c;大会主题为“同心同行”。会上&#xff0c;vivo正式发布全新AI战略——“蓝心智能”&#xff0c;同时带来全面升级的自研蓝心大模型矩阵、原系统5&#xff08;OriginOS 5&#xff09;、蓝河操作系…

PHP中的HTTP请求:简化你的网络通信

在当今的网络应用开发中&#xff0c;PHP作为一种流行的服务器端脚本语言&#xff0c;经常需要与外部服务进行通信。这通常涉及到发送HTTP请求来获取或提交数据。幸运的是&#xff0c;PHP提供了多种方式来简化HTTP请求的过程&#xff0c;使得网络通信变得轻而易举。 PHP中的HTTP…

网络编程(17)——asio多线程模型IOThreadPool

十七、day17 之前我们介绍了IOServicePool的方式&#xff0c;一个IOServicePool开启n个线程和n个iocontext&#xff0c;每个线程内独立运行iocontext, 各个iocontext监听各自绑定的socket是否就绪&#xff0c;如果就绪就在各自线程里触发回调函数。为避免线程安全问题&#xf…

AVL树如何维持平衡

1.AVL树的特性 二叉搜索树虽可以缩短查找的效率&#xff0c;但如果数据有序或接近有序二叉搜索树将退化为单支树&#xff0c;查 找元素相当于在顺序表中搜索元素&#xff0c;效率低下。因此&#xff0c;两位俄罗斯的数学家G.M.Adelson-Velskii 和E.M.Landis在1962年 发明了一种…

音频文件重采样 - python 实现

在处理音频文件的时候&#xff0c;经常会将原音频进行统一的重采样处理&#xff0c;设置为相同的采样率&#xff0c;本示例&#xff0c;就是将44100采样率的音频&#xff0c;重采样为16000. 安装对应的python 库&#xff1a;librosa 和 soundfile. pip install soundfile pip i…

详细解读“霸王面”战术

“霸王面”战术是指在没有得到雇主面试通知的情况下&#xff0c;强行加入面试&#xff0c;以此争取工作机会的求职策略。以下将以3000字左右的篇幅&#xff0c;通过生动形象的例子详细解释这一战术。 一、背景介绍 在当今竞争激烈的就业市场中&#xff0c;求职者需要经历网申…

国外火出圈儿的PM御用AI编程工具Bolt.new效果干不过国产的CodeFlying?号称全新定义全栈开发流程?

不知道大家最近有没有发现国外的很多AI都在挤破脑袋想去提升大模型的编程能力&#xff0c; 离我们最近的是上周Openai 发布的全新模型GPT-4o-Canvas&#xff0c; 拥有超强的代码编写能力。 另外还有LlamaCoder、Cursor、Claude artifacts、Replit... 光是今年一年就推出了好…

【笔记学习篇】一篇文章搞定Mybatis-快速回顾

概述 5.1.1 Mybatis简介 Mybatis是一款优秀的持久层框架&#xff0c;它以sql为中心&#xff0c;支持定制化sql、存储过程以及高级映射。 使用Mybatis框架&#xff0c;可以无需手动编写基础的JDBC代码、无需手动设置参数和转换结果集到对象。 Mybatis可以使用简单的xml或注解来…

2024.10月7~10日 进一步完善《电信资费管理系统》

一、新增的模块&#xff1a; 在原项目基础上&#xff0c;新增加了以下功能&#xff1a; 1、增加AspectJ 框架的AOP 异常记录和事务管理模块。 2、增加SpringMVC的拦截器&#xff0c;实现登录 控制页面访问权限。 3、增加 Logback日志框架&#xff0c;记录日志。 4、增加动态验…

ssm基于Javaee的影视创作论坛的设计与实现

系统包含&#xff1a;源码论文 所用技术&#xff1a;SpringBootVueSSMMybatisMysql 免费提供给大家参考或者学习&#xff0c;获取源码请私聊我 需要定制请私聊 目 录 目 录 III 第1章 绪论 1 1.1选题动因 1 1.2目的和意义 1 1.3论文结构安排 2 第2章 开发环境与技术 …