import java.util.Queue
import java.util.Set
import java.util.concurrent.ConcurrentMap
import org.redisson.Config
import org.redisson.Redisson
public class RedisExample {
/**
* @param args
*/
public static void main(String[] args) {
// 1.初始化
Config config = new Config()
config.setConnectionPoolSize(10)
config.addAddress("127.0.0.1:6379")
Redisson redisson = Redisson.create(config)
System.out.println("reids连接成功...")
// 2.测试concurrentMap,put方法的时候就会同步到redis中
ConcurrentMap<String, Object> map = redisson.getMap("FirstMap")
map.put("wuguowei", "男")
map.put("zhangsan", "nan")
map.put("lisi", "女")
ConcurrentMap resultMap = redisson.getMap("FirstMap")
System.out.println("resultMap==" + resultMap.keySet())
// 2.测试Set集合
Set mySet = redisson.getSet("MySet")
mySet.add("wuguowei")
mySet.add("lisi")
Set resultSet = redisson.getSet("MySet")
System.out.println("resultSet===" + resultSet.size())
//3.测试Queue队列
Queue myQueue = redisson.getQueue("FirstQueue")
myQueue.add("wuguowei")
myQueue.add("lili")
myQueue.add("zhangsan")
myQueue.peek()
myQueue.poll()
Queue resultQueue=redisson.getQueue("FirstQueue")
System.out.println("resultQueue==="+resultQueue)
// 关闭连接
redisson.shutdown()
}
}
创建一个redis docker容器首先,我们先为redis创建一个Dockerfile
FROMubuntu:12.10
RUN apt-get update
RUN apt-get -y install redis-server
EXPOSE 6379
ENTRYPOINT ["/usr/bin/redis-server"]
现在你需要通过Dockerfile创建一个镜像,将替换成你自己的名字。
sudo docker build -t /redis .
运行服务
使用我们刚才创建的redis镜像
使用 -d 运行这个服务分离模式,让容器在后台运行。
重要的是我们没有开放容器端口,相反,我们将使用一个容器来连接redis容器数据库
sudo docker run -name redis -d /redis
创建你的web应用容器
现在我们可以创建我们的应用程序容器,我们使用-link参数来创建一个连接redis容器,我们使用别名db,这将会在redis容器和redis实例容器中创建一个安全的通信隧道
sudo docker run -link redis:db -i -t ubuntu:12.10 /bin/bash
进入我们刚才创建的容器,我们需要安装redis的redis-cli的二进制包来测试连接
apt-get update
apt-get -y install redis-server
service redis-server stop
现在我们可以测试连接,首先我么要先查看下web应用程序容器的环境变量,我们可以用我们的ip和端口来连接redis容器
env
. . .
DB_NAME=/violet_wolf/db
DB_PORT_6379_TCP_PORT=6379
DB_PORT=tcp://172.17.0.33:6379
DB_PORT_6379_TCP=tcp://172.17.0.33:6379
DB_PORT_6379_TCP_ADDR=172.17.0.33
DB_PORT_6379_TCP_PROTO=tcp
我们可以看到我们有一个DB为前缀的环境变量列表,DB来自指定别名连接我们的现在的容器,让我们使用DB_PORT_6379_TCP_ADDR变量连接到Redis容器。
redis-cli -h $DB_PORT_6379_TCP_ADDR
redis 172.17.0.33:6379>
redis 172.17.0.33:6379>set docker awesome
OK
redis 172.17.0.33:6379>get docker
"awesome"
redis 172.17.0.33:6379>exit
我们可以很容易的使用这个或者其他环境变量在我们的web应用程序容器上连接到redis容器
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)