redis使用例子和net模块

关闭redis的持久化操作,只需要在redis启动的配置文件里,将save项全注释掉

var redis = require('redis');
var client = redis.createClient(6379, '127.0.0.1');

client.on('error', function (err) {
	console.log('Error' + err);
});

client.set('color', 'red', redis.print);
client.get('color', function(err, value) {
	if (err) throw err;
	console.log('Got: ' + value);
});

/* 2.用哈希表存放数据 */
// 用哈希表存储和获取数据
client.hmset('camping', {
	'shelter': '2-person tent',
	'cooking': 'campstove'
}, redis.print);

// 获取元素cooking的值
client.hget('camping', 'cooking', function(err, value) {
	if (err) throw err;
	console.log('Will be cooking with: ' + value);
});

// 获取哈希表的键
client.hkeys('camping', function(err, keys) {
	if (err) throw err;
	keys.forEach(function(key, i) {
		console.log(' ' + key);
	});
});


/* 3.用链表存储和获取数据 */
// lpush向键表中添加值
client.lpush('tasks', 'Paint the bikeshed red.', redis.print);
client.lpush('tasks', 'Paint the bikeshed green.', redis.print);
// 获取参数start和end范围内的链表元素
client.lrange('tasks', 0, -1, function(err, items) {
	if (err) throw err;
	items.forEach(function(item, i) {
		console.log(' ' + item);
	});
});

/* 4.用集合存储和获取数据 */
client.sadd('ip_addresses', '192.168.1.1', redis.print);
client.sadd('ip_addresses', '192.168.1.1', redis.print);
client.sadd('ip_addresses', '192.168.1.2', redis.print);
client.smembers('ip_addresses', function(err, members) {
	if (err) throw err;
	console.log(members);
});

/* 5.用信道传递数据 */
// Redis客户端可以向任一给定的信道预订或发布消息.预订一个信道意味着你会收到所有发送给它的消息,发布给信道的消息会发送给所有预订了那个信道的客户端
// 用Redis的发布/预订功能实现简单聊天服务器
var net = require('net');
var server = net.createServer(function(socket) {
	var subscriber;
	var publisher;
	socket.on('connect', function() {
		// 为用户创建预订客户端
		subscriber = redis.createClient();
		// 预订信道
		subscriber.subscribe('main_chat_room');
		// 信道收到消息后把它发给用户
		subscriber.on('message', function(channel, message) {
			socket.write('Channel ' + channel + ': ' + message);
		});
		// 为用户创建发布客户端
		publisher = redis.createClient();
	});
	socket.on('data', function(data) {
		// 用户输入消息后发布它
		publisher.publish('main_chat_room', data);
	});
	socket.on('end', function() {
		subscriber.unsubscribe('main_chat_room');
		subscriber.end();
		publisher.end();
	});
});
server.listen(3000);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用Spring Data Redis例子: 1. 添加依赖 在Maven项目中,需要添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 配置Redis连接信息 在Spring Boot应用程序中,可以在application.properties或application.yml文件中配置Redis连接信息,例如: ``` spring.redis.host=localhost spring.redis.port=6379 spring.redis.password=123456 ``` 3. 编写Redis操作代码 在Spring Boot应用程序中,可以使用RedisTemplate或Spring Data Redis提供的Repository来操作Redis。以下是使用RedisTemplate操作Redis例子: ``` @Service public class RedisService { @Autowired private RedisTemplate<String, String> redisTemplate; public void set(String key, String value) { redisTemplate.opsForValue().set(key, value); } public String get(String key) { return redisTemplate.opsForValue().get(key); } } ``` 在上面的代码中,我们通过注入RedisTemplate对象来操作Redis。set方法用于将key-value数据存储到Redis中,get方法用于从Redis中获取key对应的value值。 4. 测试 在Spring Boot应用程序中,可以编写单元测试代码来测试Redis操作是否正常。以下是一个简单的测试代码示例: ``` @RunWith(SpringRunner.class) @SpringBootTest public class RedisServiceTest { @Autowired private RedisService redisService; @Test public void testSetAndGet() { String key = "key1"; String value = "value1"; redisService.set(key, value); String result = redisService.get(key); Assert.assertEquals(value, result); } } ``` 在上面的代码中,我们通过注入RedisService对象来测试Redis操作是否正常。testSetAndGet方法用于测试set和get方法是否能够正常工作。 总之,Spring Data Redis是一个非常方便的模块,可以帮助开发人员快速集成Redis到Spring Boot应用程序中,并提供了一组简单易用的API,使得开发人员可以方便地进行Redis操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值