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,默认为everysecappendfsync everysec 4、在aof-rewrite期间,appendfsync是否暂缓文件同步,"no"表示“不暂缓”,“yes”表示“暂缓”,默认为“no”no-appendfsync-on-rewrite no 5、触发aof rewrite的最小文件尺寸 auto-aof-rewrite-min-size 64mb6、当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集成开发环境(IDE),由JetBrains公司开发。它为Python开发者提供了丰富的功能和工具,使得Python编程变得更加高效和便捷。PyCharm Pro具有智能代码编辑功能,能够自动完成代码、快速导航至…...
Linux的 .bashrc 有什么作用?
一、.bashrc 是什么? 有什么用? .bashrc是一个存储在你的home目录下的隐藏文件,它用来配置和自定义你的终端环境和行为。 每次你启动一个新的终端时,.bashrc文件就会被执行,加载你设置的环境变量,别名,函数…...
.ui文件相关
目录 ui类生成过程: 提问: 等以后自己熟练了用代码写这些样式内容,尽量用代码写,原因很简单: 用代码写的可以直接修改代码,但是在设计界面修改的东西,电脑没有QC这玩意,还真不好改…...
【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" ,然后去关闭对应的进程 但是我遇到的是8080改成任意一个端口,都报错端口被占用,且使用上面的命令并不能查到对应的进程 网上找到的方案能解决我的问题,原链接所…...
IDEA:git 回滚本地提交-git 选择 Reset Current Branch to
前言 回滚提交到本地但是还没有 Push 上去的提交 选择我们要回滚的节点,然后点击 git 选择 Reset Current Branch to… 再选择 Hard 。当我们点击 Reset 的时候,代码就会回滚到单前选中的这个版本...
Docker核心教程
1. 概述 官网:https://docs.docker.com/ Docker Hub 网站:https://hub.docker.com/ 容器较为官方的解释: 一句话概括容器:容器就是将软件打包成标准化单元,以用于开发、交付和部署。 容器镜像是轻量的、可执行的独立…...
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制作线框图
写在前面:在哔哩哔哩上面找到的Axure自学教程0基础入门课程,播放量最高,5个多小时。课程主要分为4个部分,快速入门、动态面板、常用动效、项目设计。UP主账号【Song老师产品经理课堂】。做个有素质的白嫖er,一键三连必…...
day38_MySQL
今日内容 0 复习昨日 1 引言 2 数据库 3 数据库管理系统 4 MySQL 5 SQL语言 0 复习昨日 1 引言 1.1 现有的数据存储方式有哪些? Java程序存储数据(变量、对象、数组、集合),数据保存在内存中,属于瞬时状态存储。文件&…...
element ui组件 el-date-picker设置default-time的默认时间
default-time :选择日期后的默认时间值。 如未指定则默认时间值为 00:00:00 默认值修改 <el-form-item label"计划开始时间" style"width: 100%;" prop"planStartTime"><el-date-picker v-model"formData.planStart…...
###C语言程序设计-----C语言学习(8)## 斐波那契数列问题,素数问题,人数分配问题。
前言:感谢您的关注哦,我会持续更新编程相关知识,愿您在这里有所收获。如果有任何问题,欢迎沟通交流!期待与您在学习编程的道路上共同进步。 今天,我们主要分享三个问题如何用C语言去求解,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 架构》系列(已完结),共包含以下 6 篇文章: Flink 架构(一):系统架构Flink 架构(二):数据传输Flink 架构(三):事件…...
执行rpm安装命令的时候抛出异常:rpmdb BDB0113 Thread/process
问题现象 错误:rpmdb: BDB0113 Thread/process 66126/140498505373504 failed: BDB1507 Thread died in Berkeley DB library 错误:db5 错误(-30973) 来自 dbenv->failchk:BDB0087 DB_RUNRECOVERY: Fatal error, run database recovery 错…...
Android 在WebView中加载H5传递图片
最近h5开发一个编译器,要在手机上显示,需要获取手机上的图片,使用webview不能直接到文件管理拿取,还需要对webview做处理,做个记录,方便以后使用; public ValueCallback<Uri[]> mUploadMe…...
图的学习
图的基本概念和术语 图的定义:图是由顶点的有穷非空集合和顶点之间的边的集合组成的,G表示,V是图G中顶点的集合,E是图G中边的集合 无向图:任意两点的边都是无向边组成的图(无向边:(…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...
以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:
一、属性动画概述NETX 作用:实现组件通用属性的渐变过渡效果,提升用户体验。支持属性:width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项: 布局类属性(如宽高)变化时&#…...
IGP(Interior Gateway Protocol,内部网关协议)
IGP(Interior Gateway Protocol,内部网关协议) 是一种用于在一个自治系统(AS)内部传递路由信息的路由协议,主要用于在一个组织或机构的内部网络中决定数据包的最佳路径。与用于自治系统之间通信的 EGP&…...
Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
微信小程序云开发平台MySQL的连接方式
注:微信小程序云开发平台指的是腾讯云开发 先给结论:微信小程序云开发平台的MySQL,无法通过获取数据库连接信息的方式进行连接,连接只能通过云开发的SDK连接,具体要参考官方文档: 为什么? 因为…...
Maven 概述、安装、配置、仓库、私服详解
目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...
动态 Web 开发技术入门篇
一、HTTP 协议核心 1.1 HTTP 基础 协议全称 :HyperText Transfer Protocol(超文本传输协议) 默认端口 :HTTP 使用 80 端口,HTTPS 使用 443 端口。 请求方法 : GET :用于获取资源,…...
Python Ovito统计金刚石结构数量
大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...
