从小白到大神之路之学习运维第49天---第三阶段----MHA高可用集群数据库的安装部署

第三阶段基础

时  间:2023年6月29日

参加人:全班人员

内  容:

MHA高可用数据库集群

目录

一、MHA基础

(一)简介

(二)发挥过程

(三)组成

(四)原理

(五)条件

(六)架构

(七)工作流程

二、MHA工具介绍

(一)Manager管理节点工具包

(二)Node节点工具包

(三)注  意

三、MHA安装部署

环境配置: 所有操作系统均为centos 7.x 64bit

 1、关闭防火墙:(所有服务器)

2.配置所有主机名映射(所有服务器)

3、同步时区

4.安装MHA node及相关perl依赖包(所有服务器)

5.安装MHA Node(所有服务器)

6.管理节点huyang5安装MHA Manger(1)(管理服务器)

7.配置SSH密钥对验证(所有服务器)

8.安装mysql(所有服务器)

搭建主从复制环境

主库设置:(huyang1)

步骤一:修改配置文件/etc/my.cnf

步骤二:重启服务后进入数据库

步骤三:授权复制权限

步骤四:查看主状态

步骤五:创建监控用户

从库一设置:(huyang4)备用主库

步骤一:修改配置文件/etc/my.cnf

步骤二:重启服务后进入数据库

步骤三:授权复制权限

步骤四:连接主库

步骤五:创建监控用户

从库二设置:(huyang2)

步骤一:修改配置文件/etc/my.cnf

步骤二:重启服务后进入数据库

步骤三:授权复制权限

步骤四:连接主库

步骤五:创建监控用户

从库三设置:(huyang3)

步骤一:修改配置文件/etc/my.cnf

步骤二:重启服务后进入数据库

步骤三:授权复制权限

步骤四:连接主库

步骤五:创建监控用户

配置MHA环境:(huyang5)

步骤一:建立工作目录及并设置配置文件

步骤二:配置故障转移脚本并赋权

部署完成,检查结果:(huyang5操作)

检查MHA ssh通信状态

检查整个集群的状态  

检查manager状态

开启监控再查看为开启状态

开启manager监控

关闭监控

验证MHA高可用当主库服务器因为某种原因宕机之后的变化:

步骤一:检查当前的端口(主库huyang1)

步骤二:停止主库服务,查看变化

验证当主库服务器宕机恢复之后的变化:

步骤一:检查当前的端口(主库huyang1)

步骤二:开启主库服务,查看变化

步骤三:将huyang1连接至huyang4

步骤四:添加进huyang5的监听文件并开启监控

步骤五:关闭现有主库huyang4,查看变化

总  结:


一、MHA基础

总结各个服务以及其端口

Master High Availability

(一)简介

优秀的作为MySQL高可用性环境下故障切换和主从角色提升的高可用软件

(二)发挥过程

在MySQL故障切换过程中,MHA能做到在0∽30秒之内自动完成数据库的主从故障切换操作;

在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性。

(三)组成

MHA Manager(管理节点)

MHA Node(数据节点)

(四)原理

MHA Node运行在每台MySQL服务器及Manager服务器上;

MHA Manager会定时探测集群中的master节点

当master出现故障时,它可以自动将拥有最新数据的slave提升为新的master;

将所有其他的slave重新指向新提升的master;

通过检测二进制文件的时间节点和操作ID,从数据库谁最新,谁就变成主。

(五)条件

支持一主多从的架构,要搭建MHA,要求一个MySQL复制集群中必须最少有三台数据库服务器;

一主二从,即一台充当master,一台充当备用master,另外一台充当从库。

(六)架构

一个MHA Manger,检测多个主数据库,主数据库下有多个从数据库;

每一个主数据库和从数据库称之为复制组;

当主数据库坏掉,检测从谁最新成为主。

(七)工作流程

从宕机崩溃的master上尝试保存二进制日志事件(binlog events);

识别含有最新更新的slave服务器;

应用差异的中继日志(relay log)到其他的slave;

应用从master保存的二进制日志事件(binlog events);

提升一个slave为新的master服务器;

将其他的slave连接指向新的master进行主从复制。

二、MHA工具介绍

(一)Manager管理节点工具包

masterha_check_ssh     检查MHA的SSH配置状况

masterha_check_repl    检查MySQL复制状况

masterha_manger        启动MHA

masterha_check_status  检测当前MHA运行状态

masterha_master_monitor检测master是否宕机

