使用with打开文件的方式,是调用了上下文管理的功能

  1. #打开文件的两种方法:
  2.  
  3. f = open('a.txt','r')
  4.  
  5. with open('a.txt','r') as f
  6.  
  7. 实现使用with关闭socket
  8. import contextlib
  9. import socket
  10.  
  11. @contextlib.contextmanage
  12. def Sock(ip,port):
  13. socket = socket.socket()
  14. socket.bind((ip,port))
  15. socket.listen(5)
  16. try:
  17. yield socket
  18. finally:
  19. socket.close()
  20.  
  21. #执行Sock函数传入参数,执行到yield socket返回值给s,执行with语句体,执行finally后面的语句
  22. with Sock('127.0.0.1',8000) as s:
  23. print(s)

redis的发布订阅

  1. class RedisHelper:
  2.  
  3. def __init__(self):
  4. #调用类时自动连接redis
  5. self.__conn = redis.Redis(host='192.168.1.100')
  6.  
  7. def public(self, msg, chan):
  8. self.__conn.publish(chan, msg)
  9. return True
  10.  
  11. def subscribe(self, chan):
  12. pub = self.__conn.pubsub()
  13. pub.subscribe(chan)
  14. pub.parse_response()
  15. return pub
  16.  
  17. #订阅者
  18. import s3
  19.  
  20. obj = s3.RedisHelper()
  21. data = obj.subscribe('fm111.7')
  22. print(data.parse_response())
  23.  
  24. #发布者
  25. import s3
  26.  
  27. obj = s3.RedisHelper()
  28. obj.public('alex db', 'fm111.7')

RabbitMQ

  1. #消费者
  2. import pika
  3.  
  4. connection = pika.BlockingConnection(pika.ConnectionParameters(host='127.0.0.1'))
  5. channel = connection.channel()#创建对象
  6.  
  7. channel.queue_declare(queue = 'wocao')
  8. def callback(ch,method,properties,body):
  9. print("[x] Received %r"%body)
  10.  
  11. channel.basic_consume(callback,queue = 'wocao',no_ack = True)
  12. print('[*] Waiting for messages. To exit press CTRL+C')
  13. channel.start_consuming()
  14.  
  15. #生产者
  16. import pika
  17. connection = pika.BlockingConnection(pika.ConnectionParameters(host='127.0.0.1'))
  18. channel = connection.channel()
  19. channel.queue_declare(queue = 'wocao')#指定一个队列,不存在此队列则创建
  20. channel.basic_publish(exchange = '',routing_key = 'wocao',body = 'hello world!')
  21. print("[x] Sent 'hello world!")
  22. connection.close()

