百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

redis缓存服务重点简单总结(redis缓存技术)

mhr18 2024-10-23 11:37 26 浏览 0 评论

redis缓存服务重点简单总结(cent6.6和red6.5)

如果对运维课程感兴趣,可以在b站上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频

1.redis缓存服务安装和测试存储数据(单redis服务,使用默认端口6379运行时)

1)在192.168.14.128上:(服务端)(安装redis服务,需要启动服务)

[root@bogon ~]# yum -y install gcc gcc-c++

[root@bogon ~]# tar -zxf redis-2.6.14.tar.gz

[root@bogon ~]# cd redis-2.6.14

[root@bogon redis-2.6.14]# make MALLOC=jemalloc

[root@bogon redis-2.6.14]# make PREFIX=/usr/local/redis install

[root@bogon redis-2.6.14]# mkdir /usr/local/redis/conf #优化目录结构

[root@bogon redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ #配置其他功能可修改配置文件

[root@bogon redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@bogon redis-2.6.14]# . /etc/profile

[root@bogon redis-2.6.14]# sysctl vm.overcommit_memory=1 #解决启动时内存不够问题

[root@bogon redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf

[root@bogon redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动

[root@bogon redis-2.6.14]# lsof -i :6379 #有端口

[root@bogon redis-2.6.14]# ps -ef |grep redis #有进程

[root@bogon redis-2.6.14]# pkill redis-server #杀掉服务

[root@bogon redis-2.6.14]# redis-cli shutdown #停止服务

[root@bogon redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动

[1] 3466

.........

[3466] 18 Apr 21:22:20.483 * The server is now ready to accept connections on port 6379 回车即可

注意事项1:

1)若配置文件里改成在后台运行(yes),启动时候才能将pid号保存到配置文件指定文件,那么启动时候不用加&选项。若配置文件不是指定在后台运行(是no),那么即使配置文件指定了存放pid号的文件,该文件里也不会有pid号.

2)若默认端口号改成其他端口号,客户端连接时候需要指定端口号才能连接。

[root@bogon ~]# vim /usr/local/redis/conf/redis.conf

daemonize no #默认情况下,redis不是在后台运行的,如果需要在后台运行,把该项的值更改为yes

pidfile /var/run/redis.pid #当redis在后台运行时(yes时),redis默认会把pid文件放在/var/run/redis.pid,也可配置到其他地址

port 6379 #默认端口号,也可修改为其他,若改为其他,则客户端登录时需指定端口号

注意事项2:redis可以设置密码,让客户端指定密码才能连接:客户端不指定密码,看似能连上,但用keys * 查不到数据

#vim ...redis.conf

requirepass Duyao001 #密码设置为Duyao001

此后客户端连接redis服务器时候,需要指定密码才能连接上,#redis-cli -h redis服务ip -p 端口号 -a Duyao001(密码)

2)本地测试存储数据和获得数据:(redis-cli客户端测试)

[root@bogon redis-2.6.14]# redis-cli 或者:redis-cli -h 192.168.14.128 -p 6379

redis 192.168.14.128:6379> set key1 001

OK

redis 192.168.14.128:6379> set key2 002

OK

redis 192.168.14.128:6379> get key1

"001"

redis 192.168.14.128:6379> get key2

"002"

redis 192.168.14.128:6379> del key1

(integer) 1

redis 192.168.14.128:6379> get key1

(nil)

redis 192.168.14.128:6379> quit

3)其他机器192.168.14.129上:作为客户端测试存储数据和获得数据:(redis-cli客户端测试,也需要安装redis,利用里面的客户端工具redis-cli,但不需要启动redis服务)

[root@localhost ~]# yum -y install gcc gcc-c++

[root@localhost ~]# tar -zxf redis-2.6.14.tar.gz

[root@localhost ~]# cd redis-2.6.14

[root@localhost redis-2.6.14]# make MALLOC=jemalloc

