Redis 之集群模式

news2025/1/21 22:08:58

一 集群原理

集群,即Redis Cluster,是Redis 3.0开始引入的分布式存储方案。

集群由多个节点(Node)组成,Redis的数据分布在这些节点中。

集群中的节点分为主节点和从节点:只有主节点负责读写请求和集群信息的维护;从节点只进行主

节点数据和状态信息的复制。

Cluster模式是Redis的一种高级集群模式,它通过数据分片和分布式存储实现了负载均衡和高可用

性。

在Cluster模式下,Redis将所有的键值对数据分散在多个节点上。每个节点负责一部分数据,称为

槽位。通过对数据的分片,Cluster模式可以突破单节点的内存限制,实现更大规模的数据存储。

1 集群的作用

(1)数据分区:

数据分区(或称数据分片)是集群最核心的功能。

集群将数据分散到多个节点,一方面突破了Redis单机内存大小的限制,存储容量大大增加;另一

方面每个主节点都可以对外提供读服务和写服务,大大提高了集群的响应能力。

Redis单机内存大小受限问题,在介绍持久化和主从复制时都有提及;例如,如果单机内存太大,

bgsave和bgrewriteaof的fork操作可能导致主进程阻塞,主从环境下主机切换时可能导致从节点长

时间无法提供服务,全量复制阶段主节点的复制缓冲区可能溢出。

(2)高可用:

集群支持主从复制和主节点的自动故障转移(与哨兵类似);当任一节点发生故障

时,集群仍然可以对外提供服务。

2 Redis集群的作用和优势

高可用性:Redis集群可以在某个节点发生故障时,自动进行故障转移,保证服务的持续可用。

负载均衡:Redis集群可以将客户端请求分发到不同的节点上,有效地分摊节点的压力,提高系统

的整体性能。

容灾恢复:通过主从复制或哨兵模式,Redis集群可以在主节点出现故障时,快速切换到从节点,

实现业务的无缝切换。

数据分片:在Cluster模式下,Redis集群可以将数据分散在不同的节点上,从而突破单节点内存限

制,实现更大规模的数据存储。

易于扩展:Redis集群可以根据业务需求和系统负载,动态地添加或移除节点,实现水平扩展

3 Redis集群的数据分片:

  • Redis集群引入了哈希槽的概念
  • Redis集群有16384个哈希槽(编号0-16383)
  • 集群的每个节点负责一部分哈希槽

每个Key通过CRC16校验后对16384取余来决定放置哪个哈希槽,通过这个值,去找到对应的插槽

所对应的节点,然后直接自动跳转到这个对应的节点上进行存取操作

4 以3个节点组成的集群为例:

  • 节点A包含0到5460号哈希槽
  • 节点B包含5461到10922号哈希槽
  • 节点C包含10923到16383号哈希槽

5 Redis集群的主从复制模型

集群中具有A、B、C三个节点,如果节点B失败了,整个集群就会因缺少5461-10922这个范围的槽

而不可以用。

为每个节点添加一个从节点A1、B1、C1整个集群便有三个Master节点和三个slave节点组成,在节

点B失败后,集群选举B1位为的主节点继续服务。当B和B1都失败后,集群将不可用。

6 Redis集群的工作原理

集群有多组节点,每组节点负责一部分哈希槽。

读写数据时,先针对key根据crc16的算法得出一个结果,然后把结果对 16384 取余。通过这个值

去找到对应的哈希槽的节点,进行数据读写。

集群每组节点内做主从复制,当主节点宕机的时候,就会启用从节点。主节点负责读写请求和集群

信息的维护;从节点负责主节点数据和状态信息的复制。

二 搭建Redis 群集模式

redis的集群一般需要6个节点,3主3从。方便起见,这里所有节点在同一台服务器上模拟:

1 以端口号进行区分:

3个主节点端口号:6001/6002/6003,

对应的从节点端口号:6004/6005/6006。

     cluster              ①读写可以负载均衡 ②自动故障转移   ③突破了单机存储限制

  master作用          ①可读、可写            ②利用分布式特性 存储上限  ③进行故障转移

    slave作用           ①同步自身的master ②提供可读      ③冗余 备份 准备 顶替

2 搭建redis 集群