masterha_master_switch

控制故障转移(自动或者手动)第一次自动,之后手动干涉

masterha_conf_host  添加或删除配置的server信息

(二)Node节点工具包

这些工具通常由MHA Manager的脚本触发,无需人为操作

save_binary_logs  保存和复制master的二进制日志

apply_diff_relay_logs  识别差异的中继日志事件并将其差异的事件应用于其他的slave

filter_mysqlbinlog  去除不必要的ROLLBACK事件(MHA已不再使用这个工具)

purge_relay_logs 清除中继日志(不会阻塞SQL线程)

从变成主之后要清除,否则会影响SQL线程,主服务不需要

(三)注  意

为了尽可能的减少主库硬件损坏宕机造成的数据丢失,因此在配置MHA的同时建议配置成MySQL 5.5的半同步复制;

但不是必须

三、MHA安装部署

环境配置: 所有操作系统均为centos 7.x 64bit

至少五台主机,一主三从一Manger

三从主指定为主的备胎,当主坏掉,他顶上,但默认情况还是从的角色

例:

IP地址

主机名

任  务

192.168.59.137

huyang1

主 库

192.168.59.138

huyang2

从库1

192.168.59.140

huyang3

从库2

192.168.59.142

huyang4

从库3(备用主库)

192.168.59.144

huyang5

管理节点

192.168.59.146

huyang6

VIP

 1、关闭防火墙:(所有服务器)

systemctl stop firewalld

iptables -F   

setenforce 0

2.配置所有主机名映射(所有服务器)

cat << END >> /etc/hosts

192.168.59.137 huyang1

192.168.59.138 huyang2

192.168.59.140 huyang3

192.168.59.142 huyang4

192.168.59.144 huyang5

END

映射完之后需要用ip地址的可以用主机名

3、同步时区

[huyang1]yum -y install ntp

         systemctl start ntpd

[huyang2/3/4/5/6]ntpdate huyang1

4.安装MHA node及相关perl依赖包(所有服务器)

wget -O /etc/yum.repos.d/CentOS-Base.repo

http://mirrors.aliyun.com/repo/Centos-7.repo

下载阿里源

yum -y install epel-release  下载epel源

yum install -y perl-DBD-MySQL.x86_64

perl-DBI.x86_64 perl-CPAN perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker

5.安装MHA Node(所有服务器)

rz  上传文件包(mha4mysql-node-0.56.tar.gz)

tar xf mha4mysql-node-0.56.tar.gz  解压

cd mha4mysql-node-0.56/    切换目录

perl Makefile.PL 用perl

语言编译文件,生成Makefile文件

make && make install  编译安装

查看结果:MHA Node安装完后会在 /usr/local/bin生成以下脚本  ls -l /usr/local/bin/   有4个

6.管理节点huyang5安装MHA Manger(1)(管理服务器)

安装MHA Manger之前也需要安装MHA Node

安装MHA Manger依赖的perl模块

yum install -y perl perl-Log-Dispatch

perl-Parallel-ForkManager perl-DBD-MySQL perl-DBI perl-Time-HiRes   依赖

rz  上传依赖包

perl-Config-Tiny-2.14-7.el7.noarch.rpm

用perl软件配置Manger

rpm  -ivh

perl-Config-Tiny-2.14-7.el7.noarch.rpm

安装MHA Manger软件包

rz  上传管理节点安装包

tar xf mha4mysql-manager-0.56.tar.gz

cd mha4mysql-manager-0.56/

perl Makefile.PL

make && make install

安装完成后会有以下脚本文件

查看结果:MHA Manger e安装完后会在/usr/local/bin/

生成以下脚本  ls -l /usr/local/bin/   有13个

7.配置SSH密钥对验证(所有服务器)

manger生成传给其他服务器,并验证,其他服务器直接互相传密钥,无需验证

服务器之间需要实现密钥对验证

【huyang1/2/3/4/5】ssh-keygen -t rsa

【huyang1/2/3/4/5】

ssh-copy-id -i .ssh/id_rsa.pub root@huyang1

cat /root/.ssh/authorized_keys

scp .ssh/authorized_keys root@huyang2:.ssh/

scp .ssh/authorized_keys root@huyang3:.ssh/

scp .ssh/authorized_keys root@huyang4:.ssh/

scp .ssh/authorized_keys root@huyang5:.ssh/

Manger生成密钥对传给其他数据库连接每个主机测试

ssh 加主机名

