当前位置: 首页 > news >正文

MemcachedRedis构建缓存服务器

目录

Memcached&Redis构建缓存服务器

一、介绍

二、memcached

1、特点

2、服务框架

3.配置安装memcached

三、redis服务

1、介绍

2、特点

3、缓存

4、安装redis

5、数据持久化

6、redis主从配置


Memcached&Redis构建缓存服务器

一、介绍

许多Web应用都将数据保存到 RDBMS中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大、访问的集中,就会出现RDBMS的负担加重、数据库响应恶化、 网站显示延迟等重大影响。**Memcached/redis是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web等应用的速度、 提高可扩展性。

RDBMS即关系数据库管理系统(Relational Database Management System)

NOSQL名词解释:非关系型数据库:

1、nosql产品: redis,mongodb,memcached.

2、存储方式:以键值对的方式存储数据---(Key-Value)的形式

3、类型:缓存数据库、非关系型数据库。

4.、缓存服务器的作用:加快访问速度,缓解数据库读的压力。

5、nosql的优点与缺点

 优点:- 高可扩展性- 分布式计算- 低成本- 架构的灵活性,半结构化数据- 没有复杂的关系缺点:- 没有标准化 - 有限的查询功能(到目前为止)- 最终一致是不直观的程序

6、关系型数据库与非关系型数据库的区别:

 1.关系型数据库:优点:1、易于维护:都是使用表结构,格式一致;2、使用方便:SQL语言通用,可用于复杂查询;3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。缺点:1、读写性能比较差,尤其是海量数据的高效率读写;2、固定的表结构,灵活度稍欠;3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。=============================================================================2.非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。优点:1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;3、高扩展性;4、成本低:nosql数据库部署简单,基本都是开源软件。​缺点:1、不提供sql支持,学习和使用成本较高;2、无事务处理;3、数据结构相对复杂,复杂查询方面稍欠。​

二、memcached

1、特点

 1.内置内存存储方式-----------为了提高性能,memcached中保存的数据都存储在memcache内置的内存存储空间中。由于数据仅存在于内存中,重启操作系统会导致全部数据消失2.简单key/value存储---------------服务器不关心数据本身的意义及结构,只要是可序列化数据即可。存储项由“键、过期时间、可选的标志及数据”四个部分组成;3.不互相通信的分布式 -------------  memcached尽管是“分布式”缓存服务器,但服务器端并没有分布式功能。 各个memcached不会互相通信以共享信息。那么,怎样进行分布式呢? 这完全取决于客户端的实现。

 

2、服务框架

原理:

1、检查客户端的请求数据是否在memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作,路径操作为①②③⑦。 2、如果请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(memcached客户端不负责,需要程序明确实现),路径操作为①②④⑤⑦⑥。

3.保持缓存的“新鲜性”,每当数据发生变化的时候(比如,数据有被修改,或被删除的情况下),要同步的更新缓存信息,确保用户不会在缓存取到旧的数据。

3.配置安装memcached

memcached能存放多少数据,取决于服务器本身的内存有多大。

 1.安装----准备一台服务器[root@memcached ~]# yum install memcached -y[root@memcached ~]# systemctl start memcached  #启动2.修改配置文件[root@memcached ~]# cat /etc/sysconfig/memcached PORT="11211"  # 监听端口USER="memcached"  # 用户MAXCONN="1024"    # 最大并发数CACHESIZE="64"    # 分配内存大小OPTIONS=""        # 监听网络地址然后把ip地址发给开发人员,开发的会使用api接口连接memcached.测试:[root@memcached ~]# yum install -y telnet   #安装telent[root@memcached ~]# telnet 192.168.246.188 11211Trying 192.168.246.188...Connected to 192.168.246.188.Escape character is '^]'.set name 0 60 7    #设置名称为name的keynewrain        #给name的值STORED#出现stored表示已经存储成功。​get name       #查询key值VALUE name 0 7newrainEND参数解释:name:key的名字 自己定义0:key的id号,需要和其他的key不一样60:缓存过期时间,单位为秒,0为永远7:字符串最大长度