[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install #客户端安装一下即可,不用优化目录,不用启动服务

[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@localhost redis-2.6.14]# . /etc/profile

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379

redis 192.168.14.128:6379> set key5 005

OK

redis 192.168.14.128:6379> set key6 006

OK

redis 192.168.14.128:6379> get key5

"005"

redis 192.168.14.128:6379> get key6

"006"

redis 192.168.14.128:6379> del key5

(integer) 1

redis 192.168.14.128:6379> get key5

(nil)

redis 192.168.14.128:6379> quit

注意:本地客户端和和其他机器客户端都一样,其他机器只是需要安装一个命令,本地客户端已经安装过命令,不需再安装命令而已。

2.redis缓存服务安装和测试存储数据(redis服务多实例启动,使用指定多端口,多pid并存放到指定文件中运行时)

1)在192.168.14.128上:(服务端)(安装redis服务,需要启动服务)

[root@bogon ~]# yum -y install gcc gcc-c++

[root@bogon ~]# tar -zxf redis-2.6.14.tar.gz

[root@bogon ~]# cd redis-2.6.14

[root@bogon redis-2.6.14]# make MALLOC=jemalloc

[root@bogon redis-2.6.14]# make PREFIX=/usr/local/redis install

[root@bogon redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构

[root@bogon redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件

[root@bogon redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@bogon redis-2.6.14]# . /etc/profile

[root@bogon redis-2.6.14]# sysctl vm.overcommit_memory=1 //解决内存小时启动警告问题

[root@bogon redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf

[root@bogon redis-2.6.14]# cd /usr/local/redis/conf/

[root@bogon redis-2.6.14]# vim redis.conf #默认的配置文件作为实例1

daemonize yes #修改为后台,其他保持默认,

pidfile /var/run/redis.pid

port 6379

[root@bogon redis-2.6.14]# cp redis.conf redis2.conf

[root@bogon redis-2.6.14]# cp redis.conf redis3.conf

[root@bogon redis-2.6.14]# vim redis2.conf #复制一个配置文件作为实例2

daemonize yes #修改为后台

pidfile /var/run/redis2.pid #修改

port 6380 #修改

[root@bogon redis-2.6.14]# vim redis3.conf #再复制一个配置文件作为实例3

daemonize yes #修改为后台

pidfile /var/run/redis2.pid #修改

port 6381 #修改

[root@bogon conf]# redis-server /usr/local/redis/conf/redis.conf #指定配置文件启动

[root@bogon conf]# redis-server /usr/local/redis/conf/redis2.conf #指定配置文件启动

[root@bogon conf]# redis-server /usr/local/redis/conf/redis3.conf #指定配置文件启动

[root@bogon conf]# ps -ef |grep redis

root 3857 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis.conf

root 3861 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis2.conf

root 3865 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis3.conf

root 3869 1406 0 00:01 pts/0 00:00:00 grep redis

[root@bogon conf]# cat /var/run/redis.pid

3857

[root@bogon conf]# cat /var/run/redis2.pid

3861

[root@bogon conf]# cat /var/run/redis3.pid

3865

[root@bogon conf]# netstat -anput |grep redis

tcp 0 0 0.0.0.0:6379 0.0.0.0:* LISTEN 3857/redis-server

tcp 0 0 0.0.0.0:6380 0.0.0.0:* LISTEN 3861/redis-server

tcp 0 0 0.0.0.0:6381 0.0.0.0:* LISTEN 3865/redis-server

多实例注意:

1)若用单独杀进程号杀掉单独一个实例,其他实例会正常工作而不受影响,只是当前杀掉的实例不能工作。

2)若用pkill redis-server按服务名杀掉服务,则所有实例都将被杀掉。

2)其他机器192.168.14.129上:作为客户端测试存储数据和获得数据:(redis-cli客户端测试,也需要安装redis,利用里面的客户端工具redis-cli,但不需要启动redis服务) #注意本地客户端和这一样,其他机器只是需要安装一个命令

[root@localhost ~]# yum -y install gcc gcc-c++