[huyang5]ssh huyang1

[huyang5]ssh huyang2

[huyang5]ssh huyang3

[huyang5]ssh huyang4

[huyang5]ssh huyang5

 因为第一次连接的时候需要输入yes影响后期故障切换时,对于每个主机的SSH控制;

数据库之间生成密钥对,保证一个数据库有其他三个数据库的密钥,无需连接测试.

8.安装mysql(所有服务器)

数据库服务器上的操作

yum -y install mariadb mariadb-server mariadb-devel

systemctl start mariadb

mysqladmin -u root password 123456

设置数据库初始密码

搭建主从复制环境

主库设置:(huyang1)

步骤一:修改配置文件/etc/my.cnf

[mysqld]

server-id = 1

log-bin=master-bin

log-slave-updates=true

relay_log_purge=0

步骤二:重启服务后进入数据库

systemctl restart mariadb

mysql -uroot -p123456

步骤三:授权复制权限

grant replication slave on *.* to

'repl'@'192.168.59.%' identified by '123456';

flush privileges;  刷新权限

步骤四:查看主状态

 show master status;

步骤五:创建监控用户

为监控节点服务较高的权限

grant all privileges on *.* to

'root'@'192.168.59.%' identified  by '123456';

  flush privileges;

为自己的主机名授权

grant all privileges on *.* to 'root'@'huyang1'

identified  by '123456';

从库一设置:(huyang4)备用主库

步骤一:修改配置文件/etc/my.cnf

[mysqld]

server-id = 2

log-bin=master-bin

log-slave-updates=true

relay_log_purge=0

步骤二:重启服务后进入数据库

systemctl restart mariadb

mysql -uroot -p123456

步骤三:授权复制权限

grant replication slave on *.* to

'repl'@'192.168.59.%' identified by '123456';

flush privileges;  刷新权限

步骤四:连接主库

stop slave;

change master to

master_host='192.168.59.137',master_user='repl',master_password='123456',master_log_file='master-bin.000003',master_log_pos=245;

start slave;

show slave status\G;

步骤五:创建监控用户

为监控节点服务较高的权限

grant all privileges on *.* to

'root'@'192.168.59.%' identified  by '123456';

  flush privileges;

为自己的主机名授权

grant all privileges on *.* to 'root'@'huyang4'

identified  by '123456';

从库二设置:(huyang2)

步骤一:修改配置文件/etc/my.cnf

[mysqld]

server-id = 3

log-bin=master-bin

log-slave-updates=true

relay_log_purge=0

步骤二:重启服务后进入数据库

systemctl restart mariadb

mysql -uroot -p123456

步骤三:授权复制权限

grant replication slave on *.* to

'repl'@'192.168.59.%' identified by '123456';

flush privileges;  刷新权限

步骤四:连接主库

stop slave;

change master to

master_host='192.168.59.137',master_user='repl',master_password='123456',master_log_file='master-bin.000003',master_log_pos=245;

start slave;

show slave status\G;

步骤五:创建监控用户

为监控节点服务较高的权限

grant all privileges on *.* to

'root'@'192.168.59.%' identified  by '123456';

  flush privileges;

为自己的主机名授权

grant all privileges on *.* to 'root'@'huyang2'

identified  by '123456';

从库三设置:(huyang3)

步骤一:修改配置文件/etc/my.cnf

[mysqld]

server-id = 4

log-bin=master-bin

log-slave-updates=true

relay_log_purge=0

步骤二:重启服务后进入数据库

systemctl restart mariadb

mysql -uroot -p123456

步骤三:授权复制权限

grant replication slave on *.* to

'repl'@'192.168.59.%' identified by '123456';

flush privileges;  刷新权限

步骤四:连接主库

stop slave;

change master to

master_host='192.168.59.137',master_user='repl',master_password='123456',master_log_file='master-bin.000003',master_log_pos=245;

start slave;

show slave status\G;

步骤五:创建监控用户

为监控节点服务较高的权限

grant all privileges on *.* to

'root'@'192.168.59.%' identified  by '123456';

  flush privileges;

为自己的主机名授权

grant all privileges on *.* to 'root'@'huyang3'

identified  by '123456';

配置MHA环境:(huyang5)

步骤一:建立工作目录及并设置配置文件

mkdir /etc/masterha创建配置目录复制模板文件

cp mha4mysql-manager-0.56/samples/conf/app1.cnf  /etc/masterha  软件包解压后的目录里面有样例配置文件