三、redis服务

1、介绍

redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库

redis的官网:redis.io

注:域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地

2、特点

 1.丰富的数据结构  -----string,list,set,zset,hash等数据结构的存储2.支持持久化3.支持事务   ---------------事务是指“一个完整的动作,要么全部执行,要么什么也没有做”。4.支持主从

3、缓存

 1.类型1).数据缓存 2).页面缓存(Smarty) 在开发网站的时候如果有一些数据在短时间之内不会发生变化,而它们还要被频繁访问,为了提高用户的请求速度和降低网站的负载,就把这些数据放到一个读取速度更快的介质上(或者是通过较少的计算量就可以获得该数据) ,该行为就称作对该数据的缓存。 该介质可以是文件、数据库、内存,内存经常用于数据缓存​2.形式页面缓存经常用在内存管理系统里边 数据缓存经常用在页面的具体数据里边 ​redis和memcache比较 1).Redis不仅仅支持简单的k/v类型的数据,同时还提供了list,set,zset,hash等数据结构的存储 2).Redis支持master-slave(主-从)模式应用 3).Redis支持数据的持久化

4、安装redis

1.安装单机版redis

 [root@redis-master ~]# mkdir -p /data/application     ---创建工作目录[root@redis-master ~]# wget http://download.redis.io/releases/redis-5.0.10.tar.gz   ---下载redis[root@redis-master ~]# tar xzf redis-5.0.10.tar.gz -C /data/application/    ---解压[root@redis-master ~]# cd /data/application/[root@redis-master application]# mv redis-5.0.10/ redis[root@redis-master application]# cd redis/[root@redis-master redis]# yum install -y gcc make  #安装编译工具[root@redis-master redis]# make注:如果报错请将刚才解压的安装包删除掉,再次重新解压并进行make安装即可。[root@redis-master redis]# cp redis.conf redis.conf.bak[root@redis-master redis]# vim redis.conf     ---修改如下bind 192.168.246.202  #只监听内网IPdaemonize yes     #开启后台模式将on改为yestimeout 300      #连接超时时间port 6379                      #端口号dir /data/application/redis/data  #本地数据库存放持久化数据的目录该目录-----需要存在pidfile /var/run/redis_6379.pid  #定义pid文件logfile /var/log/redis.log  #定义log文件创建存放数据的目录[root@redis-master redis]# mkdir /data/application/redis/data配置redis为systemctl启动[root@redis-master redis]# cd /lib/systemd/system[root@redis-master system]# vim redis.service[Unit]Description=RedisAfter=network.target​[Service]ExecStart=/data/application/redis/src/redis-server /data/application/redis/redis.conf  --daemonize noExecStop=/data/application/redis/src/redis-cli -h 127.0.0.1 -p 6379 shutdown​[Install]WantedBy=multi-user.target
=====================
 参数详解:• [Unit] 表示这是基础信息 • Description 是描述• After 是在那个服务后面启动,一般是网络服务启动后启动​• [Service] 表示这里是服务信息 • ExecStart 是启动服务的命令• ExecStop 是停止服务的指令​• [Install] 表示这是是安装相关信息 • WantedBy 是以哪种方式启动:multi-user.target表明当系统以多用户方式(默认的运行级别)启动时,这个服务需要被自动运行。
 ===================启动服务:
 [root@redis-master system]# systemctl daemon-reload[root@redis-master system]# systemctl start redis.service

2.检查redis是否启动

 [root@master ~]# ss -npltState      Recv-Q Send-Q             Local Address:Port                            Peer Address:Port              LISTEN     0      128                            *:22                                         *:*                   users:(("sshd",pid=970,fd=3))LISTEN     0      100                    127.0.0.1:25                                         *:*                   users:(("master",pid=1188,fd=13))LISTEN     0      128                            *:6379                                       *:*                   users:(("redis-server",pid=6945,fd=6))LISTEN     0      128                         [::]:22                                      [::]:*                   users:(("sshd",pid=970,fd=4))LISTEN     0      100                        [::1]:25                                      [::]:*                   users:(("master",pid=1188,fd=14))[root@master ~]# 