①关闭防火墙 进行解压
[root@mcb-11-14 ~]# cd /opt
[root@mcb-11-14 opt]# ls
rh
[root@mcb-11-14 opt]# rz -E
rz waiting to receive.
[root@mcb-11-14 opt]# ls
redis-5.0.7.tar.gz  rh
[root@mcb-11-14 opt]# tar zxvf r
redis-5.0.7.tar.gz  rh/                 
[root@mcb-11-14 opt]# tar zxvf redis-5.0.7.tar.gz 
[root@mcb-11-14 opt]# cd redis-5.0.7/
[root@mcb-11-14 redis-5.0.7]# ls
00-RELEASENOTES  COPYING  Makefile   redis.conf       runtest-moduleapi  src
BUGS             deps     MANIFESTO  runtest          runtest-sentinel   tests
CONTRIBUTING     INSTALL  README.md  runtest-cluster  sentinel.conf      utils
[root@mcb-11-14 redis-5.0.7]# rm -rf /var/run/yum.pid
[root@mcb-11-14 redis-5.0.7]# yum install gcc gcc-c++ make -y
[root@mcb-11-14 redis-5.0.7]# make PREFIX=/usr/local/redis install
[root@mcb-11-14 redis-5.0.7]# cd utils/
[root@mcb-11-14 utils]# ls
build-static-symbols.tcl  graphs             redis-copy.rb          speed-regression.tcl
cluster_fail_time.tcl     hashtable          redis_init_script      whatisdoing.sh
corrupt_rdb.c             hyperloglog        redis_init_script.tpl
create-cluster            install_server.sh  redis-sha1.rb
generate-command-help.rb  lru                releasetools
[root@mcb-11-14 utils]# ./install_server.sh
Welcome to the redis service installer
This script will help you easily set up a running redis server

Please select the redis port for this instance: [6379] 
Selecting default: 6379
Please select the redis config file name [/etc/redis/6379.conf] 
Selected default - /etc/redis/6379.conf
Please select the redis log file name [/var/log/redis_6379.log] 
Selected default - /var/log/redis_6379.log
Please select the data directory for this instance [/var/lib/redis/6379] 
Selected default - /var/lib/redis/6379
Please select the redis executable path [] /usr/local/redis/bin/redis-server
Selected config:
Port           : 6379
Config file    : /etc/redis/6379.conf
Log file       : /var/log/redis_6379.log
Data dir       : /var/lib/redis/6379
Executable     : /usr/local/redis/bin/redis-server
Cli Executable : /usr/local/redis/bin/redis-cli
Is this ok? Then press ENTER to go on or Ctrl-C to abort.
Copied /tmp/6379.conf => /etc/init.d/redis_6379
Installing service...
Successfully added to chkconfig!
Successfully added to runlevels 345!
Starting Redis server...
Installation successful!
[root@mcb-11-14 utils]# /etc/init.d/redis_6379 stop
Stopping ...
Waiting for Redis to shutdown ...
Redis stopped
[root@mcb-11-14 utils]# cd /etc/redis
[root@mcb-11-14 redis]# mkdir -p redis-cluster/redis600{1..6}
[root@mcb-11-14 redis6006]# ln -s /usr/local/redis/bin/* /usr/local/bin/ #不做这一步,会报错