vim /etc/masterha/app1.cnf   修改配置文件

[server default]

#设置manager的工作日志

manager_workdir=/var/log/masterha/app1

#设置manager的日志,这两条都是默认存在的

manager_log=/var/log/masterha/app1/manager.log

#设置master默认保存binlog的位置,以便MHA可以找到master日志

master_binlog_dir=/var/lib/mysql

#设置自动failover时候的切换脚本

master_ip_failover_script= /usr/local/bin/master_ip_failover

#设置mysql中root用户的密码

password=123456

user=root

#ping包的时间间隔

ping_interval=1

#设置远端mysql在发生切换时保存binlog的具体位置

remote_workdir=/tmp

#设置复制用户的密码和用户名

repl_password=123456

repl_user=repl

[server1]

hostname=huyang1

port=3306

[server2]

hostname=huyang4

candidate_master=1

port=3306

check_repl_delay=0

[server3]

hostname=huyang2

port=3306

[server4]

hostname=huyang3

port=3306

步骤二:配置故障转移脚本并赋权

vim /usr/local/bin/master_ip_failover修改配置文件

chmod +x /usr/local/bin/master_ip_failover

赋予执行权限

#!/usr/bin/env perl

use strict;

use warnings FATAL => 'all';

use Getopt::Long;

my (

$command, $ssh_user, $orig_master_host, $orig_master_ip,

$orig_master_port, $new_master_host, $new_master_ip, $new_master_port,

);

my $vip = '192.168.59.146';          

my $key = "1";

my $ssh_start_vip = "/sbin/ifconfig ens33:$key $vip";

my $ssh_stop_vip = "/sbin/ifconfig ens33:$key down";

$ssh_user = "root";

GetOptions(

'command=s' => \$command,

'ssh_user=s' => \$ssh_user,

'orig_master_host=s' => \$orig_master_host,

'orig_master_ip=s' => \$orig_master_ip,

'orig_master_port=i' => \$orig_master_port,

'new_master_host=s' => \$new_master_host,

'new_master_ip=s' => \$new_master_ip,

'new_master_port=i' => \$new_master_port,

);

exit &main();

sub main {

print "\n\nIN SCRIPT TEST====$ssh_stop_vip==$ssh_start_vip===\n\n";

if ( $command eq "stop" || $command eq "stopssh" ) {

# $orig_master_host, $orig_master_ip, $orig_master_port are passed.

# If you manage master ip address at global catalog database,

# invalidate orig_master_ip here.

my $exit_code = 1;

#eval {

# print "Disabling the VIP on old master: $orig_master_host \n";

# &stop_vip();

# $exit_code = 0;

#};

eval {

print "Disabling the VIP on old master: $orig_master_host \n";

#my $ping=`ping -c 1 10.0.0.13 | grep "packet loss" | awk -F',' '{print $3}' | awk '{print $1}'`;

#if ( $ping le "90.0%"&& $ping gt "0.0%" ){

#$exit_code = 0;

#}

#else {

&stop_vip();

# updating global catalog, etc

$exit_code = 0;

#}

};

if ($@) {

warn "Got Error: $@\n";

exit $exit_code;

}

exit $exit_code;

}

elsif ( $command eq "start" ) {

# all arguments are passed.

# If you manage master ip address at global catalog database,

# activate new_master_ip here.

# You can also grant write access (create user, set read_only=0, etc) here.

my $exit_code = 10;

eval {

print "Enabling the VIP - $vip on the new master - $new_master_host \n";

&start_vip();

$exit_code = 0;

};

if ($@) {

warn $@;

exit $exit_code;

}

exit $exit_code;

}

elsif ( $command eq "status" ) {

print "Checking the Status of the script.. OK \n";

`ssh $ssh_user\@$orig_master_ip \" $ssh_start_vip \"`;

exit 0;

}

else {

&usage();

exit 1;

}

}

# A simple system call that enable the VIP on the new master

sub start_vip() {

`ssh $ssh_user\@$new_master_host \" $ssh_start_vip \"`;

}

# A simple system call that disable the VIP on the old_master

sub stop_vip() {

`ssh $ssh_user\@$orig_master_host \" $ssh_stop_vip \"`;

}

sub usage {

print

"Usage: master_ip_failover --command=start|stop|stopssh|status --orig_master_host=host --orig_master_ip=ip --orig_master_port=port --

new_master_host=host --new_master_ip=ip --new_master_port=port\n"; }

部署完成,检查结果:(huyang5操作)

检查MHA ssh通信状态

masterha_check_ssh --conf=/etc/masterha/app1.cnf

返回 successfully表示没有问题

检查整个集群的状态  

masterha_check_repl --conf=/etc/masterha/app1.cnf

返回ok表示没有问题

检查manager状态

masterha_check_status--conf=/etc/masterha/app1.cnf

如果正常会显示"PING_OK"

NOT_RUNNING",代表MHA监控没有开启

开启监控再查看为开启状态

开启manager监控

nohup masterha_manager

--conf=/etc/masterha/app1.cnf --remove_dead_master_conf --ignore_last_failover<

/dev/null >/var/log/masterha/app1/manager.log 2>&1 &

--remove_dead_master_conf

当发生主从切换后,老的主库的ip将会从配置文件中移除

--manger_log  日志存放位置

--ignore_last_failover  在缺省情况下,如果MHA检测到连续发生宕机,且两次宕机间隔不足8小时的话,则不会进行Failover,之所以这样限制是为了避免ping-pong效应。该参数代表忽略上次MHA触发切换产生的文件,默认情况下,MHA发生切换后会在日志目录,也就是上面设置的/data产生app1.failover.complete文件,下次再次切换的时候如果发现该目录下存在该文件将不允许触发切换,除非在第一次切换后收到删除该文件,为了方便,这里设置为--ignore_last_failover

关闭监控

masterha_stop --conf=/etc/masterha/app1.cnf

验证MHA高可用当主库服务器因为某种原因宕机之后的变化:

步骤一:检查当前的端口(主库huyang1)

huyang1】ip a|grep ens33

可以发现有两个,一个是主库的ip,另一个是vip的端口

步骤二:停止主库服务,查看变化

【huyang1】systemctl stop mariadb

【huyang2】show slave status\G;

【huyang3】show slave status\G;

【huyang4】show slave status\G;

【huyang4】ip a|grep ens33;

【huyang4】show master status;(成为主服务器)

【huyang5】 

masterha_check_repl --conf=/etc/masterha/app1.cnf

【huyang5】 vim /etc/master/app1.cong

可以发现监听的文件内已经不再监听huyang1

验证当主库服务器宕机恢复之后的变化:

步骤一:检查当前的端口(主库huyang1)

【huyang1】ip a|grep ens33

可以发现只有一个端口了

步骤二:开启主库服务,查看变化

【huyang1】systemctl start mariadb

【huyang2/3】show slave status\G;

没有发生变化

【huyang4】show master status;(依旧是主服务器)

【huyang5】 vim /etc/master/app1.cong

可以发现监听的文件内依旧没有huyang1

步骤三:将huyang1连接至huyang4

change master to

master_host='192.168.59.142',master_user='repl',master_password='123456',master_log_file='master-bin.000005',master_log_pos=245;

步骤四:添加进huyang5的监听文件并开启监控

【huyang5】vim /etc/master/app1.conf

步骤五:关闭现有主库huyang4,查看变化

【huyang4】systemctl stop mariadb

【huyang4】ip a |grep ens33

【huyang1】ip a |grep ens33

【huyang1】show slave status;

【huyang1】show master status;变成主库

【huyang2/3】show slave status\G;

此时huyang2/3又变成了huyang1的从库

【huyang5】 vim /etc/master/app1.cong

可以发现监听的文件内已经不再监听huyang4

总  结:

  1、MHA高可用集群,在主机宕机之后,复制组里会有一台变成主库,若指定了备用库,则备用库成为新的主库,原主库的从库成为新主库的从库;

  2、指定备用库之后,主库宕机恢复之后,将成为独立的服务器,不会成为主库,宕机之后复制组的状态不会改变,若有需要,则需手动指定成为新主库的从库;在指定宕机恢复主库为备用库主库的从库之后,备用库主库宕机,宕机恢复主库成为新的主库,来回切换;

  3、管理库的监听需要手动的进行切换,监听的主库宕机之后,将会删除其信息,恢复之后,需手动添加进监听文件。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

浅析便捷生活的新选择——抖音本地服务

抖音是一款风靡全球的短视频分享平台&#xff0c;其本地服务功能的发展也逐渐引起了广泛关注。本地服务是指抖音平台上的用户可以通过平台直接查找并使用周边的各种服务&#xff0c;比如美食外卖、快递配送、家政服务等。本地服务的发展对用户和商家都带来了很多便利和机遇。 首…

AIGC - Stable Diffusion 的 墨幽人造人 模型与 Tag 配置

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/131565068 Stable Diffusion的模型网站 LiblibAI&#xff1a;https://www.liblibai.com 墨幽人造人网址&#xff1a;https://www.liblibai.com/m…

React通过props的children实现插槽功能

可能会比较遗憾的说 React中并没有vue中的 slot 插槽概念 不过 可以通过props.children 实现类似功能 我们先创建一个React项目 在src下创建目录components 在下面创建一个dom.jsx组件 参考代码如下 import React from "react" export default class dom extends R…

Java版本+企业电子招投标系统源代码之电子招投标系统建设的重点和未来趋势

计算机与网络技术的不断发展&#xff0c;推动了社会各行业信息化的步伐。时至今日&#xff0c;电子政务、电子商务已经非常普及&#xff0c;云计算、大数据、工业4.0、“互联网”等发展理念也逐步深入人心&#xff0c;如何将传统行业与互联网科技有效结合起来&#xff0c;产生1…

开源实时监控 HertzBeat v1.3.2 发布, 更稳定更易用

HertzBeat 介绍 HertzBeat赫兹跳动 是一个拥有强大自定义监控能力&#xff0c;无需 Agent 的开源实时监控告警工具。 致力于易用友好&#xff0c;全WEB页面操作&#xff0c;鼠标点一点就能监控告警&#xff0c;零上手学习成本。 集 监控告警通知 为一体&#xff0c;支持对应用服…

为您的服务台提供6个基于AI的使用案例

人工智能&#xff08;AI&#xff09;正在向IT服务管理&#xff08;ITSM&#xff09;迈进&#xff0c;有望重新定义事物的工作方式。但是&#xff0c;人工智能是否会实现其承诺&#xff0c;并能够真正使ITSM更容易、更有效呢&#xff1f;这就是我们即将在此系列中所探讨的"…

网络安全入门教程(非常详细)从零基础入门到精通,看这一篇就够了。

基本方向: 1.web安全方面(指网站服务器安全方面,进行渗透测试,检测漏洞以及安全性) 2.逆向破解方面(对软件进行破解,脱壳) 以下内容是针对web安全方面的网络安全技术讲解: 如果你对网络安全方面没有任何的了解,如何成为一名网络安全这个问题对你来说很迷茫的话.接下来我将从以…

Scala里的WordCount 案例

7.7.5 普通 WordCount 案例 package chapter07object TestWordCount__简单版 {def main(args: Array[String]): Unit {//单词计数&#xff1a;将集合中出现的相同单词计数&#xff0c;进行计数&#xff0c;取计数排名的前三的结果val stringList List("Hello Scala Hbas…

ruoyi-vue | electron打包教程(超详细)

公司项目由于来不及单独做客户端了&#xff0c;所以想到用electron直接将前端打包程exe,dmg等格式的安装包。 由于使用的ruoyi-vue框架开发&#xff0c;所以这篇教程以ruoyi-vue为基础的。 环境说明 nodejs&#xff1a;v16.18.1npm&#xff1a;8.19.2ruoyi-vue&#xff1a;3.8…

【Java】网络编程与Socket套接字、UDP编程和TCP编程实现客户端和服务端通信

网络编程客户端和服务器Socket套接字流套接字TCP数据报套接字UDP对比TCP与UDP UDP编程DatagramSocket构造方法:普通方法&#xff1a; DatagramPacket构造方法:普通方法&#xff1a; 实现 TCP编程ServerSocket构造方法普通方法 Socket构造方法普通方法 实现 网络编程 为什么需要…

【算法集训之线性表篇】Day 02

文章目录 题目一思路分析代码实现效果 题目二思路分析代码实现效果 题目一 01.设置一个高效算法&#xff0c;将顺序表L的所有元素逆置&#xff0c;要求其空间复杂度为O(1)。 思路分析 首先&#xff0c;根据题目要求&#xff0c;空间复杂度度为O(1),则不能通过空间换时间的方…

安装qt qmake assistant 错误:could not find a Qt installation of ‘‘

1、执行qmake,提示下图的错误 Command qmake not found, but can be installed with: sudo apt install qtchooser 解决方法&#xff1a; sudo apt install qtchooser 2、执行qmake,提示一下错误 qmake: could not find a Qt installation of 解决步骤&#xff1a; 步骤一&a…