3.登陆redis

 [root@redis-master system]# cd /data/application/redis/src/[root@redis-master src]# ./redis-cli -h 192.168.246.202 -p 6379192.168.246.202:6379> ping     ---测试redis是否可以用PONG192.168.246.202:6379> set name newrain    #设置key--name,并设置值OK192.168.246.202:6379> get name    #获取到key"newrain"192.168.246.202:6379>

4.redis的相关工具

 ./redis-benchmark     #用于进行redis性能测试的工具 ./redis-check-dump    #用于修复出问题的dump.rdb文件   ./redis-cli           #redis的客户端./redis-server        #redis的服务端./redis-check-aof     #用于修复出问题的AOF文件./redis-sentinel      #用于集群管理

5、数据持久化

作用:开启持久化功能后,重启redis,数据会自动通过持久化文件恢复!!

1.redis持久化 – 两种方式

 一、redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File)。RDB(Redis DataBase):是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上;特点:1.周期性2.不影响数据写入  #RDB会启动子进程,备份所有数据。当前进程,继续提供数据的读写。当备份完成,才替换老的备份文件。3.高效     #一次性还原所有数据4.完整性较差 #故障点到上一次备份,之间的数据无法恢复。=================================================================================AOF(Append Only File)则是换了一个角度来实现持久化,那就是将redis执行过的所有写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据恢复了。特点:1.实时性2.完整性较好3.体积大  #记录数据的指令,删除数据的指令都会被记录下来。=================================================================================二、RDB和AOF两种方式也可以同时使用,在这种情况下,如果redis重启的话,则会优先采用AOF方式来进行数据恢复,这是因为AOF方式的数据恢复完整度更高。如果你没有数据持久化的需求,也完全可以关闭RDB和AOF方式,这样的话,redis将变成一个纯内存数据库,就像memcache一样。三、如何选择方式?缓存:不用开启任何持久方式双开:因RDB数据不实时,但同时使用两者时服务器只会找AOF文件,所以RDB留作万一的手段。redis持久化 – 如何选择RDB和AOF对于我们应该选择RDB还是AOF,官方的建议是两个同时使用。这样可以提供更可靠的持久化方案。写入速度快 ------------AOF写入速度慢 ------------RDB

2.持久化配置

 1、RDB默认开启:[root@redis-master src]# cd ..[root@redis-master redis]# vim redis.conf#dbfilename:持久化数据存储在本地的文件dbfilename dump.rdb#dir:持久化数据存储在本地的路径dir /data/application/redis/data##snapshot触发的时机,save <seconds> <changes>  ##如下为900秒后,至少有一个变更操作,才会snapshot  ##对于此值的设置,需要谨慎,评估系统的变更操作密集程度  ##可以通过“save “”来关闭snapshot功能  #save时间,以下分别表示更改了1个key时间隔900s进行持久化存储;更改了10个key300s进行存储;更改10000个key60s进行存储。save 900 1save 300 10save 60 10000##当snapshot时出现错误无法继续时,是否阻塞客户端“变更操作”,“错误”可能因为磁盘已满/磁盘故障/OS级别异常等  stop-writes-on-bgsave-error yes  ##是否启用rdb文件压缩,默认为“yes”,压缩往往意味着“额外的cpu消耗”,同时也意味这较小的文件尺寸以及较短的网络传输时间  rdbcompression yes 2、客户端使用命令进行持久化save存储:方式一[root@redis-master src]# ./redis-cli -h 192.168.246.202 -p 6379 save   #前台进行存储OK方式二./redis-cli -h ip -p port bgsave  #后台进行存储注意:每次快照持久化都是将内存数据完整写入到磁盘一次,并不是增量的只同步新数据。如果数据量大的话,而且写操作比较多,必然会引起大量的磁盘io操作,可能会严重影响性能。save方式:持久化前面的所有数据(rdb模式没开时,后续的数据不会进行备份)3、AOF默认关闭--开启[root@redis-master src]# cd ..[root@redis-master redis]# vim redis.conf修改如下:
  696 # Please check http://redis.io/topics/persistence for more information.697 698 appendonly yes  #修改这行699 700 # The name of the append only file (default: "appendonly.aof")
  1、此选项为aof功能的开关,默认为“no”,可以通过“yes”来开启aof功能,只有在“yes”下,aof重写/文件同步等特性才会生效​2、指定aof文件名称​appendfilename appendonly.aof  ​3、指定aof操作中文件同步策略,有三个合法值:always everysec no,默认为everysec​appendfsync everysec  ​4、在aof-rewrite期间,appendfsync是否暂缓文件同步,"no"表示“不暂缓”,“yes”表示“暂缓”,默认为“no”​no-appendfsync-on-rewrite no  ​5、触发aof rewrite的最小文件尺寸 ​auto-aof-rewrite-min-size 64mb​6、当Aof log增长超过指定比例时,重写log file, 设置为0表示不自动重写Aof 日志,重写是为了使aof体积保持最小,而确保保存最完整的数据。​auto-aof-rewrite-percentage 100**修改完配置文件后重启生效**

