day24——NoSQL简介、redis服务搭建、redis连接池、redis管道

一、Redis 安装

yum install -y epel-release
yum install -y gcc jemalloc-devel wget
cd /usr/local/src
wget https://codeload.github.com/antirez/redis/tar.gz/2.8.21 -O redis-2.8.21.tar.gz
tar xf redis-2.8.21.tar.gz
cd redis-2.8.21
make
make PREFIX=/usr/local/redis install
mkdir /usr/local/redis/etc
wget http://www.apelearn.com/study_v2/.redis_conf -O /usr/local/redis/etc/redis.conf 2>/dev/null # 下载配置文件
wget http://www.apelearn.com/study_v2/.redis_init -O /etc/init.d/redis 2>/dev/null # 下载启动脚本
useradd -s /sbin/nologin redis
mkdir /usr/local/redis/var
chmod 777 /usr/local/redis/var
chmod 755 /etc/init.d/redis
chkconfig --add redis
chkconfig redis on
/etc/init.d/redis start

[[email protected] ~]# /usr/local/redis/bin/redis-cli    # 连接Redis
127.0.0.1:6379>

二、Redis 基本操作
安装 redis 模块:
cd /usr/local/src
wget --no-check-certificate https://pypi.python.org/packages/source/r/redis/redis-2.8.0.tar.gz
tar xf redis-2.8.0.tar.gz
mv redis-2.8.0 python-redis-2.8.0
cd python-redis-2.8.0/
python setup.py install
Python 连接并操作 redis :
In [1]: import redis

In [2]: r = redis.Redis(host=‘127.0.0.1‘, port=6379)    # redis.Redis() 用于连接 redis

In [3]: r.set(‘name‘, ‘Tom‘)                            # set() 用于设置key值
Out[3]: True

In [4]: print r.get(‘name‘)                             # get() 用于获取key值
Tom

其他操作参考:

[[email protected] ~]# /usr/local/redis/bin/redis-cli     // 连接Redis
127.0.0.1:6379> keys *             // keys 用于查看所有key,也可以模糊匹配,如 keys my*
127.0.0.1:6379> exists name        // exists 用于判断是否有某个key,有返回1,没有返回0
127.0.0.1:6379> del name           // del 用于删除指定的key,成功返回1,失败返回0
127.0.0.1:6379> expire name 100    // expire 用于设置指定的key多长时间后过期,单位为秒
127.0.0.1:6379> persist name       // persist 用于取消指定key的过期时间
127.0.0.1:6379> ttl name           // ttl 用于查看指定的key还有多长时间过期,返回-2表示没有该key,返回-1表示没有设置过期时间,其他表示还有多长时间过期
127.0.0.1:6379> select 0           // select 用于选择哪个库
127.0.0.1:6379> move name 2        // move 用于把指定的key移到哪个库下
127.0.0.1:6379> randomkey          // randomkey 用于随机返回一个key
127.0.0.1:6379> rename k1 k2       // rename 用于重命名key
127.0.0.1:6379> type name          // type 用于查看指定key的类型
127.0.0.1:6379> dbsize             // dbsize 用于返回当前数据库中key的数目
127.0.0.1:6379> info               // info 用于返回redis数据库的状态信息
127.0.0.1:6379> flushdb            // flushdb 用于清空当前数据库中的所有key
127.0.0.1:6379> flushall           // flushall 用于清空所有数据库中的所有key

三、Redis 连接池

1、什么是连接池

当应用程序对数据库进行增删改查等操作时,需要先连接数据库,但是如果应用程序需要频繁地连接数据库进行增删查改操作,那就需要不断地创建连接,这是很耗时且耗资源的操作,也容易对数据库造成安全隐患。所以,当应用程序启动时先建立足够的数据库连接,并将这些连接组成一个连接池,当应用程序需要连接数据库进行增删查改操作时,再使用连接池中的连接,这样可以保证较快的数据库读写速度,还更加安全可靠。

数据库连接池的运行机制如下:

(1) 程序初始化时创建连接池
(2) 使用时向连接池申请可用连接
(3) 使用完毕,将连接返还给连接池
(4) 程序退出时,断开所有连接,并释放资源

2、Python 使用 redis 连接池

In [5]: import redis

In [6]: pool = redis.ConnectionPool(host=‘127.0.0.1‘, port=6379)    # redis.ConnectionPool() 用于创建一个连接池

In [7]: r = redis.Redis(connection_pool=pool)    # 通过 redis.Redis() 连接到连接池

In [8]: r.set(‘name‘, ‘Tom‘)    # 执行 redis 操作
Out[8]: True

