OpenStack HA高可用集群Train版-0集群环境准备
OpenStack HA高可用集群Train版-0集群环境准备
目录
- 主机配置
- 1.主机名
- 2.网卡配置
- 网卡UUID
- 配置主机名解析
- 配置免密登录
- 防火墙相关配置
- 时间同步配置
- 二、基础软件安装
- 数据库
- 构建数据库集群
- 设置心跳检测clustercheck
- 准备脚本
- 创建心跳检测用户,(任意控制节点)
- 检测配置文件
- 每个控制节点启动心跳检测服务
- 测试心跳检测脚本
- 设置心跳检测clustercheck
主机配置
1.主机名
hostnamectl set-hostname controller01
exec bashhostnamectl set-hostname controller02
exec bashhostnamectl set-hostname controller03
exec bashhostnamectl set-hostname compute01
exec bashhostnamectl set-hostname compute02
exec bashhostnamectl set-hostname compute03
exec bash
2.网卡配置
网卡UUID
nmcli con show
uuidgen ens33
cd /etc/sysconfig/network-scripts/
ls
reboot
nmcli con show
cat /etc/sysconfig/network-scripts/ifcfg-ens33
cat /etc/sysconfig/network-scripts/ifcfg-ens37
cat /etc/networks
ifconfig
配置主机名解析
echo 10.0.0.41 controller01 >> /etc/hosts
echo 10.0.0.42 controller02 >> /etc/hosts
echo 10.0.0.43 controller03 >> /etc/hosts
echo 10.0.0.51 compute01 >> /etc/hosts
echo 10.0.0.52 compute02 >> /etc/hosts
echo 10.0.0.53 compute03 >> /etc/hosts
cat /etc/hosts
ping -c 4 controller01
ping -c 4 controller02
ping -c 4 controller03
ping -c 4 compute01
ping -c 4 compute02
ping -c 4 compute03
ping -c 4 qq.com
高可用OpenStack(Queen版)集群-1. 集群环境
配置免密登录
在controller01生成密钥
ssh-keygen -t rsa
ssh-copy-id controller01
ssh-copy-id controller02
scp -r .ssh controller02:~/
ssh-copy-id controller03
scp -r .ssh controller03:~/
ssh-copy-id compute01
scp -r .ssh compute01:~/
ssh-copy-id compute02
scp -r .ssh compute02:~/
ssh-copy-id compute03
scp -r .ssh compute03:~/
快照拍一个
防火墙相关配置
systemctl stop firewalld.service
systemctl disable firewalld.service
systemctl status firewalld.service
setenforce 0
getenforce
sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/sysconfig/selinux
grep SELINUX=disabled /etc/sysconfig/selinux
cat /etc/sysconfig/selinux
reboot
sestatus
时间同步配置
每个节点
yum install chrony -y
cp /etc/chrony.conf /etc/chrony.conf.bak
设计vim的部分都可以进行优化,要么sed改,要么cat EOF进行文件替换
vim /etc/chrony.conf
egrep -v "^$|^#" /etc/chrony.conf
[root@controller03 ~]# egrep -v "^$|^#" /etc/chrony.conf
server ntp1.aliyun.com iburst
server controller01 iburst
server controller02 iburst
server controller03 iburst
driftfile /var/lib/chrony/drift
makestep 1.0 3
rtcsync
allow 10.0.0.2/24
logdir /var/log/chrony
[root@controller03 ~]#
systemctl enable chronyd.service
systemctl restart chronyd.service
systemctl status chronyd.service
timedatectl set-timezone Asia/Shanghai
chronyc sources -v
timedatectl status
date
当前节点为controller03
scp -r /etc/chrony.conf root@controller01:/etc/chrony.conf
scp -r /etc/chrony.conf root@controller02:/etc/chrony.conf
scp -r /etc/chrony.conf root@controller03:/etc/chrony.conf
scp -r /etc/chrony.conf root@compute01:/etc/chrony.conf
scp -r /etc/chrony.conf root@compute02:/etc/chrony.conf
scp -r /etc/chrony.conf root@compute03:/etc/chrony.conf
确认yum源,可以更换为本地源
cat > /etc/yum.repos.d/CentOS-PrivateLocal.repo <<EOF [base]
name=CentOS-$releasever - Base
baseurl=http://192.168.2.103/yumrepository/base/
gpgcheck=0
enabled=1[updates]
name=CentOS-$releasever - Updates
baseurl=http://192.168.2.103/yumrepository/updates/
gpgcheck=0
enabled=1[extras]
name=CentOS-$releasever - Extras
baseurl=http://192.168.2.103/yumrepository/extras/
gpgcheck=0
enabled=1[centos-openstack-train]
name=CentOS-7 - OpenStack train
baseurl=http://192.168.2.103/yumrepository/centos-openstack-train/
gpgcheck=0
enabled=1[centos-qemu-ev]
name=CentOS-$releasever - QEMU EV
baseurl=http://192.168.2.103/yumrepository/centos-qemu-ev/
gpgcheck=0
enabled=1[centos-ceph-nautilus]
name=CentOS-7 - Ceph Nautilus
baseurl=http://192.168.2.103/yumrepository/centos-ceph-nautilus/
gpgcheck=0
enabled=1[centos-nfs-ganesha28]
name=CentOS-7 - NFS Ganesha 2.8
baseurl=http://192.168.2.103/yumrepository/centos-nfs-ganesha28/
gpgcheck=0
enabled=1
EOF
ls /etc/yum.repos.d/CentOS-PrivateLocal.repo
yum install centos-release-openstack-train -y
yum clean all
yum makecache
yum install python-openstackclient openstack-selinux -y
yum install openstack-utils -y
yum install -y lsof vim net-tools wget git
poweroff
所有控制和计算节点,拍快照
配置完成
一环境准备
https://www.cnblogs.com/netonline/p/9180299.html
https://blog.csdn.net/u013469753/article/details/106274225
二、基础软件安装
https://www.cnblogs.com/netonline/p/9184691.html
https://blog.csdn.net/u013469753/article/details/106274225
数据库
在全部controller节点安装mariadb,以controller01节点为例
所有控制节点
在全部controller节点安装mariadb,以controller01节点为例
安装galera相关插件,利用galera搭建集群
yum install mariadb mariadb-server MySQL-python python2-PyMySQL -y
yum install mariadb-server-galera mariadb-galera-common galera xinetd rsync -y
在全部控制节点初始化数据库密码,以controller01节点为例;
root初始密码为空
systemctl restart mariadb.service
systemctl status mariadb.service
mysql_secure_installation <<EOFy
mysql_pass
mysql_pass
y
n
y
y
EOF
mysql -uroot -pmysql_pass
exit
或者手动设置
mysql_secure_installation
[root@controller01 ~]# mysql_secure_installation
Enter current password for root (enter for none): #直接按回车
Set root password? [Y/n] y
New password: #设置root用户密码为:mysql_pass
Re-enter new password:
Remove anonymous users? [Y/n] y
Disallow root login remotely? [Y/n] n #注意允许
Remove test database and access to it? [Y/n] y
Reload privilege tables now? [Y/n] y
所有控制节点创建OpenStack的配置文件,IP地址根据实际所在节点进行修改
#touch /etc/my.cnf.d/openstack.cnf
# [mysqld]
# bind-address = 0.0.0.0
# default-storage-engine = innodb
# innodb_file_per_table = on
# max_connections = 4096
# collation-server = utf8_general_ci
# character-set-server = utf8
# init-connect = 'SET NAMES utf8'
在全部控制节点/etc/my.cnf.d/目录下新增openstack.cnf配置文件,主要设置集群同步相关参数.
以controller01节点为例,个别涉及ip地址/host名等参数根据实际情况修改
控制节点1
cat > /etc/my.cnf.d/openstack.cnf <<EOF
[mysqld]
binlog_format = ROW
bind-address = 0.0.0.0
default-storage-engine = innodb
innodb_file_per_table = on
max_connections = 4096
collation-server = utf8_general_ci
character-set-server = utf8
init-connect = 'SET NAMES utf8'[galera]
bind-address = 10.0.0.41
wsrep_provider = /usr/lib64/galera/libgalera_smm.so
wsrep_cluster_address ="gcomm://controller01,controller02,controller03"
wsrep_cluster_name = openstack-cluster-01
wsrep_node_name = controller01
wsrep_node_address = 10.0.0.41
wsrep_on=ON
wsrep_slave_threads=4
wsrep_sst_method=rsync
default_storage_engine=InnoDB
[embedded]
[mariadb]
[mariadb-10.1]
EOF
控制节点2
cat > /etc/my.cnf.d/openstack.cnf <<EOF
[mysqld]
binlog_format = ROW
bind-address = 0.0.0.0
default-storage-engine = innodb
innodb_file_per_table = on
max_connections = 4096
collation-server = utf8_general_ci
character-set-server = utf8
init-connect = 'SET NAMES utf8'[galera]
bind-address = 10.0.0.42
wsrep_provider = /usr/lib64/galera/libgalera_smm.so
wsrep_cluster_address ="gcomm://controller01,controller02,controller03"
wsrep_cluster_name = openstack-cluster-01
wsrep_node_name = controller02
wsrep_node_address = 10.0.0.42
wsrep_on=ON
wsrep_slave_threads=4
wsrep_sst_method=rsync
default_storage_engine=InnoDB
[embedded]
[mariadb]
[mariadb-10.1]
EOF
控制节点3
cat > /etc/my.cnf.d/openstack.cnf <<EOF
[mysqld]
binlog_format = ROW
bind-address = 0.0.0.0
default-storage-engine = innodb
innodb_file_per_table = on
max_connections = 4096
collation-server = utf8_general_ci
character-set-server = utf8
init-connect = 'SET NAMES utf8'[galera]
bind-address = 10.0.0.43
wsrep_provider = /usr/lib64/galera/libgalera_smm.so
wsrep_cluster_address ="gcomm://controller01,controller02,controller03"
wsrep_cluster_name = openstack-cluster-01
wsrep_node_name = controller03
wsrep_node_address = 10.0.0.43
wsrep_on=ON
wsrep_slave_threads=4
wsrep_sst_method=rsync
default_storage_engine=InnoDB
[embedded]
[mariadb]
[mariadb-10.1]
EOF
cat /etc/my.cnf.d/openstack.cnf
所有控制节点先拍个快照
https://www.cnblogs.com/netonline/p/9184691.html
构建数据库集群
停止全部控制节点的mariadb服务,以controller01节点为例
systemctl stop mariadb.service
systemctl status mariadb.service
拍个快照,后面服务status异常,未能启动成功
任选1个控制节点以如下方式启动mariadb服务,这里选择controller01节点
/usr/libexec/mysqld --wsrep-new-cluster --user=root &
systemctl status mariadb.service
其他控制节点加入mariadb集群,以controller02节点为例,启动后加入集群,通过查看service的status,可以看到controller02节点从controller01节点同步数据,也可同步查看mariadb日志/var/log/mariadb/mariadb.log
systemctl start mariadb.service
systemctl status mariadb.service
控制节点1
[root@controller01 ~]# /usr/libexec/mysqld --wsrep-new-cluster --user=root &
[1] 1229
[root@controller01 ~]# 2022-01-13 9:37:20 0 [Note] /usr/libexec/mysqld (mysqld 10.3.20-MariaDB) starting as process 1229 ...[root@controller01 ~]# systemctl status mariadb.service
● mariadb.service - MariaDB 10.3 database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled)Active: inactive (dead)Docs: man:mysqld(8)https://mariadb.com/kb/en/library/systemd/
[root@controller01 ~]#
控制节点2
[root@controller02 ~]# systemctl start mariadb.service
[root@controller02 ~]#
[root@controller02 ~]# systemctl status mariadb.service
● mariadb.service - MariaDB 10.3 database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled)Active: active (running) since Thu 2022-01-13 09:37:57 CST; 4min 14s agoDocs: man:mysqld(8)https://mariadb.com/kb/en/library/systemd/Process: 1445 ExecStartPost=/usr/libexec/mysql-check-upgrade (code=exited, status=0/SUCCESS)Process: 1259 ExecStartPre=/usr/libexec/mysql-prepare-db-dir %n (code=exited, status=0/SUCCESS)Process: 1235 ExecStartPre=/usr/libexec/mysql-check-socket (code=exited, status=0/SUCCESS)Main PID: 1297 (mysqld)Status: "Taking your SQL requests now..."CGroup: /system.slice/mariadb.service└─1297 /usr/libexec/mysqld --basedir=/usrJan 13 09:37:55 controller02 rsyncd[1385]: connect from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1385]: rsync to rsync_sst/./mysql from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1385]: receiving file list
Jan 13 09:37:55 controller02 rsyncd[1391]: connect from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1391]: rsync to rsync_sst/./performance_schema from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1391]: receiving file list
Jan 13 09:37:55 controller02 rsyncd[1393]: connect from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1393]: rsync to rsync_sst/ from controller01 (10.0.0.41)
Jan 13 09:37:55 controller02 rsyncd[1393]: receiving file list
Jan 13 09:37:57 controller02 systemd[1]: Started MariaDB 10.3 database server.
[root@controller02 ~]#
控制节点3
[root@controller03 ~]# systemctl start mariadb.service
[root@controller03 ~]#
[root@controller03 ~]# systemctl status mariadb.service
● mariadb.service - MariaDB 10.3 database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled)Active: active (running) since Thu 2022-01-13 09:42:39 CST; 2s agoDocs: man:mysqld(8)https://mariadb.com/kb/en/library/systemd/Process: 1442 ExecStartPost=/usr/libexec/mysql-check-upgrade (code=exited, status=0/SUCCESS)Process: 1260 ExecStartPre=/usr/libexec/mysql-prepare-db-dir %n (code=exited, status=0/SUCCESS)Process: 1236 ExecStartPre=/usr/libexec/mysql-check-socket (code=exited, status=0/SUCCESS)Main PID: 1298 (mysqld)Status: "Taking your SQL requests now..."CGroup: /system.slice/mariadb.service└─1298 /usr/libexec/mysqld --basedir=/usrJan 13 09:42:37 controller03 rsyncd[1386]: connect from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1386]: rsync to rsync_sst/./mysql from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1386]: receiving file list
Jan 13 09:42:38 controller03 rsyncd[1388]: connect from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1388]: rsync to rsync_sst/./performance_schema from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1388]: receiving file list
Jan 13 09:42:38 controller03 rsyncd[1390]: connect from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1390]: rsync to rsync_sst/ from controller01 (10.0.0.41)
Jan 13 09:42:38 controller03 rsyncd[1390]: receiving file list
Jan 13 09:42:39 controller03 systemd[1]: Started MariaDB 10.3 database server.
[root@controller03 ~]#
重新启动controller01节点,启动前删除contrller01节点的数据
pkill -9 mysql
rm -rf /var/lib/mysql/*
[root@controller01 ~]# pkill -9 mysql
[root@controller01 ~]# rm -rf /var/lib/mysql/*
控制节点以system unit方式启动mariadb服务时的权限配置
chown mysql:mysql /var/run/mariadb/mariadb.pid
reboot
[root@controller01 ~]# chown mysql:mysql /var/run/mariadb/mariadb.pid
[root@controller01 ~]# reboot
启动后查看节点所在服务状态,controller01节点从controller02节点同步数据
[root@controller01 ~]# systemctl start mariadb.service
[root@controller01 ~]# systemctl status mariadb.service
[root@controller01 ~]# systemctl status mariadb.service
● mariadb.service - MariaDB 10.3 database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled)Active: active (running) since Fri 2022-01-07 11:50:16 CST; 10min agoDocs: man:mysqld(8)https://mariadb.com/kb/en/library/systemd/Process: 1508 ExecStartPost=/usr/libexec/mysql-check-upgrade (code=exited, status=0/SUCCESS)Process: 1261 ExecStartPre=/usr/libexec/mysql-prepare-db-dir %n (code=exited, status=0/SUCCESS)Process: 1237 ExecStartPre=/usr/libexec/mysql-check-socket (code=exited, status=0/SUCCESS)Main PID: 1364 (mysqld)Status: "Taking your SQL requests now..."CGroup: /system.slice/mariadb.service└─1364 /usr/libexec/mysqld --basedir=/usrJan 07 11:50:15 controller01 rsyncd[1452]: connect from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1452]: rsync to rsync_sst/./mysql from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1452]: receiving file list
Jan 07 11:50:15 controller01 rsyncd[1454]: connect from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1454]: rsync to rsync_sst/./performance_schema from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1454]: receiving file list
Jan 07 11:50:15 controller01 rsyncd[1456]: connect from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1456]: rsync to rsync_sst/ from controller03 (10.0.0.43)
Jan 07 11:50:15 controller01 rsyncd[1456]: receiving file list
Jan 07 11:50:16 controller01 systemd[1]: Started MariaDB 10.3 database server.
查看集群状态
mysql -uroot -pmysql_pass
[root@controller01 ~]# mysql -uroot -pmysql_pass
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 13
Server version: 10.3.20-MariaDB MariaDB ServerCopyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MariaDB [(none)]> show status like "wsrep_cluster_size";
+--------------------+-------+
| Variable_name | Value |
+--------------------+-------+
| wsrep_cluster_size | 3 |
+--------------------+-------+
1 row in set (0.001 sec)MariaDB [(none)]> show status LIKE 'wsrep_ready';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| wsrep_ready | ON |
+---------------+-------+
1 row in set (0.002 sec)MariaDB [(none)]> exit
设置心跳检测clustercheck
准备脚本
wget https://raw.githubusercontent.com/olafz/percona-clustercheck/master/clustercheck
[root@controller01 ~]# wget https://raw.githubusercontent.com/olafz/percona-clustercheck/master/clustercheck
--2022-01-07 13:46:43-- https://raw.githubusercontent.com/olafz/percona-clustercheck/master/clustercheck
Resolving raw.githubusercontent.com (raw.githubusercontent.com)... 185.199.109.133, 185.199.108.133, 185.199.111.133, ...
Connecting to raw.githubusercontent.com (raw.githubusercontent.com)|185.199.109.133|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 3882 (3.8K) [text/plain]
Saving to: ‘clustercheck’100%[===========================================================================================================================================>] 3,882 --.-K/s in 0s 2022-01-07 13:46:44 (115 MB/s) - ‘clustercheck’ saved [3882/3882][root@controller01 ~]#
chmod +x clustercheck
cp ~/clustercheck /usr/bin/
创建心跳检测用户,(任意控制节点)
在任意控制节点创建clustercheck_user用户并赋权;
注意账号/密码与脚本中的账号/密码对应,这里采用的是脚本默认的账号/密码,否则需要修改clustercheck脚本文件
mysql -uroot -pmysql_pass
GRANT PROCESS ON *.* TO 'clustercheckuser'@'localhost' IDENTIFIED BY 'clustercheckpassword!';
FLUSH PRIVILEGES;
exit
检测配置文件
在全部控制节点新增心跳检测服务配置文件/etc/xinetd.d/mysqlchk,以controller01节点为例
全部控制节点
cat > /etc/xinetd.d/mysqlchk <<EOF
# default: on
# description: mysqlchk
service mysqlchk
{port = 9200disable = nosocket_type = streamprotocol = tcpwait = nouser = rootgroup = rootgroups = yesserver = /usr/bin/clusterchecktype = UNLISTEDper_source = UNLIMITEDlog_on_success =log_on_failure = HOSTflags = REUSE
}
EOF
每个控制节点启动心跳检测服务
每个控制节点,修改/etc/services,变更tcp9200端口用途,以controller01节点为例
vim /etc/services +10101
[root@controller01 ~]# vim /etc/services +10101
............
#wap-wsp 9200/tcp # WAP connectionless session service
mysqlchk 9200/tcp # mysqlchk
............
每个控制节点,启动xinetd服务,以controller01节点为例
systemctl daemon-reload
systemctl enable xinetd
systemctl start xinetd
systemctl status xinetd
[root@controller01 ~]# systemctl daemon-reload
[root@controller01 ~]# systemctl enable xinetd
[root@controller01 ~]# systemctl start xinetd
测试心跳检测脚本
在全部控制节点验证,以controller01节点为例
/usr/bin/clustercheck
[root@controller01 ~]# /usr/bin/clustercheck
https://www.cnblogs.com/netonline/p/9184691.html
设置心跳检测clustercheck
测试心跳检测脚本
!!! 心跳脚本测试失败,先关机,拍快照
poweroff
[root@controller01 ~]# systemctl daemon-reload
[root@controller01 ~]# systemctl enable xinetd
[root@controller01 ~]# systemctl start xinetd
[root@controller01 ~]# systemctl status xinetd
● xinetd.service - Xinetd A Powerful Replacement For InetdLoaded: loaded (/usr/lib/systemd/system/xinetd.service; enabled; vendor preset: enabled)Active: active (running) since Fri 2022-01-07 17:03:57 CST; 11min agoMain PID: 951 (xinetd)CGroup: /system.slice/xinetd.service└─951 /usr/sbin/xinetd -stayalive -pidfile /var/run/xinetd.pidJan 07 17:03:57 controller01 xinetd[951]: removing daytime
Jan 07 17:03:57 controller01 xinetd[951]: removing discard
Jan 07 17:03:57 controller01 xinetd[951]: removing discard
Jan 07 17:03:57 controller01 xinetd[951]: removing echo
Jan 07 17:03:57 controller01 xinetd[951]: removing echo
Jan 07 17:03:57 controller01 xinetd[951]: removing tcpmux
Jan 07 17:03:57 controller01 xinetd[951]: removing time
Jan 07 17:03:57 controller01 xinetd[951]: removing time
Jan 07 17:03:57 controller01 xinetd[951]: xinetd Version 2.3.15 started with libwrap ...n.
Jan 07 17:03:57 controller01 xinetd[951]: Started working: 0 available services
Hint: Some lines were ellipsized, use -l to show in full.
[root@controller01 ~]# /usr/bin/clustercheck
HTTP/1.1 503 Service Unavailable
Content-Type: text/plain
Connection: close
Content-Length: 44Percona XtraDB Cluster Node is not synced.
[root@controller01 ~]#
相关文章:
OpenStack HA高可用集群Train版-0集群环境准备
OpenStack HA高可用集群Train版-0集群环境准备 目录 主机配置1.主机名2.网卡配置网卡UUID配置主机名解析配置免密登录防火墙相关配置时间同步配置 二、基础软件安装数据库构建数据库集群设置心跳检测clustercheck准备脚本创建心跳检测用户,(任意控制节点)检测配置文件每个控制节…...
Python3与Dubbo3.1通讯解决方案(dubbo-python)
【文章非VIP可读,如果发现阅读限制为系统自动修改阅读权限,请留言我改回】 概述 最近AI项目需要java与python通讯,两边都是比较新的版本。因此需要双方进行通讯,在这里记录一下所采用的方案和关键点。 JAVA调用Python python通…...
深入探索 Java 区块链技术:从核心原理到企业级实践
一、Java 与区块链的天然契合 1.1 区块链技术的核心特征 区块链作为一种分布式账本技术,其核心特征包括: 去中心化:通过 P2P 网络实现节点自治,消除对中央机构的依赖。不可篡改性:利用哈希链和共识机制确保数据一旦…...
NV214NV217美光闪存固态NV218NV225
NV214NV217美光闪存固态NV218NV225 在当今数据驱动的时代,固态硬盘(SSD)的性能直接决定了计算系统的效率上限。美光科技作为全球存储解决方案的领军者,其NV系列产品凭借尖端技术持续刷新行业标准。本文将围绕NV214、NV217、NV218、…...
第三方组件库:element-uiiviewVant
第三方组件库:element-ui 使用方法: 1.引入样式 <!-- 引入element-ui样式 --><link rel"stylesheet" type"text/css" href"http://unpkg.com/view-design/dist/styles/iview.css">2.引入vue <!-- 引入Vue …...
Qt实现 hello world + 内存泄漏(5)
文章目录 实现hello world的两种方式通过图形化的方式通过纯代码的方式1. 新老头文件的说明2.堆或栈上创建对象的选择3.QString的说明 内存泄漏问题 实现hello world的两种方式 通过图形化的方式 通过图形化的方式,在界面上创建出一个控件,显示出hello …...
13:图像处理—畸变矫正详解
1.制作标定板和描述文件 (用PS软件打印) * 0.00375 mark 点间距 , 不是 点的直径//倒数第二个就是描述文件 gen_caltab(7,7,0.00375,0.5,caltab_30mm.descr,30-30.ps) * 1 比 1 打印 。Photoshop 格式 2.把标定板调正 调正的目的是为了…...
Prompt compress 技术探究-LLMLingua
Prompt summary:是通过精心设计的提示词(prompt)引导大型语言模型(如 GPT-4)生成特定风格或结构的摘要。其目标不仅是压缩信息,还包括满足特定的格式要求、风格偏好或任务需求,所以和一般的文本…...
Python|Pyppeteer实现自动登录小红书(32)
前言 本文是该专栏的第32篇,结合优质项目案例持续分享Pyppeteer的干货知识,记得关注。 本文中,笔者以小红书为例,基于Pyppeteer实现自动登录“小红书”。 需要注意的是,对Pyppeteer不太熟悉的同学,可往前翻阅本专栏前面介绍的Pyppeteer知识点,本专栏将带你了解并熟练使…...
Milvus(13):自定义分析器、过滤器
1 自定义分析器 1.1 标准标记符 Milvus 中的standard 令牌分割器根据空格和标点符号分割文本,适用于大多数语言。要配置使用standard 令牌转换器的分析器,请在analyzer_params 中将tokenizer 设置为standard 。 analyzer_params {"tokenizer&quo…...
调试Cortex-M85 MCU启动汇编和链接命令文件 - 解题一则
调试Cortex-M85 MCU启动汇编和链接命令文件 - 解题一则 苏勇 Andrew, 2025-05 最近在Keil中调试一款新的Cortex-M85内核MCU的SDK代码时,从原有其它芯片的工程中引入了汇编语言编写的启动代码和配套的sct文件,结果总是报错,清理到最后&#…...
SpringMVC——第五章:视图View
一、SpringMVC中视图的实现原理 1.Spring MVC视图支持可配置 在Spring MVC中,视图View是支持定制的,例如我们之前在 springmvc.xml 文件中进行了如下的配置: <!--视图解析器--> <bean id"thymeleafViewResolver" class…...
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】3.4 数据重复与去重(IDENTITY COLUMN/UNIQUE约束)
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 PostgreSQL数据分析实战:数据质量分析之数据重复与去重(IDENTITY COLUMN/UNIQUE约束)3.4 数据重复与去重3.4.1 数据重复的影响与识别3.4.…...
数据分析之药物-基因-代谢物
记录一下最近的数据分析过程: 假如我有一个Dataframe,有两列[Drug, Gene],我想构造一个矩阵,行名为Drug,列名为Gene,值为0或者1,其中0表示药物的靶点是该基因,0表示不是靶点。 &am…...
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】3.2 缺失值检测与处理(NULL值填充/删除策略)
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 缺失值检测与处理全攻略:NULL值填充与删除策略实战3.2 缺失值检测与处理3.2.1 缺失值类型与业务影响3.2.1.1 缺失值的三种形态3.2.1.2 业务影响分级 3.2.2 缺失值…...
科普简洁版:同态加密——密码学的未来瑰宝
文章目录 一、同态加密的基本概念1.1 什么是同态加密1.2 同态加密的数学本质1.3 同态加密的类型 二、主要同态加密方案详解2.1 ElGamal加密2.2 Paillier加密2.3 Gentry的完全同态加密方案2.4 BGV方案2.5 BFV方案2.6 CKKS方案 三、同态加密的关键技术3.1 噪声管理技术3.2 多项式…...
时序分解 | Matlab基于WOA-MVMD鲸鱼算法优化多元变分模态分解
时序分解 | Matlab基于WOA-MVMD鲸鱼算法优化多元变分模态分解 目录 时序分解 | Matlab基于WOA-MVMD鲸鱼算法优化多元变分模态分解效果一览基本介绍程序设计参考资料 效果一览 基本介绍 WOA-MVMD鲸鱼算法优化多元变分模态分解时间序列信号分解 可直接运行 分解效果好 适合作为创…...
模型部署与提供服务
工具准备 FastApi (提供接口服务) LLamafactory(模型测试) AutoDL-SSH(隧道工具) 结构目录 app ├── api.sh ├── lawbot_infer.py ├── main.py ├── models.py ├── prompts │ ├── chat.jinja2 │ ├── prediction.jinja2 │…...
【Linux】深入理解程序地址空间
🌟🌟作者主页:ephemerals__ 🌟🌟所属专栏:Linux 目录 前言 一、什么是程序地址空间 二、深入理解程序地址空间 1. 引例 2. 理解地址转化 3. 再谈程序地址空间 4. 补充知识 总结 前言 在现代操作系…...
基于AWS Marketplace的快速解决方案:从选型到部署实战
1. 引言:为什么选择AWS Marketplace? 在数字化转型的背景下,企业需要快速获取成熟的软件工具和服务以降低开发成本。AWS Marketplace 作为亚马逊云科技的官方应用商店,提供超过万款预配置的第三方和AWS原生解决方案,涵…...
Android 常用输入控件
一 控件名称 TextView二 示例代码 <?xml version="1.0" encoding="utf-8"?> <androidx.coordinatorlayout.widget.CoordinatorLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.a…...
ubuntu修改时区和设置24小时格式时间
这里写目录标题 一、修改时区二、设置24小时格式时间endl 一、修改时区 使用timedatectl命令更改当前时区为东八区[rootubuntu24-16:~]# timedatectl list-timezones | grep -i shanghai Asia/Shanghai [rootubuntu24-16:~]# timedatectl set-timezone Asia/Shanghai [rootubu…...
Android之Button、ImageButton、ChipGroup用法
一 控件名称及UI代码 Button、ImageButton、ChipGroup <?xml version="1.0" encoding="utf-8"?> <androidx.coordinatorlayout.widget.CoordinatorLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:app=&qu…...
【中间件】brpc_基础_用户态线程中断
bthread之用户态线程中断 源码 1 简介 interrupt_pthread 核心功能是 通过信号机制中断阻塞的 pthread 线程,以实现线程的协作式中断。 2 核心功能与设计 2.1 信号选择与注册 信号选择:使用 SIGURG 作为中断信号。 原因:SIGURG 通常用于…...
MATLAB中tabulate函数——先验概率的简单估计
load fisheriris X meas(:,1:2); Y species; labels unique(Y); tabulate(Y)ValueCountPercentsetosa5033.33%versicolor5033.33%virginica5033.33%...
修复笔记:SkyReels-V2 项目中的 torch.load 警告
#工作记录 一、问题描述 在运行项目时,出现以下警告: FutureWarning: You are using torch.load with weights_onlyFalse (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pic…...
[特殊字符] 人工智能大模型之开源大语言模型汇总(国内外开源项目模型汇总) [特殊字符]
Large Language Model (LLM) 即大规模语言模型,是一种基于深度学习的自然语言处理模型,它能够学习到自然语言的语法和语义,从而可以生成人类可读的文本。 所谓 "语言模型",就是只用来处理语言文字(或者符号…...
自监督学习(Self-supervised Learning)李宏毅
目录 Self-supervised Learning简介: BERT : How to use BERT case1:sequence to class 语言积极性OR消极性判断 case2:sequence to sequence句子中的词语词性标注 case3:sequence2 to class两个句子是不是一个为前提一个为…...
数字化时代下,软件测试中的渗透测试是如何保障安全的?
在如今数字化与信息化的时代,软件测试中存在渗透测试,其位置十分重要,它借助模拟恶意攻击的方式,去发现软件系统所存在的漏洞以及安全问题,这是保障软件安全的关键环节,接下来我会对它的各个方面进行详细介…...
内容中台的AI中枢是什么?
智能算法与知识图谱融合引擎 现代内容中台的核心竞争力在于智能算法与知识图谱的深度融合,这种技术组合构建了动态演化的认知网络。通过将机器学习模型与领域知识图谱进行耦合,系统不仅能识别文本、图像、视频等多模态数据的关联特征,还能实…...
PostgreSQL 的 REINDEX 命令
PostgreSQL 的 REINDEX 命令 REINDEX 是 PostgreSQL 中用于重建索引的重要命令,它可以解决索引损坏、索引膨胀或性能下降等问题。 一 REINDEX 基本语法 -- 重建单个索引 REINDEX [ ( option [, ...] ) ] { INDEX | TABLE | SCHEMA } [ CONCURRENTLY ] name REIND…...
GNOME扩展:Bing壁纸
难点 网络请求(Soup) 下载文件(Soup) 读写设置(Gio.Settings) 源码 import GLib from "gi://GLib"; import Gio from gi://Gio; import St from gi://St; import Soup from gi://Soup;import { Extension } from resource:///org/gnome/shell/extensions/extens…...
BUUCTF——Fake XML cookbook
BUUCTF——Fake XML cookbook 进入靶场 只有一个登录框 先弱口令万能密码试一下吧 弱口令和万能密码都失败了 找其他突破口 F12看看 发现xml代码 function doLogin(){var username $("#username").val();var password $("#password").val();if(user…...
【数据结构】线性表--链表
【数据结构】线性表--链表 一.前情回顾二.链表的概念三.链表的实现1.链表结点的结构:2.申请新结点函数:3.尾插函数:4.头插函数:5.尾删函数:6.头删函数:7.在指定结点之前插入:8.在指定结点之后插…...
2022年第十三届蓝桥杯省赛B组Java题解
2022年第十三届蓝桥杯省赛B组Java题解 个人心得: 2022年蓝桥杯省赛Java B组共包含10道题目,其中填空题2道(A、B),编程题8道(C-J)。题目覆盖数论、字符串处理、动态规划、数据结构等核心知识点…...
【操作系统】死锁
1. 定义 死锁是指两个或多个进程(或线程)在执行过程中,因争夺资源而造成的一种僵局,每个进程都无限期地等待其他进程释放它们所持有的资源。在这种情况下,没有任何进程能够继续执行,除非有外部干预。 2. …...
Ubuntu22.04及以上版本buildroot SIGSTKSZ 报错问题
本文提供一种解决 Buildroot SIGSTKSZ 报错途径 解决途径来源参考:Buildroot error when building with Ubuntu 21.10 其出现原因在于 GNU C Library 2.34 release announcement: Add _SC_MINSIGSTKSZ and _SC_SIGSTKSZ. When _DYNAMIC_STACK_SIZE_SOU…...
postgresql数据库基本操作
1. 连接 PostgreSQL 数据库 首先,使用 psql 命令行工具连接到数据库。如果是本地连接,命令格式如下: psql -U postgres -d <数据库名称> -h <主机地址>其中: -U postgres:表示以 postgres 用户身份登录…...
【运维】构建基于Python的自动化运维平台:用Flask和Celery打造高效管理工具
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 随着企业IT基础设施的复杂性不断增加,手动运维已无法满足高效管理的需求。本文详细介绍如何基于Python构建一个自动化运维平台,利用Flask…...
ES6入门---第三单元 模块三:async、await
async function fn(){ //表示异步:这个函数里面有异步任务 let result await xxx //表示后面结果需要等待 } 读取文件里数据实例: const fs require(fs);//简单封装 fs封装成一个promise const readFile function (fileName){return…...
洛谷 P2866 [USACO06NOV] Bad Hair Day S
题目描述 农夫约翰有 N 头奶牛正在过乱头发节。 每一头牛都站在同一排面朝右,它们被从左到右依次编号为 1,2,⋯,N。编号为 i 的牛身高为 hi。第 N 头牛在最前面,而第 1 头牛在最后面。 对于第 i 头牛前面的第 j 头牛,如果 hi>hi1…...
TS 变量类型生成
TS简单类型注解 let count:number 15 let myName:string MIO let isLoading:boolean false let a:null null let b:undefined undefined let s:symbol Symbol()console.log(hello ts)TS数组类型 数组类型两种写法: 问题:数组中只能存在单一类型数…...
工业大模型:从设备诊断到工艺重构
引言 工业大模型正在引发制造业认知革命。据埃森哲研究,到2026年全球工业大模型市场规模将突破280亿美元,其中工艺优化应用占比达42%。本文将系统解析工业大模型的"预训练-领域适配-应用落地"技术路径,并通过设备健康诊断与工艺参数生成的实践案例,展示如何构建…...
【项目篇之统一内存操作】仿照RabbitMQ模拟实现消息队列
我们的操作分为两种,一种是在内存上进行统一的操作,一种是在硬盘上面操作,今天我写的文章是编写了一个MemoryDataCenter类来实现了 在内存上面的统一操作: 实现统一内存操作 如何使用内存来组织数据 创建一个类来统一管理内存上的…...
强化学习机器人模拟器——GridWorld:一个用于强化学习的 Python 环境
GridWorld 是一个为强化学习(Reinforcement Learning, RL)实验设计的多功能 Python 环境。它提供了一个可定制的二维网格,智能体(agent)需要从起始位置导航到目标位置,避开障碍物、穿越泥泞单元格并收集奖励。本篇博客将详细介绍 grid_world.py 代码中实现的 GridWorld 环…...
DeepSeek Copilot idea插件推荐
🌌 DeepSeek Copilot for IntelliJ IDEA 让 AI 成为你的编程副驾驶,极速生成单元测试 & 代码注释驱动开发! 🚀 简介 DeepSeek Copilot 是一款为 IntelliJ IDEA 打造的 AI 编程助手插件,它能够智能分析你的代码逻辑…...
vue-cropper实现图片裁剪
一、什么是vue-cropper? Vue-Cropper 是一个基于 Vue.js 的图片裁剪组件库,专为 Web 应用设计。当你在网上搜索的时候发现还有一个叫cropper的库,下面是他们的区别: 特性cropper.jsvue-cropper框架依赖纯 JavaScript&am…...
MPI,Pthreads和OpenMP等并行实验环境配置
(假设你已按照文档前面的步骤正确安装了 VMware 和 Ubuntu 20.04) 第一部分:安装 C/OpenMP/Pthreads 环境(修正后) 打开终端: 在 Ubuntu 中启动终端应用程序。 更新软件包列表: sudo ap…...
Spring AI Advisors API:AI交互的灵活增强利器
Spring AI Advisors API:AI交互的灵活增强利器 前言 在当今的软件开发领域,随着人工智能技术的飞速发展,将AI融入应用程序变得越来越普遍。Spring AI作为一个强大的框架,为开发者提供了便捷的方式来实现这一目标。其中的Advisor…...
排序功法入门指南【江湖算法笔记】
话说江湖风云变幻,各路英雄好汉行走江湖,总得有个名号排行。若问“东邪西毒南帝北丐”谁强谁弱,总得排个座次不是?这排序之道,恰似武功秘籍,练好了能号令群雄,练岔了怕是要被笑掉大牙࿰…...