6、redis主从配置

1.主从-用法

 像MySQL一样,redis是支持主从同步的,而且也支持一主多从以及多级从结构。主从结构,一是为了纯粹的冗余备份,二是为了提升读性能,比如很消耗性能的SORT就可以由从服务器来承担。redis的主从同步是异步进行的,这意味着主从同步不会影响主逻辑,也不会降低redis的处理性能。主从架构中,可以考虑关闭主服务器的数据持久化功能,只让从服务器进行持久化,这样可以提高主服务器的处理性能。在主从架构中,从服务器通常被设置为只读模式,这样可以避免从服务器的数据被误修改。但是从服务器仍然可以接受CONFIG等指令,所以还是不应该将从服务器直接暴露到不安全的网络环境中。

2.主从-原理

 主从 – 同步原理从服务器会向主服务器发出SYNC(sync)指令,当主服务器接到此命令后,就会调用BGSAVE(bgsave)指令来创建一个子进程专门进行数据持久化工作,也就是将主服务器的数据写入RDB文件中。在数据持久化期间,主服务器将执行的写指令都缓存在内存中。在BGSAVE指令执行完成后,主服务器会将持久化好的RDB文件发送给从服务器,从服务器接到此文件后会将其存储到磁盘上,然后再将其读取到内存中。这个动作完成后,主服务器会将这段时间缓存的写指令再以redis协议的格式发送给从服务器。​另外,要说的一点是,即使有多个从服务器同时发来SYNC指令,主服务器也只会执行一次BGSAVE,然后把持久化好的RDB文件发给多个下游。在redis2.8版本之前,如果从服务器与主服务器因某些原因断开连接的话,都会进行一次主从之间的全量的数据同步;而在2.8版本之后,redis支持了效率更高的增量同步策略,这大大降低了连接断开的恢复成本。​主服务器会在内存中维护一个缓冲区,缓冲区中存储着将要发给从服务器的内容。从服务器在与主服务器出现网络瞬断之后,从服务器会尝试再次与主服务器连接,一旦连接成功,从服务器就会把“希望同步的主服务器ID”和“希望请求的数据的偏移位置(replication offset)”发送出去。主服务器接收到这样的同步请求后,首先会验证主服务器ID是否和自己的ID匹配,其次会检查“请求的偏移位置”是否存在于自己的缓冲区中,如果两者都满足的话,主服务器就会向从服务器发送增量内容。​增量同步功能,需要服务器端支持全新的PSYNC指令。这个指令,只有在redis-2.8之后才具有。

3.准备3台服务器部署redis主从

首先三台服务器将redis部署完成且做环境变量 a.编辑master的redis配置文件:

 redis-master----192.168.246.202redis-slave-1-----192.168.246.203redis-slave-2-----192.168.246.204[root@redis-master ~]# cd /data/application/redis/[root@redis-master redis]# vim redis.conf