②搭建Redis 群集模式 
[root@mcb-11-14 utils]# cd /etc/redis/
[root@mcb-11-14 redis]# ls
6379.conf
[root@mcb-11-14 redis]# cd redis-cluster/
[root@mcb-11-14 redis-cluster]# ls
redis6001  redis6002  redis6003  redis6004  redis6005  redis6006
[root@mcb-11-14 redis-cluster]# cd ..
[root@mcb-11-14 redis]# ls
6379.conf  redis-cluster
[root@mcb-11-14 redis]# for i in {1..6}
> do
> cp /opt/redis-5.0.7/redis.conf /etc/redis/redis-cluster/redis600$i
> cp /opt/redis-5.0.7/src/redis-cli /opt/redis-5.0.7/src/redis-server /etc/redis/redis-cluster/redis600$i
> done
[root@mcb-11-14 redis]# ll redis-cluster/redis6001
总用量 12704
-rwxr-xr-x. 1 root root 4808824 4月   7 14:29 redis-cli
-rw-r--r--. 1 root root   61797 4月   7 14:29 redis.conf
-rwxr-xr-x. 1 root root 8127288 4月   7 14:29 redis-server
[root@mcb-11-14 redis]# ls
6379.conf  redis-cluster
[root@mcb-11-14 redis]# cd redis-cluster/
[root@mcb-11-14 redis-cluster]# ls
redis6001  redis6002  redis6003  redis6004  redis6005  redis6006
[root@mcb-11-14 redis-cluster]# cd redis6001 
[root@mcb-11-14 redis6001]# ls
redis-cli  redis.conf  redis-server
[root@mcb-11-14 redis6001]# vim redis.conf
③编译master节点配置文件
#bind 127.0.0.1							#69行,注释掉bind 项,默认监听所有网卡
protected-mode no						#88行,修改,关闭保护模式
port 6001								#92行,修改,redis监听端口,
daemonize yes							#136行,开启守护进程,以独立进程启动
cluster-enabled yes						#832行,取消注释,开启群集功能
cluster-config-file nodes-6001.conf		#840行,取消注释,群集名称文件设置
cluster-node-timeout 15000				#846行,取消注释群集超时时间设置
appendonly yes							#700行,修改,开启AOF持久化
[root@mcb-11-14 redis6001]# vim redis.conf
[root@mcb-11-14 redis6001]# cp redis.conf ../redis6002
cp:是否覆盖"../redis6002/redis.conf"? yes
[root@mcb-11-14 redis6001]# vim ../redis6002/redis.conf 

修改文本内容 

92 port 6002

840  cluster-config-file nodes-6002.conf

继续拷贝

[root@mcb-11-14 redis6001]# cp redis.conf ../redis6003
cp:是否覆盖"../redis6003/redis.conf"? yes
[root@mcb-11-14 redis6001]# cp redis.conf ../redis6004
cp:是否覆盖"../redis6004/redis.conf"? yes
[root@mcb-11-14 redis6001]# cp redis.conf ../redis6005
cp:是否覆盖"../redis6005/redis.conf"? yes
[root@mcb-11-14 redis6001]# cp redis.conf ../redis6006
cp:是否覆盖"../redis6006/redis.conf"? yes
92行 port 6002

840行 cluster-config-file nodes-6002.conf

[root@mcb-11-14 redis6001]# vim ../redis6003/redis.conf  

92行 port 6003

840行 cluster-config-file nodes-6003.conf

[root@mcb-11-14 redis6001]# vim ../redis6004/redis.conf  

 92行 port 6004

 840行  cluster-config-file nodes-6004.conf

[root@mcb-11-14 redis6001]# vim ../redis6005/redis.conf  

92 port 6005

840  cluster-config-file nodes-6005.conf

[root@mcb-11-14 redis6001]# vim ../redis6006/redis.conf  

92 port 6006
840  cluster-config-file nodes-6006.conf
④启动redis节点 
[root@mcb-11-14 redis-cluster]# for d in {1..6}
> do
> cd /etc/redis/redis-cluster/redis600$d
> redis-server redis.conf
> done

 这样也行

[root@mcb-11-14 redis6006]# ln -s /usr/local/redis/bin/* /usr/local/bin/
[root@mcb-11-14 redis6006]# for d in {1..6}; do cd /etc/redis/redis-cluster/redis600$d; redis-server redis.conf; done
10398:C 07 Apr 2024 17:25:52.747 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10398:C 07 Apr 2024 17:25:52.747 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10398, just started
10398:C 07 Apr 2024 17:25:52.747 # Configuration loaded
10400:C 07 Apr 2024 17:25:52.754 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10400:C 07 Apr 2024 17:25:52.754 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10400, just started
10400:C 07 Apr 2024 17:25:52.754 # Configuration loaded
10402:C 07 Apr 2024 17:25:52.762 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10402:C 07 Apr 2024 17:25:52.762 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10402, just started
10402:C 07 Apr 2024 17:25:52.762 # Configuration loaded
10410:C 07 Apr 2024 17:25:52.770 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10410:C 07 Apr 2024 17:25:52.770 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10410, just started
10410:C 07 Apr 2024 17:25:52.770 # Configuration loaded
10415:C 07 Apr 2024 17:25:52.775 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10415:C 07 Apr 2024 17:25:52.775 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10415, just started
10415:C 07 Apr 2024 17:25:52.775 # Configuration loaded
10420:C 07 Apr 2024 17:25:52.779 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
10420:C 07 Apr 2024 17:25:52.779 # Redis version=5.0.7, bits=64, commit=00000000, modified=0, pid=10420, just started
10420:C 07 Apr 2024 17:25:52.779 # Configuration loaded