exchange type类型

  1. #生产者
  2. import pika
  3. connection = pika.BlockingConnection(pika.ConnectionParameters(
  4. host='192.168.11.87'))
  5. channel = connection.channel()
  6. #fanout类型,对绑定该exchange的队列实行广播
  7. channel.exchange_declare(exchange='logs_fanout',
  8. type='fanout')
  9.  
  10. # 随机创建队列
  11. result = channel.queue_declare(exclusive=True)
  12. queue_name = result.method.queue
  13. # 绑定exchange
  14. channel.queue_bind(exchange='logs_fanout',
  15. queue=queue_name)
  16.  
  17. print(' [*] Waiting for logs. To exit press CTRL+C')
  18.  
  19. def callback(ch, method, properties, body):
  20. print(" [x] %r" % body)
  21.  
  22. channel.basic_consume(callback,
  23. queue=queue_name,
  24. no_ack=True)
  25.  
  26. channel.start_consuming()
  27. #消费者
  28. import pika
  29.  
  30. #发送方
  31. connection = pika.BlockingConnection(pika.ConnectionParameters(
  32. host='192.168.11.87'))
  33. channel = connection.channel()
  34.  
  35. channel.exchange_declare(exchange='logs_fanout',
  36. type='fanout')
  37.  
  38. message = "what's the fuck"
  39. #设置exchange的名
  40. channel.basic_publish(exchange='logs_fanout',
  41. routing_key='',
  42. body=message)
  43. print(" [x] Sent %r" % message)
  44. connection.close()
  1. #根据关键字发送指定队列
  2. #生产者(发布者)
  3. import pika
  4. connection = pika.BlockingConnection(pika.ConnectionParameters(
  5. host = '127.0.0.1'))
  6. channel = connection.channel()
  7.  
  8. channel.exchange_declare(exchange='direct_logs_1',
  9. type='direct') # 关键字发送到队列
  10. #对error关键字队列发送指令
  11. severity = 'error'
  12. message = ''
  13. channel.basic_publish(exchange = 'direct_logs_1',
  14. routing_key = severity,
  15. body = message)
  16. print('[x] Sent %r:%r'%(severity,message))
  17. connection.close()
  18. #消费者(订阅者)
  19. import pika
  20. #消费者
  21. connection = pika.BlockingConnection(pika.ConnectionParameters(
  22. host = '127.0.0.1'))
  23. channel = connection.channel()
  24. channel.exchange_declare(exchange='direct_logs_1',
  25. type = 'direct')#关键字发送到队列
  26.  
  27. result = channel.queue_declare(exclusive=True)
  28. queue_name = result.method.queue
  29. serverities = ['error','info','warning']
  30. for severity in serverities:
  31. channel.queue_bind(exchange='direct_logs_1',
  32. queue = queue_name,
  33. routing_key = severity)
  34. def callback(ch,method,properties,body):
  35. print('[x] %r:%r'%(method.routing_key,body))
  36.  
  37. channel.basic_consume(callback,
  38. queue = queue_name,
  39. no_ack = True)
  40. channel.start_consuming()
  1. #实现消息不丢失接收方
  2. import pika
  3. connection = pika.BlockingConnection(pika.ConnectionParameters(host = '10.211.55.4'))
  4. channel = connection.channel()
  5. channel.queue_declare(queue = 'hello')
  6.  
  7. def callback(ch,method,properties,body):
  8. print('redeived %s'%body)
  9. import time
  10. time.sleep(10)
  11. print('ok')
  12. ch.basic_ack(delivery_tag= method.delivery_tag)
  13. #no_ack = False接收方接受完请求后发送给对方一个接受成功的信号,如果没收到mq会重新将任务放到队列
  14. channel.basic_consume(callback,queue = 'hello',no_ack=False)
  15. print(' Waiting for messages.To exit press CTRL+C')
  16. channel.start_consuming()
  1. #发送方
  2. #实现消息不丢失
  3. import pika
  4. connection = pika.BlockingConnection(pika.ConnectionParameters(host = '10.211.55.4'))
  5. channel = connection.channel()
  6. channel.queue_declare(queue = 'hello',durable = True)
  7. channel.basic_publish(exchange = '',routing_key = 'hello world',
  8. properties = pika.BasicProperties(
  9. delivery_mode=2,
  10. ))#发送方不丢失,发送方保持持久化
  11. print(' Waiting for messages.To exit press CTRL+C')
  12. channel.start_consuming()
  1. #接收方
  2. import pika
  3.  
  4. connection = pika.BlockingConnection(pika.ConnectionParameters(host='192.168.11.100'))
  5. channel = connection.channel()
  6.  
  7. channel.queue_declare(queue='hello', durable=True)
  8. def callback(ch, method, properties, body):
  9. print(" [x] Received %r" % body)
  10. import time
  11. time.sleep(10)
  12. print 'ok'
  13. ch.basic_ack(delivery_tag = method.delivery_tag)
  14. channel.basic_consume(callback,
  15. queue='hello',
  16. no_ack=False)
  17. channel.start_consuming()

RabbitMQ队列中默认情况下,接收方从队列中获取消息是顺序的,例如:接收方1只从队列中获取奇数的任务,接收方2只从队列中获取偶数任务

  1. import pika
  2.  
  3. connection = pika.BlockingConnection(pika.ConnectionParameters(host='192.168.11.100'))
  4. channel = connection.channel()
  5. channel.queue_declare(queue='hello')
  6. def callback(ch, method, properties, body):
  7. print(" [x] Received %r" % body)
  8. import time
  9. time.sleep(10)
  10. print 'ok'
  11. ch.basic_ack(delivery_tag = method.delivery_tag)
  12. #表示队列不分奇偶分配,谁来取任务就给谁
  13. channel.basic_qos(prefetch_count=1)
  14. channel.basic_consume(callback,
  15. queue='hello',
  16. no_ack=False)
  17. print(' [*] Waiting for messages. To exit press CTRL+C')
  18. channel.start_consuming()

RabbitMQ会重新将该任务添加到队列中

