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

WordPress潮流媒体主题/白帽seo公司

WordPress潮流媒体主题,白帽seo公司,企业做网站的费用,title 网站建设目录 前言 一、REDIS概述 二、REDIS安装 1、编译安装 2.yum安装 三、Redis的目录结构 四、基础命令解析 五、在一台服务器上启动多个redis 六、数据库的基本操作 (一)登录数据库 (二)基础命令 七、Redis持久化 (一&…

目录

前言

一、REDIS概述

二、REDIS安装

1、编译安装

2.yum安装

三、Redis的目录结构

四、基础命令解析

五、在一台服务器上启动多个redis

六、数据库的基本操作

(一)登录数据库

(二)基础命令

七、Redis持久化

(一)RDB持久化

(二)AOF持久化

总结



前言

Redis是一个开源的内存数据结构存储系统,也可以用作数据库、缓存和消息中间件。它支持多种数据结构,包括字符串(strings)、哈希(hashes)、列表(lists)、集合(sets)、有序集合(sorted sets)等。
Redis的特点包括:

高性能:Redis将数据存储在内存中,因此具有非常快速的读写速度。
持久化:Redis支持两种持久化方式,即RDB(Redis Database)和AOF(Append-Only File)。

RDB是将数据以快照的形式保存到磁盘上,通常用于备份和恢复数据。
AOF是将每个写操作追加到文件中,以日志的形式记录,通过重新执行这些写操作可以恢复数据。


多种数据结构:Redis支持多种数据结构,使得它可以灵活地应用于不同的场景。
发布/订阅模式:Redis支持发布/订阅模式,可以将消息发布到多个订阅者。
高可用性:Redis支持主从复制和哨兵机制,可以实现高可用性和故障转移。
支持事务:Redis可以通过MULTI、EXEC、WATCH等命令实现事务的功能,保证多个命令的原子性。
分布式:Redis Cluster可以将数据分布在多个节点上,提高系统的可扩展性和容错性。

Redis广泛应用于缓存、计数器、队列、排行榜等场景,具有高性能、高可用性和灵活性的特点,成为了很多互联网公司的首选技术之一。
 


一、REDIS概述

REDIS属于非关系型数据库,采用内存存储的方式(速度快,但不 能长久保存)

Redis全称Remote Dictionary Server 远程字典服务
官网:https://www.redis.net.cn/

 1.内存存储、持久化、   键值对存储、监听端口号:6379
 数据类型:
        字符串(string)
        哈希值(hash)
        列表(list)
        集合(set)
        位图(bitmap)

2.类型:
    文档型数据库(Document-oriented database)如MongoDB;
    列族数据库(Column-family database)如HBase、Cassandra等;
    图形数据库(Graph database)如Neo4j、ArangoDB等;
    键值对数据库(Key-value database)如Redis、Memcached等;
    对象数据库(Object-oriented database)如db4o等。

3.应用场景:
    缓存:Redis最常用的应用场景就是缓存,它可以缓存各种类型的数据,如数据库查询结果、API返回结果等,以提高应用程序的响应速度和并发性能。
    分布式锁:Redis的分布式锁可以确保在分布式系统中对某个资源的互斥访问,避免多个节点出现并发操作的问题。
    计数器:Redis支持对计数器的操作,能够方便地实现各种计数器的功能,如网站访问次数计数、订单数量计数等。
    会话管理:Redis可以用来管理会话信息,实现会话的状态存储和共享,避免了单点故障的问题。
    消息队列:Redis支持发布订阅模式,可以作为一个轻量级的消息队列使用,实现异步消息处理和任务派发等功能。

二、REDIS安装

1、编译安装

配置环境:设置防火墙、selinux、图形化、配置IP确保联网

[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# setenforce 0
setenforce: SELinux is disabled
[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
[root@localhost ~]# systemctl restart network
[root@localhost ~]# ping www.baidu.com
PING www.a.shifen.com (220.181.38.150) 56(84) bytes of data.
64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=1 ttl=128 time=51.6 ms
64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=2 ttl=128 time=32.7 ms
64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=3 ttl=128 time=111 ms
64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=4 ttl=128 time=114 ms
^C
--- www.a.shifen.com ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3004ms
rtt min/avg/max/mdev = 32.740/77.544/114.197/36.007 ms
[root@localhost ~]# 

下载wget http://download.redis.io/releases/redis-5.0.8.tar.gz

[root@localhost ~]# wget http://download.redis.io/releases/redis-5.0.8.tar.gz
--2023-08-08 23:05:12--  http://download.redis.io/releases/redis-5.0.8.tar.gz
正在解析主机 download.redis.io (download.redis.io)... 45.60.125.1
正在连接 download.redis.io (download.redis.io)|45.60.125.1|:80... 已连接。
已发出 HTTP 请求,正在等待回应... 200 OK
长度:1985757 (1.9M) [application/octet-stream]
正在保存至: “redis-5.0.8.tar.gz”100%[==============================================================================>] 1,985,757   46.3KB/s 用时 59s    2023-08-08 23:06:11 (32.7 KB/s) - 已保存 “redis-5.0.8.tar.gz” [1985757/1985757])[root@localhost ~]# ls
anaconda-ks.cfg  initial-setup-ks.cfg  redis-5.0.8.tar.gz  公共  模板  视频  图片  文档  下载  音乐  桌面
[root@localhost ~]# 

解压此处大家可自行选择路径,编译安装 make && make install

[root@localhost ~]# mkdir redis
[root@localhost ~]# tar -xf redis-5.0.8.tar.gz -C redis
[root@localhost ~]# cd redis/
[root@localhost redis]# ls
redis-5.0.8
[root@localhost redis]# cd redis-5.0.8/
[root@localhost redis-5.0.8]# make && make install

编译安装结束后我们进入配置文件redis.conf修改daemonize yes改为后台启动

在我们的redis-5.0.8目录启动REDIS命令:redis-server redis.conf 登录redis-cli

[root@localhost redis-5.0.8]# vim redis.conf
[root@localhost redis-5.0.8]# redis-server redis.conf 
8921:C 08 Aug 2023 16:34:33.301 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
8921:C 08 Aug 2023 16:34:33.301 # Redis version=5.0.8, bits=64, commit=00000000, modified=0, pid=8921, just started
8921:C 08 Aug 2023 16:34:33.301 # Configuration loaded
[root@localhost redis-5.0.8]# netstat -anput |grep redis
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      8922/redis-server 1 

2.yum安装

1.和编译安装一样配置环境

2.安装epel源前需要去看看我们的yum如下图所示,yum -y install epel-release

[root@localhost yum.repos.d]# ls
back                   CentOS-Media.repo
CentOS-Base.repo       CentOS-Sources.repo
CentOS-CR.repo         CentOS-Vault.repo
CentOS-Debuginfo.repo  CentOS-x86_64-kernel.repo
CentOS-fasttrack.repo
[root@localhost yum.repos.d]# yum -y install epel-release
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile* base: mirrors.bfsu.edu.cn* extras: mirrors.ustc.edu.cn* updates: mirrors.bfsu.edu.cn
base                                   | 3.6 kB     00:00     
extras                                 | 2.9 kB     00:00     
updates                                | 2.9 kB     00:00     
(1/4): base/7/x86_64/group_gz            | 153 kB   00:00     
(2/4): extras/7/x86_64/primary_db        | 250 kB   00:00     
(3/4): base/7/x86_64/primary_db          | 6.1 MB   00:05     
(4/4): updates/7/x86_64/primary_db       |  22 MB   00:10     
正在解决依赖关系
--> 正在检查事务
---> 软件包 epel-release.noarch.0.7-11 将被 安装
--> 解决依赖关系完成依赖关系解决==============================================================Package           架构        版本         源           大小
==============================================================
正在安装:epel-release      noarch      7-11         extras       15 k事务概要
==============================================================
安装  1 软件包总下载量:15 k
安装大小:24 k
Downloading packages:
警告:/var/cache/yum/x86_64/7/extras/packages/epel-release-7-11.noarch.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY
epel-release-7-11.noarch.rpm 的公钥尚未安装
epel-release-7-11.noarch.rpm             |  15 kB   00:00     
从 file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 检索密钥
导入 GPG key 0xF4A80EB5:用户ID     : "CentOS-7 Key (CentOS 7 Official Signing Key) <security@centos.org>"指纹       : 6341 ab27 53d7 8a78 a7c2 7bb1 24c6 a8a7 f4a8 0eb5软件包     : centos-release-7-9.2009.0.el7.centos.x86_64 (@anaconda)来自       : /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction正在安装    : epel-release-7-11.noarch                  1/1 验证中      : epel-release-7-11.noarch                  1/1 已安装:epel-release.noarch 0:7-11                                  完毕!
[root@localhost yum.repos.d]# 

安装yum -y install redis

[root@localhost yum.repos.d]# yum -y install redis
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
epel/x86_64/metalink                   | 5.9 kB     00:00     * base: mirrors.bfsu.edu.cn* epel: mirrors.bfsu.edu.cn* extras: mirrors.huaweicloud.com* updates: mirrors.bfsu.edu.cn
epel                                   | 4.7 kB     00:00     
(1/3): epel/x86_64/group_gz              |  99 kB   00:00     
(2/3): epel/x86_64/updateinfo            | 1.0 MB   00:00     
(3/3): epel/x86_64/primary_db            | 7.0 MB   00:03     
正在解决依赖关系
--> 正在检查事务
---> 软件包 redis.x86_64.0.3.2.12-2.el7 将被 安装
--> 正在处理依赖关系 libjemalloc.so.1()(64bit),它被软件包 redis-3.2.12-2.el7.x86_64 需要
--> 正在检查事务
---> 软件包 jemalloc.x86_64.0.3.6.0-1.el7 将被 安装
--> 解决依赖关系完成依赖关系解决==============================================================Package       架构        版本               源         大小
==============================================================
正在安装:redis         x86_64      3.2.12-2.el7       epel      544 k
为依赖而安装:jemalloc      x86_64      3.6.0-1.el7        epel      105 k事务概要
==============================================================
安装  1 软件包 (+1 依赖软件包)总下载量:648 k
安装大小:1.7 M
Downloading packages:
警告:/var/cache/yum/x86_64/7/epel/packages/jemalloc-3.6.0-1.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID 352c64e5: NOKEY
jemalloc-3.6.0-1.el7.x86_64.rpm 的公钥尚未安装
(1/2): jemalloc-3.6.0-1.el7.x86_64.rpm   | 105 kB   00:00     
(2/2): redis-3.2.12-2.el7.x86_64.rpm     | 544 kB   00:00     
--------------------------------------------------------------
总计                             686 kB/s | 648 kB  00:00     
从 file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7 检索密钥
导入 GPG key 0x352C64E5:用户ID     : "Fedora EPEL (7) <epel@fedoraproject.org>"指纹       : 91e9 7d7c 4a5e 96f1 7f3e 888f 6a2f aea2 352c 64e5软件包     : epel-release-7-11.noarch (@extras)来自       : /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction正在安装    : jemalloc-3.6.0-1.el7.x86_64               1/2 正在安装    : redis-3.2.12-2.el7.x86_64                 2/2 验证中      : redis-3.2.12-2.el7.x86_64                 1/2 验证中      : jemalloc-3.6.0-1.el7.x86_64               2/2 已安装:redis.x86_64 0:3.2.12-2.el7                                 作为依赖被安装:jemalloc.x86_64 0:3.6.0-1.el7                               完毕!

3.启动systemctl start redis

[root@localhost yum.repos.d]# systemctl start redis
[root@localhost yum.repos.d]# netstat -anput |grep redis
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      9483/redis-server 1 
[root@localhost yum.repos.d]# 

三、Redis的目录结构

/var/lib/redis 持久化文件存储目录

/var/log/redis

日志文件存储目录
/var/run/redis PID文件存储目录
    /etc/redis.conf主配置文件 
 bind 127.0.0.1修改监听地址
port 6379修改监听端口号
pidfile 指定通过该配置文件启动reids进程后的PID文件名称
 loglevel定义日志级别
 logfile定义日志存储路径
 databases 指定默认数据库数量
save定义单位时间内key的改变次数
dbfilename定义存储RDB持久化数据的文件名称
dir定义RDB与AOF文件的存储目录
appendonly AOF的启停

appendfilename

定义AOF持久化文件的名称
 appendfsync定义AOF数据同步间隔
 requirepass设置登录redis的密码

 

四、基础命令解析

redis-server redis启动命令
redis-cli

redis登录命令

-h:    redis服务器IP

-p:    指定访问端口号

-a:    指定登录密码

-n:    指定数据库编号

redis-check-rdb 检查RDB文件
redis-check-aof 检查AOF文件

五、在一台服务器上启动多个redis

1.列如我是采用yum的方式安装的redis,直接使用systectl start redis启动

[root@localhost yum.repos.d]# systemctl start redis
[root@localhost yum.repos.d]# 
[root@localhost yum.repos.d]# netstat -anput |grep redis
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      10942/redis-server  
[root@localhost yum.repos.d]# 

2.接下来将redis的主配置文件复制到/opt目录下(可以以端口号命名,方便操作)

[root@localhost redis-5.0.8]# ls
00-RELEASENOTES  dump.rdb   redis.conf         sentinel.conf
BUGS             INSTALL    runtest            src
CONTRIBUTING     Makefile   runtest-cluster    tests
COPYING          MANIFESTO  runtest-moduleapi  utils
deps             README.md  runtest-sentinel
[root@localhost redis-5.0.8]# cp redis.conf /opt/redis_6380.conf
[root@localhost redis-5.0.8]# cd /opt/
[root@localhost opt]# ls
redis_6380.conf  rh

3.来到/opt目录在redis的配置文件中修改redis的端口vim /redis_6380.conf

4.启动端口号为6380的redis并且验证服务是否启动

[root@localhost opt]# redis-server /opt/redis_6380.conf 
11126:C 08 Aug 2023 18:25:18.898 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
11126:C 08 Aug 2023 18:25:18.898 # Redis version=5.0.8, bits=64, commit=00000000, modified=0, pid=11126, just started
11126:C 08 Aug 2023 18:25:18.898 # Configuration loaded
[root@localhost opt]# netstat -anput |grep redis
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      10942/redis-server  
tcp        0      0 127.0.0.1:6380          0.0.0.0:*               LISTEN      11127/redis-server  
[root@localhost opt]# 

5.按照此方法可以启动多个redis

六、数据库的基本操作

(一)登录数据库

本地登录

监听回环地址           redis-cli

监听本地网卡地址    redis-cli -h IP - 端口号

远程登录redis-cli -h IP -p 端口号

1、本地登录  redis-cli

2、远程登录 (这里我们需要2台主机并且都安装redis),我想用主机2登录主机1

在主机1的配置文件中修改bind监听地址为主机1的IP,并且设置一个密码,重启服务

: 

 在主机2上远程登录1命令redis-cli -h 192.168.73.10 -p 6379之后输入我们在主机1上设置的密码

[root@localhost redis-5.0.8]# redis-cli -h 192.168.73.10 -p 6379
192.168.73.10:6379> set k1 v1
(error) NOAUTH Authentication required.
192.168.73.10:6379> auth 123.com
OK

(二)基础命令

在redis中我们可以使用帮助信息 help 命令字  、tab补齐

库操作: 切换  select 数据库编号

set 设置键值对 set key value

keys * 查看所有键的名称
keys 键名称   查看一个键是否存在

get 取出键值对
get 键       键不存在则返回空

del 删除键值对

 flushall  清空所有数据库中的数据(慎用)

rename 重命名键名称

不论更名后的键是否存在都会覆盖原有键,并将改名前的键的值赋予改名后的键
rename oldkey newkey

 renamenx  重命名键名称
 假如改名后键名称存在则更改不成功
 renamenx oldkey newkey

move
    移动键值对到指定数据库
    move key dbnumber
    假如目标数据库中存在同名键则移动失败

 ttl查看键值对的生命周期
 ttl key   (-1 永久-2已过期)

expire
    设置键值对的存储周期
    expire key seconds

七、Redis持久化

Redis的持久化原理主要包括两种方式:RDB持久化和AOF持久化。

(一)RDB持久化


RDB持久化:RDB持久化是通过将Redis的数据集快照保存到硬盘上的一个二进制文件中实现的。当执行RDB持久化时,Redis会fork一个子进程来处理久化工作,该子进程会将当前数据集的副本保存到一个临时文件中,待保存完成后,再替换原来的RDB文件。RDB持久化的优点是可以生成一个紧凑的二进制文件,适合用于备份和恢复数据。缺点是在发生故障时,可能会丢失最后一次持久化后的数据。

RDB模式  默认持久化
dump.rdb数据库启动时会读取
触发条件:redis进程退出、宕机、redis程序崩溃
手动保存(触发RDB)    save

在配置文件中我们可以看到dump.rdp

[root@localhost redis-5.0.8]# ls
00-RELEASENOTES  dump.rdb   redis.conf         sentinel.conf
BUGS             INSTALL    runtest            src
CONTRIBUTING     Makefile   runtest-cluster    tests
COPYING          MANIFESTO  runtest-moduleapi  utils
deps             README.md  runtest-sentinel

dump.rdp中存储着我们库里的数据,会自动记录,也可以通过save命令手动触发。

(二)AOF持久化

AOF持久化:AOF持久化是通过将Redis的操作日志追加到一个文件中实现的。当执行AOF持久化时,Redis会将每个写操作(包括读操作)以类似于写日志的方式追加到AOF文件的末尾。当Redis重启时,会重新执行AOF文件中的操作日志来恢复数据集的状态。AOF持久化的优点是可以提供更好的数据安全性,因为操作日志可以追加到文件中,避免数据丢失。缺点是AOF文件通常比RDB文件大,并且恢复数据集的速度比RDB持久化慢。

 AOF模式AOF模式
appendonly.aof默认进程启动时读取
开启appendonly  yes   可以与RDB同时使用

在配置文件redis.conf中手动开启此功能,保存退出,重启服务

 此时查看配置文件就会出现新生成的文件,里面会记录我们在数据库的操作与MySQL的二进制文件有些类似

我们查一下里面的内容

 我们去数据库进行一些操作后再来看此文件

在Redis的配置文件中,可以通过设置"save"选项来控制RDB持久化的频率,通过设置"appendonly"选项来启用AOF持久化。此外,Redis还支持将RDB持久化和AOF持久化结合使用,以提供更好的数据安全性和恢复速度。


总结

今天很高兴和大家分享这些内容,今天主要是要对我们redis的安装进行一个操作,对于主配置文件来说是要记忆的,很多功能需要从中开启,最后要了解持久化的原理。

相关文章:

Redis的安装方法与基本操作

目录 前言 一、REDIS概述 二、REDIS安装 1、编译安装 2.yum安装 三、Redis的目录结构 四、基础命令解析 五、在一台服务器上启动多个redis 六、数据库的基本操作 &#xff08;一&#xff09;登录数据库 &#xff08;二&#xff09;基础命令 七、Redis持久化 &#xff08;一&…...

选读SQL经典实例笔记20_Oracle语法示例

1. 计算一年有多少天 1.1. sql select Days in 2005: ||to_char(add_months(trunc(sysdate,y),12)-1,DDD)as reportfrom dualunion allselect Days in 2004: ||to_char(add_months(trunc(to_date(01-SEP-2004),y),12)-1,DDD)from dual REPORT ----------------- Days in 200…...

JAVA细节/小技巧

一、 Callable类可以实现返回结果的多线程。实现Callable类&#xff0c;然后实例化一个对象传递给FutureTask&#xff0c;然后把FutureTask对象传递给Thread对象&#xff0c;执行start即可开始多线程。FutureTask对象执行get函数可以获得Callable类中call函数的返回值&#xf…...

jmeter如何压测和存储

一、存储过程准备&#xff1a; 1、建立一个空表&#xff1a; 1 CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER ); 2、建立一个存储过程&#xff1a; 1 2 3 4 5 6 7 8 9 CREATE OR REPLACE PROCEDURE insert_test_data (n IN NUMBER) AS BEGIN --E…...

一个月学通Python(三十三):Python并发编程在爬虫中的应用

专栏介绍 结合自身经验和内部资料总结的Python教程,每天3-5章,最短1个月就能全方位的完成Python的学习并进行实战开发,学完了定能成为大佬!加油吧!卷起来! 全部文章请访问专栏:《Python全栈教程(0基础)》 再推荐一下最近热更的:《大厂测试高频面试题详解》 该专栏对…...

HCIP——STP

STP 一、STP概述二、二层环路带来的问题1、广播风暴问题2、MAC地址漂移问题3、多帧复制 三、802.1D生成树STP的BPDU1、配置BPDU2、RPC3、COST4、配置BPDU的工作过程5、TCN BPDU6、TCN BPDU的工作原理 四、STP的角色五、STP角色选举六、STP的接口状态七、接口状态的迁移八、STP的…...

【数据结构】“单链表”的练习题

&#x1f490; &#x1f338; &#x1f337; &#x1f340; &#x1f339; &#x1f33b; &#x1f33a; &#x1f341; &#x1f343; &#x1f342; &#x1f33f; &#x1f344;&#x1f35d; &#x1f35b; &#x1f364; &#x1f4c3;个人主页 &#xff1a;阿然成长日记 …...

项目实战 — 消息队列(5){统一硬盘操作}

前面已经使用数据库管理了交换机、绑定、队列&#xff0c;然后又使用了数据文件管理了消息。 那么&#xff0c;这里就创建一个类&#xff0c;讲之前的两个部分整合起来&#xff0c;对上层提供统一的一套接口&#xff0c;表示硬盘上存储的所有的类的信息。 /* * 用这个类来管理…...

【2.2】Java微服务:Hystrix的详解与使用

目录 分布式系统面临问题 Hystrix概念 Hystrix作用 降级 什么是降级 order服务导入Hystrix依赖&#xff08;简单判断原则&#xff1a;谁调用远程谁加&#xff09; 启动类添加注解 业务方法添加注解&#xff08;冒号里填回调方法名&#xff0c;回调方法返回兜底数据&…...

【PYTHON】WebSocket服务端与客户端通信实现

目录 1 简介 2 WebSocket优点 3 前后端交互的方式 4 心跳机制和重连机制 5 后端代码 6 测试...

Runloop 的五种mode

1.runloop是一个事件驱动的循环,收到事件就去处理,没有事件就进入睡眠. 2.应用一启动主线程被创建后,主线程对应的runloop也被创建,runloop也保证了程序能够一直运行.之后创建的子线程默认是没有runloop的,只有当调用[NSRunLoop currentRunLoop]去获取的时候才被创建. 3.runloo…...

C++头文件使用精要

一、头文件包含顺序 根据《Google C 编程风格指南》&#xff0c;对于Foo.cpp&#xff0c;顺序推荐为&#xff1a; Foo.hC标准库C标准库其它库的头文件本工程的头文件 另外&#xff0c;在包含头文件时应该加上头文件所在工程的文件夹名&#xff0c;可区分重名文件。即假如你有…...

Flink之SideOutput(数据分流)

Flink在早期版本有一个split算子用来做数据分流使用的,但是在flink-1.12开始这个API就已经被删除了,在1.12版本以后我们是通过process算子来做数据分流的,这里就介绍一下如何使用prodess进行数据分流. 代码 import org.apache.flink.api.common.typeinfo.TypeInformation; im…...

Android Studio新版本logcat过滤说明

按包名过滤 //输入package:&#xff08;输入一个p就会有提示的&#xff09; &#xff0c;后面加上包名 比如: package:com.xal.runcontrol package:包名可以完整或者输部分包名即可 package:包名需要输完整准确 package~:正则表达式过滤 不了解正则表达式的可以参考&#…...

carsim与matlab仿真

matlab2021a安装教程&#xff0c;亲测。 百度网盘&#xff1a; matlab2021a安装包 提取码&#xff1a;1223 CarSim2020安装教程&#xff0c; 亲测。 百度网盘&#xff1a; CarSim2020安装包 提取码&#xff1a;1223 &#xff0c;破解可参考 b站视频...

rust里如何快速实现一个LRU 本地缓存?

LRU是Least Recently Used&#xff08;最近最少使用&#xff09;的缩写&#xff0c;是一种常见的缓存淘汰算法。LRU算法的基本思想是&#xff0c;当缓存空间已满时&#xff0c;优先淘汰最近最少使用的数据&#xff0c;以保留最常用的数据。 在计算机系统中&#xff0c;LRU算法…...

MQTT 订阅接收消息 mosquitto 方式

1 说明 采用 mosquitto 库&#xff0c;实现订阅主题&#xff0c;并接收消息。其中服务器有做限制&#xff0c;需要对应的 cilent id &#xff0c;cafile 、certfile 、keyfile 等配置2 环境 采用ubuntu 直接编译调试 安装mosquitto 库 sudo apt install libmosquitto-dev su…...

以mod_jk方式整合apache与tomcat(动静分离)

前言&#xff1a; 为什么要整合apache和tomcat apache对静态页面的处理能力强&#xff0c;而tomcat对静态页面的处理不如apache&#xff0c;整合后有以下好处 提升对静态文件的处理性能 利用 Web 服务器来做负载均衡以及容错 更完善地去升级应用程序 jk整合方式介绍&#…...

springboot动态数据源切换

1&#xff09;、就是将多个数据源全部注入到bean中&#xff0c;根据需要实现多数据源之间的切换。 2&#xff09;、使用baomidou的DS注解。见文章DS注解实现数据源动态切换 com.baomidou dynamic-datasource-spring-boot-starter 3.5.1 ##设置默认的数据源或者数据源组,默认值…...

代码随想录训练营day14

101. 对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 func isSymmetric(root *TreeNode) bool {if root nil{ return true}return judge(root.Left,root.Right) }func judge(lf *TreeNode , ri *TreeNode)bool{if lf nil && ri nil{ retu…...

功能测试进阶自动化测试如何摸清学习方向,少走弯路呢?

目录 抛开疑问&#xff0c;只做学术探讨 小白在想什么&#xff1f; 盖楼之前先打好地基&#xff0c;首先需要学习一门语言 语言入门后&#xff0c;正式踏上开始自动化成神之路&#xff0c;入门篇Selenium 玩腻了Selenium 开始接触自动化框架unittest/testNG 不满足于单元…...

检测前端是否可以ping通后端返回的ip地址

检测前端是否可以ping通后端返回的ip地址 前端检测是否可ping通ip地址&#xff08;PC端&#xff09;前端检测是否可ping通ip地址&#xff08;uniapp小程序端&#xff09; 前端检测是否可ping通ip地址&#xff08;PC端&#xff09; // 前端检测是否可ping通ip地址 ping…...

SMART司马他法则(目标管理)

S代表具体(Specific)&#xff0c;指绩效考核要切中特定的工作指标&#xff0c;不能笼统&#xff1b; M代表可度量(Measurable)&#xff0c;指绩效指标是数量化或者行为化的&#xff0c;验证这些绩效指标的数据或者信息是可以获得的&#xff1b; A代表可实现(Attainable)&…...

【LeetCode】删除并获得点数

删除并获得点数 题目描述算法分析编程代码空间优化 链接: 删除并获得点数 题目描述 算法分析 编程代码 class Solution { public:int deleteAndEarn(vector<int>& nums) {const int N 10001;int arr[N] {0};for(const auto& n : nums){arr[n]n;}vector<in…...

SciencePub学术 | 传感器类重点SCIE征稿中

SciencePub学术 刊源推荐: 传感器类重点SCIE征稿中&#xff01;信息如下&#xff0c;录满为止&#xff1a; 一、期刊概况&#xff1a; 传感器类重点SCIE 【期刊简介】IF&#xff1a;2.0-2.5&#xff0c;JCR3区&#xff0c;中科院4区&#xff1b; 【版面类型】正刊&#xff1…...

移动端开发基础总结

移动端学习总结 (适合于复习) 移动端基础 技术选型&#xff1a; 单独制作移动端页面&#xff08;主流&#xff09; 流式布局&#xff08;百分比布局&#xff09;flex弹性布局&#xff08;强烈推荐&#xff09;lessrem媒体查询布局混合布局 响应式页面兼容移动端&#xff08;…...

小X学游泳(深搜)

第一题 题目描述 小X想要学游泳。 这天&#xff0c;小X来到了游泳池&#xff0c;发现游泳池可以用N行M列的格子来表示&#xff0c;每个格子的面积都是1&#xff0c;且格子内水深相同。 由于小X刚刚入门&#xff0c;他只能在水深相同的地方游泳。为此&#xff0c;他把整个游泳池…...

分布式协议与算法——拜占庭将军问题

拜占庭将军问题 背景&#xff1a;以战国时期为背景 战国时期&#xff0c;齐、楚、燕、韩、赵、魏、秦七雄并立&#xff0c;后来秦国的势力不断强大起来&#xff0c;成了东方六国的共同威胁。于是&#xff0c;这六个国家决定联合&#xff0c;全力抗秦&#xff0c;免得被秦国各个…...

MySQL数据库管理的基本原则和技巧

MySQL数据库是一种常用的关系型数据库管理系统&#xff0c;用于存储和管理大量的数据。在进行MySQL数据库管理时&#xff0c;有一些基本原则和技巧可以帮助我们更有效地管理数据库。 数据库设计原则&#xff1a; 合理规划数据表结构&#xff1a; 根据数据之间的关系和业务需求…...

SQL-每日一题【1193. 每月交易 I】

题目 Table: Transactions 编写一个 sql 查询来查找每个月和每个国家/地区的事务数及其总金额、已批准的事务数及其总金额。 以 任意顺序 返回结果表。 查询结果格式如下所示。 示例 1: 解题思路 1.题目要求我们查找每个月和每个国家/地区的事务数及其总金额、已批准的事务数…...