[root@mcb-11-14 redis6006]# ps -ef | grep redis
root      10399      1  0 17:25 ?        00:00:00 redis-server *:6001 [cluster]
root      10401      1  0 17:25 ?        00:00:00 redis-server *:6002 [cluster]
root      10409      1  0 17:25 ?        00:00:00 redis-server *:6003 [cluster]
root      10414      1  0 17:25 ?        00:00:00 redis-server *:6004 [cluster]
root      10419      1  0 17:25 ?        00:00:00 redis-server *:6005 [cluster]
root      10424      1  0 17:25 ?        00:00:00 redis-server *:6006 [cluster]
root      10493   3574  0 17:33 pts/1    00:00:00 grep --color=auto redis
⑤启动集群
[root@mcb-11-14 redis6006]# redis-cli --cluster create 127.0.0.1:6001 127.0.0.1:6002 127.0.0.1:6003 127.0.0.1:6004 127.0.0.1:6005 127.0.0.1:6006 --cluster-replicas 1
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 127.0.0.1:6005 to 127.0.0.1:6001
Adding replica 127.0.0.1:6006 to 127.0.0.1:6002
Adding replica 127.0.0.1:6004 to 127.0.0.1:6003
>>> Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: ab3223cc1465bb79bd5310b5044286eab261c593 127.0.0.1:6001
   slots:[0-5460] (5461 slots) master
M: 7843a1fe4eeb70acc4915176284c3b1e583a6f65 127.0.0.1:6002
   slots:[5461-10922] (5462 slots) master
M: c8bafedba2552472b5bfc1725d7e30879bda2302 127.0.0.1:6003
   slots:[10923-16383] (5461 slots) master
S: 6a608dd808a72f735152f942e74caaaa7c2fa38f 127.0.0.1:6004
   replicates 7843a1fe4eeb70acc4915176284c3b1e583a6f65
S: 7d08f9ff9aab477327776a5566546db608024739 127.0.0.1:6005
   replicates c8bafedba2552472b5bfc1725d7e30879bda2302
S: 6f0f84e0e897edf9955da23f7c57ed989128a2ae 127.0.0.1:6006
   replicates ab3223cc1465bb79bd5310b5044286eab261c593
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
......
>>> Performing Cluster Check (using node 127.0.0.1:6001)
M: ab3223cc1465bb79bd5310b5044286eab261c593 127.0.0.1:6001
   slots:[0-5460] (5461 slots) master
   1 additional replica(s)
M: c8bafedba2552472b5bfc1725d7e30879bda2302 127.0.0.1:6003
   slots:[10923-16383] (5461 slots) master
   1 additional replica(s)
S: 7d08f9ff9aab477327776a5566546db608024739 127.0.0.1:6005
   slots: (0 slots) slave
   replicates c8bafedba2552472b5bfc1725d7e30879bda2302
M: 7843a1fe4eeb70acc4915176284c3b1e583a6f65 127.0.0.1:6002
   slots:[5461-10922] (5462 slots) master
   1 additional replica(s)
S: 6a608dd808a72f735152f942e74caaaa7c2fa38f 127.0.0.1:6004
   slots: (0 slots) slave
   replicates 7843a1fe4eeb70acc4915176284c3b1e583a6f65
S: 6f0f84e0e897edf9955da23f7c57ed989128a2ae 127.0.0.1:6006
   slots: (0 slots) slave
   replicates ab3223cc1465bb79bd5310b5044286eab261c593
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
[root@mcb-11-14 redis6006]#
⑥集群测试 
[root@mcb-11-14 redis6006]# redis-cli -p 6001 -c
127.0.0.1:6001>  cluster slots
1) 1) (integer) 0
   2) (integer) 5460
   3) 1) "127.0.0.1"
      2) (integer) 6001
      3) "ab3223cc1465bb79bd5310b5044286eab261c593"
   4) 1) "127.0.0.1"
      2) (integer) 6006
      3) "6f0f84e0e897edf9955da23f7c57ed989128a2ae"
