2、 redis简述及安装

关系型数据库(SQL):

Mysql,oracle

特点:数据和数据之间,表和字段之间,表和表之间是存在关系的

例如:部门表 001部门,   员工表 001

用户表,用户名、密码

分类表 和 商品表, 一对多关系。

优点:①数据之间有关系,进行数据的增删改查时非常方便的。

    ②关系型数据库 有事务操作。 保证数据的完整性

缺点:1、因为数据和数据之间有关系的,关系是由底层大量算法保证

    大量算法会拉低系统运行速度

    大量算法会消耗系统资源

   2、海量数据的增删改查时会显得无能为力。

    很可能宕(dang)机

3、海量数据环境下对数据表进行维护/扩展,也会变得无能为力

    update product set cname = ‘手机数码’;//修改所有数据

    把商品表的cname字段,由varchar(64),  char(100)

适合处理一般量级数据,安全。

非关系型数据库(NOSQL:不仅仅是sql):

为了处理海量数据,需要将关系型数据库的关系 去掉。

非关系型数据库设计之初 是为了替代关系型数据库的

Redis

优点:1、海量数据的增删改查,非常轻松应对

      2、海量数据的维护非常轻松。

缺点:1、数据和数据之间没有关系,所以不能一目了然

   2、非关系型数据库,没有关系,没有强大的事务保证数据的完整和安全

适合处理海量数据,效率高。不一定安全

奥运健儿奖牌总数 每秒千万次查询

关系型数据库+非关系型数据库 ====》项目

重要数据      海量操作数据,不重要

2、1 Redis使用环境

1、可以作为关系型数据库的缓存存在

2、可以做任务队列

3、大量数据运算

4、排行榜

Redis非常擅长做大量数据的排行榜

2、2 redis安装

redis是C语言开发,安装redis需要先将官网下载的源码进行编译,编译依赖gcc环境。如果没有gcc环境,需要安装gcc:(环境已经导入完成)

yum install gcc-c++

如果提示是否下载,输入y。

如果提示是否安装,输入y

l 步骤1:将Windows下下载的压缩文件上传到Linux下。通过secureCRT进行上传,步骤如下:

lalt + p

lput F:/redis-3.0.0.tar.gz

l

l 步骤2:解压文件

ltar -zxvf redis-3.0.0.tar.gz

l 步骤3:编译redis (编译,将.c文件编译为.o文件)

l进入解压文件夹,cd redis-3.0.0

l执行make,将里边所有的c代码运行一遍

1)如果没有安装gcc,编译将出现错误提示。(如果安装失败,必须删除文件夹,重写解压)

2)安装成功

l 步骤4:安装

make PREFIX=/usr/local/redis install

lPREFIX必须大写

安装完后,在/usr/local/redis/bin下有几个可执行文件

redis-benchmark----性能测试工具

redis-check-aof----AOF文件修复工具

redis-check-dump----RDB文件检查工具(快照持久化文件)

redis-cli----命令行客户端

redis-server----redis服务器启动命令

l 步骤5:copy文件

redis启动需要一个配置文件,可以修改端口号等信息。

回到根目录,进到redis-3.0.0,复制该目录下的redis.conf到/usr/local/redis

cp redis.conf /usr/local/redis

如果没有配置文件redis也可以启动不过将启用默认配置这样不方便我们修改端口号等信息

2、3前端启动:(了解)-无法部署集群

先进入redis程序目录中,运行一下命令启动redis服务器。./代表当前目录

./bin/redis-server

[root@yejing redis]# ll

总用量 48

drwxr-xr-x. 2 root root  4096 1月  15 07:28 bin

-rw-r--r--. 1 root root 41403 1月  15 07:35 redis.conf

[root@yejing redis]# pwd

/usr/local/redis

[root@yejing redis]# ./bin/redis-server

1631:C 15 Jan 17:57:09.181 # Warning: no config file specified, using the default config. In order to specify a config file use ./bin/redis-server /path/to/redis.conf

1631:M 15 Jan 17:57:09.186 * Increased maximum number of open files to 10032 (it was originally set to 1024).

1631:M 15 Jan 17:57:09.199 # Warning: 32 bit instance detected but no memory limit set. Setting 3 GB maxmemory limit with 'noeviction' policy now.

                _._                                                  

           _.-``__ ''-._                                             

      _.-``    `.  `_.  ''-._           Redis 3.0.0 (00000000/0) 32 bit

  .-`` .-```.  ```\/    _.,_ ''-._                                   

 (    '      ,       .-`  | `,    )     Running in standalone mode

 |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379

 |    `-._   `._    /     _.-'    |     PID: 1631

  `-._    `-._  `-./  _.-'    _.-'                                   

 |`-._`-._    `-.__.-'    _.-'_.-'|                                  

 |    `-._`-._        _.-'_.-'    |           http://redis.io        

  `-._    `-._`-.__.-'_.-'    _.-'                                   

 |`-._`-._    `-.__.-'    _.-'_.-'|                                  

 |    `-._`-._        _.-'_.-'    |                                  

  `-._    `-._`-.__.-'_.-'    _.-'                                   

      `-._    `-.__.-'    _.-'                                       

          `-._        _.-'                                           

              `-.__.-'                                               

1631:M 15 Jan 17:57:09.204 # Server started, Redis version 3.0.0

1631:M 15 Jan 17:57:09.206 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.

1631:M 15 Jan 17:57:09.207 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.

1631:M 15 Jan 17:57:09.207 * The server is now ready to accept connections on port 6379

再打开一个窗口运行客户端:

进到redis程序目录,运行以下命令启动客户端

./bin/redis-cli

[root@yejing ~]# cd /usr/local/redis

[root@yejing redis]# ./bin/redis-cli

127.0.0.1:6379> set username zhangsan

OK

127.0.0.1:6379> get username

"zhangsan"

127.0.0.1:6379>

启动redis,客户端连接: 连接6379端口

redis-cli -h ip地址 -p 端口

./bin/redis-cli -p 6379

运行客户端(默认连接本机6379端口):./bin/redis-cli

2、4Redis启动-后端模式

l 修改redis.conf配置文件, daemonize yes 以后端模式启动。

vim /usr/local/redis/redis.conf

l 启动时,指定配置文件

cd /usr/local/redis/

./bin/redis-server ./redis.conf

l Redis默认端口6379,通过当前服务进行查看

ps -ef | grep -i redis

2、5 redis的关闭

① 查询到PID,kill -9 pid  【断电,非正常关闭,一般不用,否则造成数据丢失】

②正常关闭  【正常关闭,数据保存】

./bin/redis-cli shutdown

Linux+Redis实战教程_day02_2、redis简述及安装与启动的更多相关文章

  1. go语言实战教程:Redis实战项目应用

    项目Redis配置 在实战项目中使用Redis功能,首先需要进行Redis配置.本实战项目中,关与Redis的配置项包含:连接类型.地址.端口.公共前缀.以上配置项被定义包含在Iris框架的redis ...

  2. Redis实战之征服 Redis + Jedis + Spring (一)

    Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)接着需要快速的调研下基于Spring框架下的Redis操作. 相关链接: Redis实战 Re ...

  3. Redis实战之征服 Redis + Jedis + Spring (二)

    不得不说,用哈希操作来存对象,有点自讨苦吃! 不过,既然吃了苦,也做个记录,也许以后API升级后,能好用些呢?! 或许,是我的理解不对,没有真正的理解哈希表. 相关链接: Redis实战 Redis实 ...

  4. Redis实战之征服 Redis + Jedis + Spring (三)

    一开始以为Spring下操作哈希表,列表,真就是那么土.恍惚间发现“stringRedisTemplate.opsForList()”的强大,抓紧时间恶补下. 通过spring-data-redis完 ...

  5. Redis实战 | 5种Redis数据类型详解

    我们知道Redis是目前非常主流的KV数据库,它因高性能的读写能力而著称,其实还有另外一个优势,就是Redis提供了更加丰富的数据类型,这使得Redis有着更加广泛的使用场景.那Redis提供给用户的 ...

  6. Redis 实战 —— 13. 扩展 Redis

    简介 当数据量增大或者读写请求增多后,一台 Redis 服务器可能没办法再存储所有数据或者处理所有读写请求,那么就需要对 Redis 进行扩展,保证 Redis 在能存储所有数据对情况下,同时能正常处 ...

  7. Linux+Redis实战教程_day01_Linux介绍与安装

    1.Linux介绍(了解) 1.1.Linux和Windows的区别 Linux是一款操作系统.正规开发 服务器项目部署都是放在Linux操作系统上. Windows一款操作系统,民用操作系统.娱乐. ...

  8. Linux+Redis实战教程_day02_消息订阅与发布_多数据库_redis批量操作-事务_redis持久化

    5.扩展知识-消息订阅与发布(了解) 订阅新闻,新闻发布 subscribe channel:订阅频道,例:subscribe mychat,订阅mychat这个频道 psubscribe chann ...

  9. Linux+Redis实战教程_day03_4、通用redis命令【重点】

    4.通用redis命令[重点] Redis五种数据类型,String,hash,list,set,有序set l keys pattern:获取所有与pattern匹配的key,返回所有与该key匹配 ...

随机推荐

  1. Thymeleaf select 数据回显 选中

    <select style='width: 148.15px' name="dlrlx" th:field="*{Ygdly.dlrlx}"> &l ...

  2. node学习笔记1——配置node环境变量及执行node文件

    最近在学习node,今天说一下node的变量环境配置.虽然网上有说,最新版的已经不需要配置这个东东了,但是我的电脑还是得配置.闲话少扯,进入正题: 1.安装node,这步就略过了.就是下载 node, ...

  3. 优雅的运用 Kotlin 的 null safety 特性,而不要简单的直接用 !!双感叹号

    对于 Null 的检查是 Kotlin 的特点之一.强制你在编码过程中考虑变量是否可为 null,因此可以避免很多在 Java 中隐藏的 NullPointerException. 但是,当你用插件直 ...

  4. 关于css定位

    关于定位要弄清一个概念,那就是"文档流" 什到是文档流 说得简单一点 就是 自上而下 从左到右 生成顺序 关于html元素又分为两种 块状元素 内联元素 块状元素:单独占一行 内联 ...

  5. jquery 实现下拉菜单

    Jquery 是一个轻量的框架,个人认为非常好用,今天就写一个非常简单的例子,实现下拉菜单功能: 首先肯定要在页面引用jquery.js  版本不限 : 接下来把=================== ...

  6. Python 引用

    python引用python中的数值类型变量也是引用,例如: a = 100b=a那么a和b指向同一块内存但是当修改a或者b的值得时候,Python会新分配一块内存来存储新的值 python中不可变类 ...

  7. 关于Unity中Mesh网格的详解

    3D模型 通过3D建模软件所建出来的点和面,如以三角形为主的点和面,比如人的脑袋一个球,就是由各种各样的三角形组成的点和面. 点和面以及纹理坐标都是通过3D建模软件建模出来的. Unity会帮我们把模 ...

  8. 【Centos】【Python3】yum install 报错

    运行yum install 安装时报错 File "/usr/libexec/urlgrabber-ext-down", line 28 except OSError, e: Sy ...

  9. 第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询

    第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询 1.elasticsearch(搜索引擎)的查询 elasticsearch是功能 ...

  10. gcc -lpthread

    转自:http://www.cnblogs.com/suntp/p/6473751.html 如果用gcc编译使用了POSIX thread的程序时,通常需要加额外的选项,以便使用thread-saf ...