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
可选值:0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存

值得注意的一点是,redis在dump数据的时候,会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

相关推荐