2) 1) (integer) 10923
   2) (integer) 16383
   3) 1) "127.0.0.1"
      2) (integer) 6003
      3) "c8bafedba2552472b5bfc1725d7e30879bda2302"
   4) 1) "127.0.0.1"
      2) (integer) 6005
      3) "7d08f9ff9aab477327776a5566546db608024739"
3) 1) (integer) 5461
   2) (integer) 10922
   3) 1) "127.0.0.1"
      2) (integer) 6002
      3) "7843a1fe4eeb70acc4915176284c3b1e583a6f65"
   4) 1) "127.0.0.1"
      2) (integer) 6004
      3) "6a608dd808a72f735152f942e74caaaa7c2fa38f"

127.0.0.1:6001> set name mcb
-> Redirected to slot [5798] located at 127.0.0.1:6002
OK
127.0.0.1:6002>  cluster keyslot name   #查看name键的槽编号
(integer) 5798
127.0.0.1:6002> 

总结

三者应该连贯一起做实验

①redis主从复制

reids 主从复制是一种同步机制,主服务器数据的修改,会实时同步到从服务器上,实现数据备份和读写分离

②哨兵模式

redis 哨兵是一个用于管理多个redis 服务器的系统 ,它提供监控 、通知、自动故障转移和配置服务,来实现redis高可用性。

哨兵功能

1)监控
2)通知
3)自动故障转移

4)配置提供服务(客户端做为验证)

③集群cluster

redis 集群 是一个提供高性能、 高可用、数据分片、 故障转移特性的 分布式 分数据库模式

1)数据分片

2)故障转移

3)高性能

4)高可用

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

51单片机之串口通信

目录 1.串口简介 1.1TXD和RXD 1.2通讯接口 1.3通信方式 1.4 51单片机的UART模式 2.串口配置 2.1寄存器简介 SCON寄存器配置 PCON配置 2.2代码配置串口 2.2.1 配置串口发送数据 2.2.2配置电脑向单片机发送数据点亮LED 1.串口简介 串口是一个应用十分广泛的通讯接口&am…

【Java集合进阶】LinkedList和迭代器的源码分析泛型类、泛型方法、泛型接口

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【Java】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收藏 …

项目架构MVC,DDD学习

写在前面 本文一起看下项目架构DDD,MVC相关的内容。 1:MVC 不管我们做什么项目,自己想想其实只是做了三件事,如下: 其实,这三件事完全在一个类中做完也可以可以正常把项目完成的,就像下面这…

MySQL-主从复制:概述、原理、同步数据一致性问题、搭建流程

主从复制 1. 主从复制概述 1.1 如何提升数据库并发能力 一般应用对数据库而言都是“读多写少”,也就说对数据库读取数据的压力比较大,有一个思路就是采用数据库集群的方案,做主从架构、进行读写分离,这样同样可以提升数据库的并…

mysql结构与sql执行流程

Mysql的大体结构 客户端:用于链接mysql的软件 连接池: sql接口: 查询解析器: MySQL连接层 连接层: 应用程序通过接口(如odbc,jdbc)来连接mysql,最先连接处理的是连接层。 连接层…

【Linux】达梦数据库安装部署(附详细图文)

目录 一、安装前的准备工作 1.检查操作系统配置 (1)获取系统位数 getconf LONG_BIT (2)查看操作系统release信息 cat /etc/system-release (3)查询系统名称 uname -a (4)查看操…

基于Spring Boot的网上书城系统(带文档)

主要功能 本次设计任务是要设计一个网上书城管理系统,通过这个系统能够满足网上书城的管理及用户的图书信息管理及购物功能。系统的主要功能包括:首页、个人中心、用户管理、图书类型管理、图书分类管理、图书信息管理、我的收藏管理、系统管理、订单管…

websocket实践

文章目录 背景WebSocket API使用场景优点 实例步骤 1: 设置 WebSocket 服务器步骤 2: 创建客户端 HTML 页面步骤 3: 测试 WebSocket 通信注意事项实际操作 参考资料 WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。它使得浏览器和服务器只需建立一个连接,…

SWM341系列应用(MPU屏应用)