[root@localhost ~]# tar -zxf redis-2.6.14.tar.gz

[root@localhost ~]# cd redis-2.6.14

[root@localhost redis-2.6.14]# make MALLOC=jemalloc

[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install #客户端只是安装命令,不需启动服务和优化目录

[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@localhost redis-2.6.14]# . /etc/profile

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379

redis 192.168.14.128:6379> set key1 001

OK

redis 192.168.14.128:6379> quit

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6380

redis 192.168.14.128:6380> set key2 002

OK

redis 192.168.14.128:6380> quit

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6381

redis 192.168.14.128:6381> set key3 003

OK

redis 192.168.14.128:6381> quit

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379

redis 192.168.14.128:6379> get key1

"001"

redis 192.168.14.128:6379> del key1

(integer) 1

redis 192.168.14.128:6379> get key1

(nil)

redis 192.168.14.128:6379> quit

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6380

redis 192.168.14.128:6380> get key2

"002"

redis 192.168.14.128:6380> del key2

(integer) 1

redis 192.168.14.128:6380> get key2

(nil)

redis 192.168.14.128:6380> quit

[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6381

redis 192.168.14.128:6381> get key3

"003"

redis 192.168.14.128:6381> del key3

(integer) 1

redis 192.168.14.128:6381> get key3

(nil)

redis 192.168.14.128:6381> quit

3.redis主从同步项目和负载均衡单实例redis服务(cent6.6和red6.5)

在192.168.4.5上(搭建redis服务(主))

[root@localhost 桌面]# yum -y install gcc gcc-c++

[root@localhost 桌面]# tar -zxf redis-2.6.14.tar.gz

[root@localhost 桌面]# cd redis-2.6.14

[root@localhost redis-2.6.14]# make MALLOC=jemalloc

[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install

[root@localhost redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构

[root@localhost redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件

[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@localhost redis-2.6.14]# . /etc/profile

[root@localhost redis-2.6.14]# sysctl vm.overcommit_memory=1 #解决启动时内存不够问题

[root@localhost redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf

[root@localhost redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动

[1] 5409

.......

[5409] 19 Jun 21:09:02.779 * The server is now ready to accept connections on port 6379 回车

[root@localhost redis-2.6.14]# lsof -i :6379 #有端口

[root@localhost redis-2.6.14]# ps -ef |grep redis #有进程

注意: redis-cli shutdown 是停止服务 pkill redis-server是杀掉服务

在192.168.4.205上(搭建redis服务(从))

[root@localhost 桌面]# yum -y install gcc gcc-c++

[root@localhost 桌面]# tar -zxf redis-2.6.14.tar.gz

[root@localhost 桌面]# cd redis-2.6.14

[root@localhost redis-2.6.14]# make MALLOC=jemalloc

[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install

[root@localhost redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构

[root@localhost redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件

[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile

[root@localhost redis-2.6.14]# . /etc/profile

[root@localhost redis-2.6.14]# sysctl vm.overcommit_memory=1

[root@localhost redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf

[root@localhost redis-2.6.14]# vim /usr/local/redis/conf/redis.conf

slaveof 192.168.4.5 6379 //修改,指定主的IP和端口

wq

[root@localhost redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动

上面提示中有:从库开始连主库,同步开始等提示

[root@localhost redis-2.6.14]# lsof -i :6379 #有端口

在192.168.4.5上(在主库上写些数据)

[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379

redis localhost:6379> set name1 shi1

OK

redis localhost:6379> set name2 shi2

OK

redis localhost:6379> set name3 shi3

OK

redis localhost:6379> quit

在192.168.4.205上(在从库上查看数据也将主库的数据同步过来)

[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.205 -p 6379

redis 192.168.4.5:6379> get name1

"shi1"

redis 192.168.4.5:6379> get name2

"shi2"

redis 192.168.4.5:6379> get name3

"shi3"

redis 192.168.4.5:6379> quit

在192.168.4.5上(在主库上删除一些数据)

[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379

redis localhost:6379> del name1

(integer) 1

redis localhost:6379> get name1

(nil)

redis localhost:6379> get name2

"shi2"

redis localhost:6379> get name3

"shi3"

redis localhost:6379> quit

在192.168.4.205上(在从库上查看数据也将主库的数据同步过来)

[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379

redis 192.168.4.5:6379> get name1

(nil)

redis 192.168.4.5:6379> get name2

"shi2"

redis 192.168.4.5:6379> get name3

"shi3"

redis 192.168.4.5:6379> quit

注意事项:redis可以设置密码,让客户端指定密码才能连接:客户端不指定密码,看似能连上,但用keys * 查不到数据

#vim ...redis.conf

requirepass Duyao001 #密码设置为Duyao001

此后客户端连接redis服务器时候,需要指定密码才能连接上,#redis-cli -h redis服务ip -p 端口号 -a Duyao001(密码)

4.redis的常用命令知识-补充(前锋python开发)

1)String:

概述:string是redis最基本的类型,最大能存储512M的数据,string类型是二进制安全的,即可以存储任何数据,比如数字、图片,序列化对象等。

设置:

A、设置键值 语法:set 键名 键值 如:set k1 v1

B、设置键值及过期时间(以秒为单位) 语法:setex 键名 秒数 键值 如:setex k1 9 v1

C、设置多个键值 语法:mset 键名1 键值1 键名2 键值2 如:mset k1 v1 k2 v2

获取:

A、根据键获取值,如果键不存在则返回null 语法:get 键名 如:get k1

B、根据多个键获取多个值 语法:mget 键名1 键名2 键名3 如:mget k1 k2 k3

运算:

要求:值时数字类型的字符串

A、将key对应的值加1 语法:incr 键名 如:incr age

B、将key对应的值减1 语法:decr 键名 如:decr age

C、将key对应的值加一个整数 语法:incrby 键名 整数数字 如:incrby age 3

D、将key对应的值减一个整数 语法:decrby 键名 整数数字 如:decrby age 3

其他:

A、追加值 语法:append 键名 键值 如:append age 4

B、获取键值长度 语法:strlen 键名 如:strlen age

2)key

查找键: 语法:keys 正则表达式 如:keys * 查找所有的键

判断键是否存在,如果存在返回1,不存在返回0 语法:exists 键名 如: exists age

查看键对应的value类型: 语法:type 键名 如:type name

删除键及对应的值: 语法:del 键名 如:del age

设置过期时间,以秒为单位 语法:expire 键名 秒数 如:expire age 5 #该键只存在5s

查看有效时间,以秒为单位 语法:ttl 键名 如:ttl age

3)hash

概述: hash用于存储对象

(1)设置

A、设置单个值: 语法:hset 大键名 小键名 小键值 如:hset k1 name tom ; hset k1 age 18;

B、设置多个值: 语法:hmset 大键名 小键名 小键值 如:hmset k2 name tom age 20

(2)获取

A、获取一个属性的值(获取大键名中小键名的值) 语法:hget 大键名 小键名 如:hget k1 name

B、获取多个属性的是(获取大键名中小键名的值) 语法:hmget 大键名 小键名1 小键名2 ... 如:hmget k1 name age

C、获取所有属性和值(获取大键名中所有小键名和值) 语法:hgetall 大键名 如:hgetall k1

D、获取所有的属性(获取大键名中所有小键名) 语法:hkeys 大键名 如:hkeys k1

E、获取所有值(获取大键名中所有小键名的值) 语法:hvals 大键名 如:hvals k1

F、返回包含数据的个数(获取大键名中所有小键名的个数) 语法:hlen 大键名 如:hlen k1

3、其他

A、判断属性是否存在,存在返回1,不存在返回0(判断大键名中小键名是否存在

语法:hexists 大键名 小键名 如:hexists k1 name #判断k1里的name属性是否存在

B、删除属性及值

语法:hdel 大键名 小键名 如:hdel k1 name #删除k1里的name属性和值

4)list:

概述:列表的元素类型为string,按照插入顺序排序,在列表的头部或尾部添加元素。

1、设置

A、在头部插入(可插多个) 语法:lpush 键名 键值 如:lpush s1 1; lpush s1 2

B、在尾部插入(可插多个) 语法:rpush 键名 键值 如:rpush s1 3; rpush s1 4

C、在一个元素的前|后插入新元素:

语法:linsert 键名 before|after 基准元素数据 要插的值 如:linsert s1 before|after 1 4

D、设置指定索引的元素值

语法:lset 键名 索引下标 要设置成的值 ,如:lset s1 2 40 #将key为s1的下标为2的元素值设置为40

注意:index从0开始,索引值可以是负数,表示偏移量是从list的尾部开始,如:-1表示最后一个元素。

2、获取:

A、移除并返回key对应的list的第一个元素

语法:lpop 键名 如:lpop s1

B、移除并返回key对应的list的最后一个元素

语法:rpop 键名 如:rpop s1

C、返回存储在key的列表中的指定范围的元素(下标从开始到某个位置)

语法:lrange 键名 start end 如:lrange s1 2 5,若从头看到尾:lrange s1 0 -1

注意:start和end都是从0开始,偏移量可以是负数。

3、其他

A、裁剪列表,改为原集合的一个子集

语法:ltrim 键名 start end,如:ltrim s1 0 1 #只要从start到end之间的数据

注意:start和end都是从0开始,偏移量可以是负数。

B、返回存储在key里的list的长度

语法:llen 键名 如:llen s1

C、返回列表中索引对应的值

语法:lindex 键名 index 如:lindex s1 1

5)set:

概述:无序集合,元素类型为String类型,元素具有唯一性,不重复.

1、设置

A、添加元素

语法:sadd 键名 值1 值2 ... 如:sadd d1 1 2 3; sadd d2 2 3 4 5 6

2、获取

A、返回key集合中所有元素(获取所有键的值)

语法:smembers 键名 如:smembers d1

B、返回集合元素个数:

语法:scard 键名 如:scard d1

3、其他

A、求多个集合的交集,语法:sinter 键名1 键名2 如:sinter d1 d2

B、求多个集合的差集,语法:sdiff 键名1 键名2 如:sdiff d1 d2

C、求多个集合的合集,语法:sunion 键名1 键名2 如:sunion d1 d2

D、判断元素是否在集合中,存在返回1,不存在返回0

语法:sismember 键名 键值元素 如:sismember d1 2 #判断2这个元素是否存在于d1中

6)zset:

概述:

A、有序集合,元素类型为String,元素具有唯一性,不能重复。

B、每个元素都会关联一个double类型的score(表示权重),通过权重的大小排序,元素的score可以相同。

1、设置:

A、添加:

语法:zadd 键名 值1的权重值 值1 值2的权重值 值2 ... 如:zadd z1 1 a 5 b 3 c

2、获取:

A、返回指定范围的元素

语法:zrange 键名 start end 如:zrange z1 0 -1,获取z1中所有元素

B、返回元素个数

语法:zcard 键名 如: zcard z1,获取z1中的元素个数

C、返回有序集合key中,score(权重)在min和max之间的元素的个数

语法:zcount 键名 start end 如:zcount z1 2 4 ,获取z1中索引2-4之间的元素个数

D、返回有序集合key中,成员member的score(权重)值

语法:zscore 键名 元素值 如:zscore z1 c,获取z1中元素c的权重值

如果对运维课程感兴趣,可以在b站上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频

相关推荐

如何检查 Linux 服务器是物理服务器还是虚拟服务器?

在企业级运维、故障排查和性能调优过程中,准确了解服务器的运行环境至关重要。无论是物理机还是虚拟机,都存在各自的优势与限制。在很多场景下,尤其是当你继承一台服务器而不清楚底层硬件细节时,如何快速辨识它是...

第四节 Windows 系统 Docker 安装全指南

一、Docker在Windows上的运行原理(一)架构限制说明Docker本质上依赖Linux内核特性(如Namespaces、Cgroups等),因此在Windows系统上无法直...

C++ std:shared_ptr自定义allocator引入内存池

当C++项目里做了大量的动态内存分配与释放,可能会导致内存碎片,使系统性能降低。当动态内存分配的开销变得不容忽视时,一种解决办法是一次从操作系统分配一块大的静态内存作为内存池进行手动管理,堆对象内存分...

Activiti 8.0.0 发布,业务流程管理与工作流系统

Activiti8.0.0现已发布。Activiti是一个业务流程管理(BPM)和工作流系统,适用于开发人员和系统管理员。其核心是超快速、稳定的BPMN2流程引擎。Activiti可以...

MyBatis动态SQL的5种高级玩法,90%的人只用过3种

MyBatis动态SQL在日常开发中频繁使用,但大多数开发者仅掌握基础标签。本文将介绍五种高阶技巧,助你解锁更灵活的SQL控制能力。一、智能修剪(Trim标签)应用场景:动态处理字段更新,替代<...

Springboot数据访问(整合Mybatis Plus)

Springboot整合MybatisPlus1、创建数据表2、引入maven依赖mybatis-plus-boot-starter主要引入这个依赖,其他相关的依赖在这里就不写了。3、项目结构目录h...

盘点金州勇士在奥克兰13年的13大球星 满满的全是...

见证了两个月前勇士与猛龙那个史诗般的系列赛后,甲骨文球馆正式成为了历史。那个大大的红色标志被一个字母一个字母地移除,在周四,一切都成为了过去式。然而这座,别名为“Roaracle”(译注:Roar怒吼...

Mybatis入门看这一篇就够了(mybatis快速入门)

什么是MyBatisMyBatis本是apache的一个开源项目iBatis,2010年这个项目由apachesoftwarefoundation迁移到了googlecode,并且改名为M...

Springboot数据访问(整合druid数据源)

Springboot整合druid数据源基本概念SpringBoot默认的数据源是:2.0之前:org.apache.tomcat.jdbc.pool.DataSource2.0及之后:com.z...

Linux 中的 &quot;/etc/profile.d&quot; 目录有什么作用 ?

什么是/etc/profile.d/目录?/etc/profile.d/目录是Linux系统不可或缺的一部分保留配置脚本。它与/etc/profile文件相关联,这是一个启动脚本,该脚...

企业数据库安全管理规范(企业数据库安全管理规范最新版)

1.目的为规范数据库系统安全使用活动,降低因使用不当而带来的安全风险,保障数据库系统及相关应用系统的安全,特制定本数据库安全管理规范。2.适用范围本规范中所定义的数据管理内容,特指存放在信息系统数据库...

Oracle 伪列!这些隐藏用法你都知道吗?

在Oracle数据库中,有几位特殊的“成员”——伪列,它们虽然不是表中真实存在的物理列,但却能在数据查询、处理过程中发挥出意想不到的强大作用。今天给大家分享Oracle伪列的使用技巧,无论...

Oracle 高效处理数据的隐藏神器:临时表妙用

各位数据库搬砖人,在Oracle的代码世界里闯荡,处理复杂业务时,是不是总被数据“搅得头大”?今天给大家安利一个超实用的隐藏神器——临时表!当你需要临时存储中间计算结果,又不想污染正式数据表...

Oracle 数据库查询:多表查询(oracle多表关联查询)

一、多表查询基础1.JOIN操作-INNERJOIN:返回两个表中满足连接条件的匹配行,不保留未匹配数据。SELECTa.emp_id,b.dept_nameFROMempl...

一文掌握怎么利用Shell+Python实现多数据源的异地备份程序

简介:在信息化时代,数据安全和业务连续性已成为企业和个人用户关注的焦点。无论是网站数据、数据库、日志文件,还是用户上传的文档、图片等,数据一旦丢失,损失难以估量。尤其是当数据分布在多个不同的目录、服务...

取消回复欢迎 发表评论: