`
zzc1684
  • 浏览: 1230226 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

centos7 安装redis和MongoDB 并且 springmvc集成redis

阅读更多

 

前一篇折腾了node.js,这一次折腾下Redis和Mongodb,这样基本就安装好nodejs的整套开发环境了。

 

Redis

在CentOS下安装Redis也比较简单,按照步骤一步一步的操作,基本不会出错。

1、切换到/usr/src 目录(如果你安装在别的目录,注意后面要一些路径也要修改),下载Redis,目前最新的是2.8.13版本

 

 

    cd /usr/src
    wget http://download.redis.io/releases/redis-2.8.13.tar.gz

 

2、解压,切换目录

 

    tar xzf redis-2.8.13.tar.gz
    cd redis-2.8.13

 

 

3、编译

 

    make
    make install

 

 

4、打开redis.conf 修改配置文件,最关键是下面几行,其他的设置参考官方文档:

    daemonize yes
    loglevel notice
    logfile /var/log/redis.log
    dir ./

 

5、设置系统的overcommit_memory,执行

vi /etc/sysctl.conf

 在文件中添加一行,保存:

vm.overcommit_memory = 1

 

执行:

sysctl vm.overcommit_memory=1

 

6、添加启动脚本,执行:

vi /etc/init.d/redis

 

写入下面的代码,保存:

    #!/bin/sh
    #
    # redis        Startup script for Redis Server
    #
    # chkconfig: - 90 10
    # description: Redis is an open source, advanced key-value store. 
    #
    # processname: redis-server
    # config: /etc/redis.conf
    # pidfile: /var/run/redis.pid
     
    REDISPORT=6379
    EXEC=/usr/local/bin/redis-server
    REDIS_CLI=/usr/local/bin/redis-cli
     
    PIDFILE=/var/run/redis.pid
    CONF="/usr/src/redis-2.8.13/redis.conf"
     
    case "$1" in
        start)
            if [ -f $PIDFILE ]
            then
                    echo "$PIDFILE exists, process is already running or crashed"
            else
                    echo "Starting Redis server..."
                    $EXEC $CONF
            fi
            if [ "$?"="0" ] 
            then 
                  echo "Redis is running..."
            fi 
            ;;
        stop)
            if [ ! -f $PIDFILE ]
            then
                    echo "$PIDFILE does not exist, process is not running"
            else
                    PID=$(cat $PIDFILE)
                    echo "Stopping ..."
                    $REDIS_CLI -p $REDISPORT SHUTDOWN
                    while [ -x ${PIDFILE} ]
                   do
                        echo "Waiting for Redis to shutdown ..."
                        sleep 1
                    done
                    echo "Redis stopped"
            fi
            ;;
       restart|force-reload)
            ${0} stop
            ${0} start
            ;;
      *)
        echo "Usage: /etc/init.d/redis {start|stop|restart|force-reload}" >&2
            exit 1
    esac

 

设置权限和开机启动:

    chmod +x /etc/init.d/redis
    chkconfig --add redis
    chkconfig redis on

 

ok,现在就安装好了。启动redis使用service redis start 或者/etc/init.d/redis start ,停止redis的命令service redis stop 或者/etc/init.d/redis stop ,在windows系统下使用redis可以参考这篇文章

参考文章:

    http://hi.baidu.com/cxc0378/item/40f4b70e7fda603af3eafcbb

    http://www.saltwebsites.com/2012/install-redis-245-service-centos-6

    http://chenjinglys.blog.163.com/blog/static/16657571620127133616965

 

 

Redis-2.8.17安装配置过程和一些错误

Redis安装过程:

正常前面3步应该没有问题,主要的问题是执行make的时候,出现了异常。

异常一:
make[2]: cc: Command not found
异常原因:没有安装gcc
解决方案:yum install gcc-c++
 
异常二:
zmalloc.h:51:31: error: jemalloc/jemalloc.h: No such file or directory
异常原因:一些编译依赖或原来编译遗留出现的问题
解决方案:make distclean。清理一下,然后再make

make成功以后,需要make test。在make test出现异常。
异常一:
couldn't execute "tclsh8.5": no such file or directory
异常原因:没有安装tcl
解决方案:yum install -y tcl

设置内存分配策略(可选,根据服务器的实际情况进行设置)
/proc/sys/vm/overcommit_memory
可选值:012
0
, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1
, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2
, 表示内核允许分配超过所有物理内存和交换空间总和的内存

值得注意的一点是,redisdump数据的时候,会fork出一个子进程,理论上child进程所占用的内存和parent是一样的,比如parent占用的内存为8G,这个时候也要同样分配8G的内存给child,如果内存无法负担,往往会造成redis服务器的down机或者IO负载过高,效率下降。所以这里比较优化的内存分配策略应该设置为 1(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)

    vim /etc/sysconfig/iptables 


    -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT 

    service iptables restart   

修改 redis/redis.conf,设置redis进程为后台守护进程:  daemonize yes

很多时候这个配置文件修改后,提到redis可能会出现问题,那么一般情况下都是redis.conf配置文件有错误造成的可以在网上找到合适的或者如下,直接复制进去,也可。

redis.conf配置:
   
daemonize yes
pidfile /usr/local/redis/var/redis.pid
port 6379
timeout 300
loglevel debug
logfile /usr/local/redis/var/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /usr/local/redis/var/
appendonly no
appendfsync always
glueoutputbuf yes
shareobjects no
shareobjectspoolsize 1024


$ redis-server  redis.conf

[root@Architect redis-2.8.17]# ps -ef | grep redis 
root      401 29222  0 18:06 pts/3    00:00:00 grep redis 
root    29258    1  0 16:23 ?        00:00:00 redis-server /etc/redis.conf 

$ redis-cli
redis> set foo jiu
OK
redis> get foo"jiu"

就这样了完成了。

 

 

MongoDB

1、下面安装MongoDB,先下载:

    cd /usr/src
    wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.6.4.tgz

 2、解压,进入目录:

    tar -zxvf mongodb-linux-x86_64-2.6.4.tgz -C /usr/src
    cd mongodb-linux-x86_64-2.6.4

 3、创建数据库和日志的目录:

    mkdir log
    mkdir db

 4、以后台运行方式启动:

./bin/mongod --dbpath=./db --logpath=./log/mongodb.log --fork --auth

 会显示如下内容:

    about to fork child process, waiting until server is ready for connections.
    forked process: 4623
    child process started successfully, parent exiting

 

5、设置开机启动:

echo "/usr/src/mongodb-linux-x86_64-2.6.4/bin/mongod --dbpath=/usr/src/mongodb-linux-x86_64-2.6.4/db --logpath=/usr/src/mongodb-linux-x86_64-2.6.4/log/mongodb.log --fork --auth" >> /etc/rc.local

 

ok,搞定,然后可以参看下端口netstat -nalupt | grep mongo

tcp   0   0 0.0.0.0:27017    0.0.0.0:*    LISTEN     4623/./bin/mongod

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    CentOS7安装redis

    **Redis在CentOS7上的安装指南** Redis是一个高性能的键值数据库,广泛应用于缓存、消息中间件等领域。在CentOS7系统上安装Redis需要遵循一系列步骤,下面将详细介绍整个过程。 ### 一、更新系统 在安装任何新...

    centos7安装redis5.0依赖GCC离线安装文件

    RHEL或centos7安装redis5.0所依赖的所有工具: cpp-4.8.2-16.el7.x86_64.rpm gcc-4.8.2-16.el7.x86_64.rpm glibc-2.17-55.el7.x86_64.rpm glibc-common-2.17-55.el7.x86_64.rpm glibc-devel-2.17-55.el7.x86_64.rpm ...

    Centos7下安装MongoDB

    Centos7下安装MongoDB是指在Centos7操作系统中安装和配置MongoDB数据库的过程。MongoDB是一个基于分布式文件存储的NoSQL数据库,由C++语言编写,运行稳定,性能高旨在为 WEB 应用提供可扩展的高性能数据存储解决方案...

    Centos7安装Redis的文档和安装包(redis单例、哨兵、集群).rar

    Centos7安装Redis的文档和安装包,包含redis单例模式、哨兵模式和集群的配置,Redis的版本是5.0.7。

    centos7 yum安装redis配置密码及简单使用

    1、安装epel-release (建议使用国内阿里云源) #下载wget,备份当前源 yum install wget -y mv /etc/yum.repo.d/*.repo /tmp #下载阿里云源和epel源 wget -O /etc/yum.repos.d/CentOS-Base.repo ...

    Linux centos7安装redis

    Linux centos7安装redis,并开启aof持久化模式

    centos源码安装redis-3.2.11

    centos源码安装redis-3.2.11

    CentOS7.5安装Redis集群.docx

    2. 安装 Redis,下载 Redis 安装包,然后解压安装包,使用 make && make install 命令编译和安装 Redis。 3. 创建节点,创建 7000 和 7001 文件夹用于存放 redis 节点的配置文件(redis.conf)。 4. 配置 redis 节点...

    centos7 安装Redis 与 Redis解决session共享

    centos7 安装Redis 与 Redis解决session共享,可根据文档进行安装和使用,本人调试过,没问题

    CentOS6.6安装Redis3.0教程

    通过上述步骤,您已经在CentOS 6.6系统上成功安装了Redis 3.0,并设置了开机自启,使得Redis服务可以在后台运行,方便管理和维护。此外,还介绍了如何让`redis-cli`命令在任意目录下都可以直接使用,大大提高了使用...

    Centos7安装Redis安装说明

    Centos7安装Redis安装说明

    centos7部署redis脚本

    centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本///centos7部署redis脚本

    centos 6.5 安装redis3.0.7

    在开始安装 Redis 之前,确保你的 CentOS 6.5 系统已更新到最新状态,并且具备必要的依赖包。以下是安装过程中需要用到的一些基本步骤: 1. **检查并安装依赖程序**: - `yum install gcc-c++` - `yum install -y...

    CentOS(Linux)离线安装MongoDB7.0详细教程(亲测可行)

    ### CentOS (Linux) 离线安装 MongoDB 7.0 详细教程 #### 一、前言 在一些特定的网络环境下,如内网或专网中,由于无法直接访问互联网资源,传统的在线安装方式不可行。对于这种情况,本文将详细介绍如何在 CentOS...

    CentOS 7 下安装 Redis 2.8.7

    在Linux系统,特别是CentOS 7中安装Redis服务器是一个常见的任务,这主要因为Redis是一个高效、灵活的内存数据存储系统,常被用作数据库、缓存和消息中间件。在这个过程中,我们将详细讨论如何从源代码编译安装Redis...

    CentOS安装Redis和phpRedis扩展记录

    在本主题中,我们将深入探讨如何在CentOS操作系统上安装Redis服务器,并且集成phpRedis扩展,以便在PHP应用中利用Redis作为持久化数据存储和会话管理。首先,让我们了解Redis的基本概念,然后逐步讲解安装过程。 ...

    百度云服务器系列:centos7安装redis记录

    4. **编译和安装Redis**: 进入解压后的目录,然后执行`make`命令进行编译,指定`MALLOC=libc`以使用C语言的标准库: ``` cd redis- make MALLOC=libc ``` 编译完成后,将Redis二进制文件安装到`/usr/local/...

    CentOS(Linux)离线安装Redis详细教程(亲测可行)

    ### CentOS (Linux) 离线安装 Redis 详细教程 #### 一、引言 在没有互联网连接的情况下,在 CentOS 系统上安装 Redis 可能会遇到诸多挑战,如依赖包缺失、软件包管理工具配置不当等。本教程旨在帮助读者解决这些...

    cent OS7无网络安装redis

    在CentOS 7环境下,没有网络的情况下安装Redis是一项挑战,因为通常我们会依赖在线包管理器如`yum`来获取和安装软件。然而,通过手动下载所需的依赖包并使用本地安装方式,我们仍然可以完成Redis的安装。以下是详细...

Global site tag (gtag.js) - Google Analytics