修改如下

   84# you are sure you want clients from other hosts to connect to Redis85 # even if no authentication is configured, nor a specific set of interfaces86 # are explicitly listed using the "bind" directive.87 protected-mode no   #将加密保护关闭88 89 # Accept connections on the specified port, default is 6379 (IANA #815344).

b.修改slave1与slave2的配置文件:

 [root@redis-slave-1 ~]# cd /data/application/redis/[root@redis-slave-1 redis]# vim redis.conf      

修改如下:slave2一样

  281 # 3) Replication is automatic and does not need user intervention. After a282 #    network partition replicas automatically try to reconnect to masters283 #    and resynchronize with them.284 #285 replicaof 10.12.153.243 6379   #添加master的内网IP与端口286 287 # If the master is password protected (using the "requirepass" configuration

c.启动三台redis

 [root@redis-master redis]# systemctl start redis

d.测试主从

 1.在master上面执行
 [root@redis-master redis]# cd src/[root@redis-master src]# ./redis-cli 127.0.0.1:6379> pingPONG127.0.0.1:6379> set name xuanOK127.0.0.1:6379> get name"newrain"127.0.0.1:6379>
 2.分别在slave-1和slave-2上面执行:
 [root@redis-slave-1 redis]# cd src/[root@redis-slave-1 src]# ./redis-cli 127.0.0.1:6379> pingPONG127.0.0.1:6379> get name"newrain"127.0.0.1:6379>[root@redis-slave-2 src]# ./redis-cli 127.0.0.1:6379> pingPONG127.0.0.1:6379> get name"newrain"127.0.0.1:6379>
 3.查看复制状态master执行:
 127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:2slave0:ip=192.168.246.203,port=6379,state=online,offset=490,lag=0slave1:ip=192.168.246.204,port=6379,state=online,offset=490,lag=1
 slave上面执行:
 127.0.0.1:6379> info replication# Replicationrole:slavemaster_host:192.168.246.202master_port:6379master_link_status:up

主从同步部署完成!

相关文章:

MemcachedRedis构建缓存服务器

目录 Memcached&Redis构建缓存服务器 一、介绍 二、memcached 1、特点 2、服务框架 3.配置安装memcached 三、redis服务 1、介绍 2、特点 3、缓存 4、安装redis 5、数据持久化 6、redis主从配置 Memcached&Redis构建缓存服务器 一、介绍 许多Web应用都将…...

Python编辑开发 --- pycharm pro 中文

PyCharm Pro是一款专业的Python集成开发环境&#xff08;IDE&#xff09;&#xff0c;由JetBrains公司开发。它为Python开发者提供了丰富的功能和工具&#xff0c;使得Python编程变得更加高效和便捷。PyCharm Pro具有智能代码编辑功能&#xff0c;能够自动完成代码、快速导航至…...

Linux的 .bashrc 有什么作用?

一、.bashrc 是什么? 有什么用&#xff1f; .bashrc是一个存储在你的home目录下的隐藏文件&#xff0c;它用来配置和自定义你的终端环境和行为。 每次你启动一个新的终端时&#xff0c;.bashrc文件就会被执行&#xff0c;加载你设置的环境变量&#xff0c;别名&#xff0c;函数…...

.ui文件相关

目录 ui类生成过程&#xff1a; 提问&#xff1a; 等以后自己熟练了用代码写这些样式内容&#xff0c;尽量用代码写&#xff0c;原因很简单&#xff1a; 用代码写的可以直接修改代码&#xff0c;但是在设计界面修改的东西&#xff0c;电脑没有QC这玩意&#xff0c;还真不好改…...

【DOCKER】docker 安装sonarque

安装docker 安装docker https://blog.csdn.net/BThinker/article/details/123358697 加入阿里云镜像 https://blog.csdn.net/TommyXu8023/article/details/113291112 { "registry-mirrors": ["https://alzgoonw.mirror.aliyuncs.com"] }安装sonarqube ht…...

