Redis相信大多读者都不陌生,即使没用过也都听过。虽然笔者项目上是用到了redis,但当时只是简单了解,并未深入和掌握redis,所以笔者利用业余时间来充电,故记下此笔记。
Redis是一个开源的基于内存的no-sql(非关系型)数据库,使用 ANSI C语言编写,支持 strings, hashes, lists, sets, sorted sets 五种数据结构,数据存储方式为key-value 键值对的存储方式,更详细的Redis的简介请参考Redis官网。
redis的安装其实并不复杂,笔者采用docker 的方式安装redis
docker pull redis
如果没有版本要求,就使用redis docker 提供的默认 pull命令
运行容器的命令有多种,官方提供的demo也简洁明了
docker run --name some-redis -d redis
直接启动一个redis实例,默认开启对外端口6379.
docker run --name some-redis -d redis redis-server --appendonly yes
启动redis开启持久化策略,redis有两种持久化策略,这个以后再细提。没有用-v去指定持久化地址的话,默认的会持久化到 VOLUME /data文件夹下。
docker run -it --network some-network --rm redis redis-cli -h some-redis
启动redis时顺带启动了redis-cli(redis客户端),可以通过redis-cli访问redis。redis分为server端和client端,server端就是用来当做缓存中间件,database等。用户访问redis需要通过redis-cli(redis客户端访问)。访问redis的方法除上述的启动值访问,也可以在redis运行后,通过进入容器指定redis-cli命令访问。
docker exec -ti d0b86 redis-cli -h 127.0.0.1 -p 6379
其中d0b86为docker 容器的id, -h指定ip,-p指定端口,如若,-h,-p不填,则默认访问本地的6379端口。也就是说上述命令相当于
docker exec -ti d0b86 redis-cli
除此之外,也可以在安装了redis-cli下通过redis-cli命令访问,不指定ip及端口的话默认也是本地。
redis也支持自定义配置文件的启动,自定义配置文件启动有两种。
FROM redis
COPY redis.conf /usr/local/etc/redis/redis.conf
CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ]
需要对dockerfile的语法了解有一定要求
docker run -v /myredis/conf/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf
通过-v暴露出了redis的配置文件,某些场景下会存在安全问题,其他人员可以看到redis的配置信息。
详细的docker配置可查看redis的docker官网