python之上下文管理、redis的发布订阅、rabbitmq的更多相关文章

  1. Python之上下文管理器

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #Python之上下文管理器 #http://python.jobbole.com/82620/ #语法形式: ...

  2. Python之上下文管理

    http://www.cnblogs.com/coser/archive/2013/01/28/2880328.html 上下文管理协议为代码块提供包含初始化和清理操作的上下文环境.即便代码块发生异常 ...

  3. Redis之发布订阅

    一 什么是发布订阅 发布订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖它的对象都将得到通知 Redis 发布订阅(pub/sub)是一种消息通信模式: ...

  4. [翻译] C# 8.0 新特性 Redis基本使用及百亿数据量中的使用技巧分享(附视频地址及观看指南) 【由浅至深】redis 实现发布订阅的几种方式 .NET Core开发者的福音之玩转Redis的又一傻瓜式神器推荐

    [翻译] C# 8.0 新特性 2018-11-13 17:04 by Rwing, 1179 阅读, 24 评论, 收藏, 编辑 原文: Building C# 8.0[译注:原文主标题如此,但内容 ...

  5. Redisson 分布式锁实现之前置篇 → Redis 的发布/订阅 与 Lua

    开心一刻 我找了个女朋友,挺丑的那一种,她也知道自己丑,平常都不好意思和我一块出门 昨晚,我带她逛超市,听到有两个人在我们背后小声嘀咕:"看咱前面,想不到这么丑都有人要." 女朋友 ...

  6. redis的发布订阅模式

    概要 redis的每个server实例都维护着一个保存服务器状态的redisServer结构 struct redisServer {     /* Pubsub */     // 字典,键为频道, ...

  7. StackExchange.Redis 使用-发布订阅 (二)

    使用Redis的发布订阅功能 redis另一个常见的用途是发布订阅功能 . 它非常的简单 ,当连接失败时 ConnectionMultiplexer 会自动重新进行订阅 . ISubscriber s ...

  8. .net core 使用Redis的发布订阅

    Redis是一个性能非常强劲的内存数据库,它一般是作为缓存来使用,但是他不仅仅可以用来作为缓存,比如著名的分布式框架dubbo就可以用Redis来做服务注册中心.接下来介绍一下.net core 使用 ...

  9. redis的发布订阅模式pubsub

    前言 redis支持发布订阅模式,在这个实现中,发送者(发送信息的客户端)不是将信息直接发送给特定的接收者(接收信息的客户端),而是将信息发送给频道(channel),然后由频道将信息转发给所有对这个 ...

随机推荐

  1. eclips新建Maven Web项目

    一.创建项目 1.Eclipse中用Maven创建项目 上图中Next 2.继续Next 3.选maven-archetype-webapp后,next 4.填写相应的信息,Packaged是默认创建 ...

  2. Android Support v4,v7,v13的区别和应用场景

    android-support-v4 是谷歌推出的兼容包,最低兼容Android1.6的系统,里面有类似ViewPager等控件.ViewPager在Android 1.6以下的版本是不自带的,所以要 ...

  3. selenium+chrome下载文件,格式怎么选择???

    学习了下载 if browser == "Chrome": options=webdriver.ChromeOptions() prefs={'profile.default_co ...

  4. .clone事件当你克隆的时候,DOM节点是克隆出来了,但是克隆出来的节点不能运行时事件 ...

    解决办法如下在clone()里面加个参数true,即可完成事件的植入.即:.clone(true).clone( [ withDataAndEvents ], [ deepWithDataAndEve ...

  5. HDU2837 Calculation(扩展欧拉定理)

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...

  6. BZOJ3671: [Noi2014]随机数生成器(贪心)

    Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 2098  Solved: 946[Submit][Status][Discuss] Descripti ...

  7. 手机丢了怎么办?MZ给你来支招

    1致电运营商挂失手机 2致电银行冻结手机网银 3手机绑定支付宝的拨95188挂失 4微信用户登录110.qq.com冻结账号 5修改微博.微信.QQ等密码 6到手机运营商处补手机卡. 一定要记住啊!手 ...

  8. 4.1 基本类型和引用类型的值【JavaScript高级程序设计第三版】

    ECMAScript 变量可能包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象. 在将一个值赋给变量时,解析器必须确定这个值是基 ...

  9. PAT (Basic Level) Practice 1006 换个格式输出整数

    个人练习 让我们用字母B来表示“百”.字母S表示“十”,用“12...n”来表示个位数字n(&lt10),换个格式来输出任一个不超过3位的正整数.例如234应该被输出为BBSSS1234,因为 ...

  10. P1338 末日的传说 逆序数对

    题目描述 只要是参加jsoi活动的同学一定都听说过Hanoi塔的传说:三根柱子上的金片每天被移动一次,当所有的金片都被移完之后,世界末日也就随之降临了. 在古老东方的幻想乡,人们都采用一种奇特的方式记 ...