SWM341系列 MPU屏应用 1、MPU屏写入时序设置(设置单位为周期),根据ST7789规格书规定的最小时序要求,建议MPU屏时序按照ST7789手册配置,建议配置的参数注释。例如WRRise_CSRise,时序图要求是最低10ns,根据计…

1.8.3 卷积神经网络近年来在结构设计上的主要发展和变迁——GoogleNet/inception-v1

1.8.3 卷积神经网络近年来在结构设计上的主要发展和变迁——GoogleNet/ inception-v1 前情回顾: 1.8.1 卷积神经网络近年来在结构设计上的主要发展和变迁——AlexNet 1.8.2 卷积神经网络近年来在结构设计上的主要发展和变迁——VGGNet GoogleNet问题 在VGGNet简单堆…

分类预测 | Matlab实现ABC-LSSVM人工蜂群算法优化最小二乘支持向量机数据分类预测

分类预测 | Matlab实现ABC-LSSVM人工蜂群算法优化最小二乘支持向量机数据分类预测 目录 分类预测 | Matlab实现ABC-LSSVM人工蜂群算法优化最小二乘支持向量机数据分类预测分类效果基本介绍程序设计参考资料 分类效果 基本介绍 1.Matlab实现ABC-LSSVM人工蜂群算法优化最小二乘支…

Redis中的Sentinel(六)

Sentinel 选举领头Sentinel. 当一个主服务器被判断为客观下线时,监视这个下线主服务器的各个Sentinel会进行协商,选举出一个领头Sentinel,并由领头 Sentinel对下线主服务器执行故障转移操作。以下是Redis选举领头Sentinel的规则和方法: 1.所有在线的S…

LabVIEW厂房漏水检测监控系统

LabVIEW厂房漏水检测监控系统 随着信息技术和智能制造的快速发展,对于精密仪器和重要物品存放场所的环境监控日益重要,特别是防止漏水带来的潜在风险。漏水不仅可能导致珍贵资料或仪器的损坏,还可能引发安全事故,给企业和研究机构…

在 C++ 中轻松实现字符串与字符数组的相互转换

在 C 中轻松实现字符串与字符数组的相互转换 引言一、将字符串转换为 char 数组1.1、C 中的 c_str()和 strcpy()函数1.2、使用 for 循环中的字符串到字符数组的转换 二、将 char 数组转换为字符串2.1、C 运算符 2.2、C 重载 运算符2.3、C 字符串内置构造函数 三、总结 引言 本…

阿里云服务器可以干嘛 阿里云服务器应用场景有哪些

阿里云服务器可以干嘛?能干啥你还不知道么!简单来讲可用来搭建网站、个人博客、企业官网、论坛、电子商务、AI、LLM大语言模型、测试环境等,阿里云百科aliyunbaike.com整理阿里云服务器的用途: 阿里云服务器活动 aliyunbaike.com…

qt环境搭建-镜像源安装Qt Creator(5.15.2)以及配置环境变量

前言: 版本:5.15.2 镜像源:ustc与清华 纯小白,找了半天的镜像源安装qtcreator,搞了半天结果安装的是最新的,太新的对小白很不友好,bug比较多,支持的系统也不全,口碑不…

011_C标准库函数之<time.h>

头文件<time.h>中说明了一些用于处理日期和时间的类型和函数。其中的一部分函数用于处理当地时间&#xff0c;因为时区等原因&#xff0c;当地时间与日历时间可能不相同。clock_t和time_t是两个用于表示时间的算术类型&#xff0c;而struct tm则用于存放日历时间的各个成…

配置vscode用于STM32编译,Debug,github上传拉取

配置环境参考&#xff1a; Docs 用cubemx配置工程文件&#xff0c;用VScode打开工程文件。 编译的时候会有如下报错&#xff1a; vscode出现process_begin :CreateProcess failed 系统找不到指定文件 解决方案&#xff1a;在你的makefile中加上SHELLcmd.exe就可以了 参考…

mysql jdbc数据库速成总结

第一步导图jar包 我们下载一个jar 按照我的习惯是把这个jar包放在桌面上 方便后续操作 然后对这个jar包ctrl c复制 接着我们在idea里面创建一个目录 我们命名为lib 然后在这个lib安ctrl V进行粘贴 然后右键这个lib 找到添加为库 我的idea好像没有选择 只有添加为模块 点…

【LeetCode: 455. 分发饼干 + 贪心】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…