In [9]: r.get(‘name‘)
Out[9]: ‘Tom‘
				
时间: 2024-08-05 19:22:31

day24——NoSQL简介、redis服务搭建、redis连接池、redis管道的相关文章

python 基础 10.0 nosql 简介--redis 连接池及管道

一. NOSQL 数据库简介 NoSQL 泛指非关系型的数据库.非关系型数据库与关系型数据库的差别 非关系型数据库的优势: 1.性能NOSQL 是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL 层的解析,所以性能非常高. 2.可扩展性同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展. 关系型数据库的优势: 1. 复杂查询可以用SQL语句方便的在一个表以及多个表之间做非常复杂的数据查询. 2.事务支持使得对于安全性能很高的数据访问要求得以实现.对于这两类数据

Tomcat集群+Nginx+Redis服务搭建

由于公司新业务突然上来了,单个Tomcat实例已经不能满足业务发展的需要了,只能通过搭建集群来解决问题了.所以就出现了下面的内容: 1.Redis保存Session信息 为了保存Session信息在集群中可用,所以session信息不能保存Tomcat中,因为如果是这样的话要想实现Session信息的共享就必须通过Session复制的方式来同步Tomcat之间的Session信息,这样比较费力费力而且性能消耗比较大,所以选择通过redis来实现Session信息的保存和共享. 1.1Redis的

Java与redis交互、Jedis连接池JedisPool

Java与redis交互比较常用的是Jedis. 先导入jar包: commons-pool2-2.3.jar jedis-2.7.0.jar 基本使用: public class RedisTest1 { public static void main(String[] args) { Jedis jedis = new Jedis("localhost",6379); jedis.set("username","chichung"); jed

NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器. 在目前广泛的Web应用中,都会出现一种场景:在某一个时刻,网站会迎来一个用户请求的高峰期(比如:淘宝的双十一购物狂欢节,12306的春运抢票节等),一般的设计中,用户的请求都会被直接写入数据库或文件中,在高并发的情形下会对数据库服务器或文件服务器造成巨大的压力,同时呢,也使响应延迟加剧.这也说明

【转】NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器. 在目前广泛的Web应用中,都会出现一种场景:在某一个时刻,网站会迎来一个用户请求的高峰期(比如:淘宝的双十一购物狂欢节,12306的春运抢票节等),一般的设计中,用户的请求都会被直接写入数据库或文件中,在高并发的情形下会对数据库服务器或文件服务器造成巨大的压力,同时呢,也使响应延迟加剧.这也说明

高可用Redis服务架构分析与搭建

基于内存的Redis应该是目前各种web开发业务中最为常用的key-value数据库了,我们经常在业务中用其存储用户登陆态(Session存储),加速一些热数据的查询(相比较mysql而言,速度有数量级的提升),做简单的消息队列(LPUSH和BRPOP).订阅发布(PUB/SUB)系统等等.规模比较大的互联网公司,一般都会有专门的团队,将Redis存储以基础服务的形式提供给各个业务调用. 不过任何一个基础服务的提供方,都会被调用方问起的一个问题是:你的服务是否具有高可用性?最好不要因为你的服务经

高可用Redis服务架构分析与搭建!

基于内存的Redis应该是目前各种Web开发业务中最为常用的Key-Value数据库了,我们经常在业务中用其存储用户登陆态(Session存储),加速一些热数据的查询(相比较MySQL而言,速度有数量级的提升),做简单的消息队列(LPUSH和BRPOP).订阅发布(PUB/SUB)系统等等.规模比较大的互联网公司,一般都会有专门的团队,将Redis存储以基础服务的形式提供给各个业务调用. 不过任何一个基础服务的提供方,都会被调用方问起的一个问题是:你的服务是否具有高可用性?最好不要因为你的服务经

分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装

redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssdb,mongodb等.既可以把redis理解为理解为缓存技术,因为它的数据都是缓存在内从中的:也可以理解为数据库,因为redis可以周期性的将数据写入磁盘或者把操作追加到记录文件中.而我个人更倾向理解为缓存技术,因为当今互联网应用业务复杂.高并发.大数据的特性,正是各种缓存技术引入最终目的. 关于r

一.redis 环境搭建

1.简介       redis是一个开源的key-value数据库.它又经常被认为是一个数据结构服务器.因为它的value不仅包括基本的string类型还有 list,set ,sorted set和hash类型.当然这些类型的元素也都是string类型.也就是说list,set这些集合类型也只能包含string 类型.你可以在这些类型上做很多原子性的操作.比如对一个字符value追加字符串(APPEND命令).加加或者减减一个数字字符串(INCR命令,当 然是按整数处理的).可以对list类