解决IDEA报错端口被占用的问题

遇到的解决方案通常是执行netstat -ano | findstr "8080" &#xff0c;然后去关闭对应的进程 但是我遇到的是8080改成任意一个端口&#xff0c;都报错端口被占用&#xff0c;且使用上面的命令并不能查到对应的进程 网上找到的方案能解决我的问题&#xff0c;原链接所…...

IDEA:git 回滚本地提交-git 选择 Reset Current Branch to

前言 回滚提交到本地但是还没有 Push 上去的提交 选择我们要回滚的节点&#xff0c;然后点击 git 选择 Reset Current Branch to… 再选择 Hard 。当我们点击 Reset 的时候&#xff0c;代码就会回滚到单前选中的这个版本...

Docker核心教程

1. 概述 官网&#xff1a;https://docs.docker.com/ Docker Hub 网站&#xff1a;https://hub.docker.com/ 容器较为官方的解释&#xff1a; 一句话概括容器&#xff1a;容器就是将软件打包成标准化单元&#xff0c;以用于开发、交付和部署。 容器镜像是轻量的、可执行的独立…...

React通用后台模板

一. 项目初始化 1. 创建项目 环境 npm init vite 打开package.json,参考以下各模块版本: "dependencies": { "react": "^18.2.0", "react-dom": "^18.2.0", "react-redux": "^7.2.8", …...

【Axure教程0基础入门】00Axure9汉化版下载、安装、汉化、注册+01制作线框图

写在前面&#xff1a;在哔哩哔哩上面找到的Axure自学教程0基础入门课程&#xff0c;播放量最高&#xff0c;5个多小时。课程主要分为4个部分&#xff0c;快速入门、动态面板、常用动效、项目设计。UP主账号【Song老师产品经理课堂】。做个有素质的白嫖er&#xff0c;一键三连必…...

day38_MySQL

今日内容 0 复习昨日 1 引言 2 数据库 3 数据库管理系统 4 MySQL 5 SQL语言 0 复习昨日 1 引言 1.1 现有的数据存储方式有哪些&#xff1f; Java程序存储数据&#xff08;变量、对象、数组、集合&#xff09;&#xff0c;数据保存在内存中&#xff0c;属于瞬时状态存储。文件&…...

element ui组件 el-date-picker设置default-time的默认时间

default-time &#xff1a;选择日期后的默认时间值。 如未指定则默认时间值为 00:00:00 默认值修改 <el-form-item label"计划开始时间" style"width: 100%;" prop"planStartTime"><el-date-picker v-model"formData.planStart…...

###C语言程序设计-----C语言学习(8)## 斐波那契数列问题,素数问题,人数分配问题。

前言&#xff1a;感谢您的关注哦&#xff0c;我会持续更新编程相关知识&#xff0c;愿您在这里有所收获。如果有任何问题&#xff0c;欢迎沟通交流&#xff01;期待与您在学习编程的道路上共同进步。 今天&#xff0c;我们主要分享三个问题如何用C语言去求解&#xff0c;1.斐波…...

蓝桥杯 第 1 场 小白入门赛

目录 1.蘑菇炸弹 2.构造数字 3.小蓝的金牌梦 4.合并石子加强版 5.简单的LIS问题 6.期望次数 1.蘑菇炸弹 我们直接依照题目 在中间位置的数进行模拟即可 void solve(){cin>>n;vector<int> a(n1);for(int i1;i<n;i) cin>>a[i];int ans0;for(int i2;i…...

飞天使-linux操作的一些技巧与知识点5-expect与docker便捷命令

expect 主要使用场景不输入账户密码的多 yum install -y expect 则可以安装上 #!/usr/bin/expect -f set username “root” set password “123456” spawn /bin/bash send “cd /data/container/\r” expect "$ " # 等待命令提示符 send “git pull\r” expect…...

编曲学习:和声音程 调式体系 唱名法 调式调性

34届和声音程 调式体系 唱名法 调式调性https://app8epdhy0u9502.pc.xiaoe-tech.com/live_pc/l_65af994be4b064a8cb1c3a5f?course_idcourse_2XLKtQnQx9GrQHac7OPmHD9tqbv 34届独立音乐人编曲训练营https://app8epdhy0u9502.pc.xiaoe-tech.com/p/t_pc/course_pc_detail/camp_p…...

【大数据】Flink 架构(四):状态管理

《Flink 架构》系列&#xff08;已完结&#xff09;&#xff0c;共包含以下 6 篇文章&#xff1a; Flink 架构&#xff08;一&#xff09;&#xff1a;系统架构Flink 架构&#xff08;二&#xff09;&#xff1a;数据传输Flink 架构&#xff08;三&#xff09;&#xff1a;事件…...

执行rpm安装命令的时候抛出异常:rpmdb BDB0113 Thread/process

问题现象 错误&#xff1a;rpmdb: BDB0113 Thread/process 66126/140498505373504 failed: BDB1507 Thread died in Berkeley DB library 错误&#xff1a;db5 错误(-30973) 来自 dbenv->failchk&#xff1a;BDB0087 DB_RUNRECOVERY: Fatal error, run database recovery 错…...

Android 在WebView中加载H5传递图片

最近h5开发一个编译器&#xff0c;要在手机上显示&#xff0c;需要获取手机上的图片&#xff0c;使用webview不能直接到文件管理拿取&#xff0c;还需要对webview做处理&#xff0c;做个记录&#xff0c;方便以后使用&#xff1b; public ValueCallback<Uri[]> mUploadMe…...

图的学习

图的基本概念和术语 图的定义&#xff1a;图是由顶点的有穷非空集合和顶点之间的边的集合组成的&#xff0c;G表示&#xff0c;V是图G中顶点的集合&#xff0c;E是图G中边的集合 无向图&#xff1a;任意两点的边都是无向边组成的图&#xff08;无向边&#xff1a;&#xff08…...

JavaSec-RCE

简介 RCE(Remote Code Execution)&#xff0c;可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景&#xff1a;Groovy代码注入 Groovy是一种基于JVM的动态语言&#xff0c;语法简洁&#xff0c;支持闭包、动态类型和Java互操作性&#xff0c…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

MMaDA: Multimodal Large Diffusion Language Models

CODE &#xff1a; https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA&#xff0c;它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构&#xf…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

三分算法与DeepSeek辅助证明是单峰函数

前置 单峰函数有唯一的最大值&#xff0c;最大值左侧的数值严格单调递增&#xff0c;最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值&#xff0c;最小值左侧的数值严格单调递减&#xff0c;最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...

pikachu靶场通关笔记19 SQL注入02-字符型注入(GET)

目录 一、SQL注入 二、字符型SQL注入 三、字符型注入与数字型注入 四、源码分析 五、渗透实战 1、渗透准备 2、SQL注入探测 &#xff08;1&#xff09;输入单引号 &#xff08;2&#xff09;万能注入语句 3、获取回显列orderby 4、获取数据库名database 5、获取表名…...

深入浅出Diffusion模型:从原理到实践的全方位教程

I. 引言&#xff1a;生成式AI的黎明 – Diffusion模型是什么&#xff1f; 近年来&#xff0c;生成式人工智能&#xff08;Generative AI&#xff09;领域取得了爆炸性的进展&#xff0c;模型能够根据简单的文本提示创作出逼真的图像、连贯的文本&#xff0c;乃至更多令人惊叹的…...

Leetcode33( 搜索旋转排序数组)

题目表述 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...

Python竞赛环境搭建全攻略

Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型&#xff08;算法、数据分析、机器学习等&#xff09;不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...

Android写一个捕获全局异常的工具类

项目开发和实际运行过程中难免会遇到异常发生&#xff0c;系统提供了一个可以捕获全局异常的工具Uncaughtexceptionhandler&#xff0c;它是Thread的子类&#xff08;就是package java.lang;里线程的Thread&#xff09;。本文将利用它将设备信息、报错信息以及错误的发生时间都…...