| 
        1
       
        2
       
        3
       
        4
       
        5
       
        6
       
        7
       | 点对点:A 发消息给 B。广播:A 发给所有其他人的消息组播:A 发给多个但不是所有其他人的消息。Requester/response:类似访问网页的通信方式,客户端发请求并等待,服务端回复该请求Pub-sub:类似杂志发行,出版杂志的人并不知道谁在看这本杂志,订阅的人并不关心谁在发表这本杂志。出版的人只管将信息发布出去,订阅的人也只在需要的时候收到该信息。Store-and-forward:存储转发模型类似信件投递,写信的人将消息写给某人,但在将信件发出的时候,收信的人并不一定在家等待,也并不知道有消息给他。但这个消息不会丢失,会放在收信者的信箱中。这种模型允许信息的异步交换。其他通信模型。。。 | 
| 
        1
       
        2
       
        3
       
        4
       
        5
       
        6
       
        7
       
        8
       
        9
       
        10
       
        11
       
        12
       
        13
       | 几个概念Producer,Routing Key,Exchange,Binding,Queue,Consumer.Producer: 消息的创建者,消息的发送者Routing Key:唯一用来映射消息该进入哪个队列的标识Exchange:负责消息的路由,交换Binding:定义Queue和Exchange的映射关系Queue:消息队列Consumer:消息的使用者Exchange类型Fan-Out:类似于广播方式,不管RoutingKeyDirect:根据RoutingKey,进行关联投寄Topic:类似于Direct,但是支持多个Key关联,以组的方式投寄。      key以.来定义界限。类似于usea.news,usea.weather.这两个消息是一组的。 | 
| 
        1
       
        2
       
        3
       | yum install qpid-cpp-serveryum install qpid-tools/etc/init.d/qpidd start | 
| 
        1
       
        2
       
        3
       
        4
       
        5
       
        6
       
        7
       
        8
       
        9
       
        10
       
        11
       
        12
       
        13
       
        14
       
        15
       
        16
       
        17
       
        18
       
        19
       
        20
       
        21
       
        22
       
        23
       
        24
       
        25
       
        26
       
        27
       
        28
       
        29
       
        30
       
        31
       
        32
       
        33
       
        34
       
        35
       
        36
       
        37
       
        38
       
        39
       
        40
       
        41
       
        42
       
        43
       
        44
       
        45
       
        46
       
        47
       
        48
       
        49
       
        50
       
        51
       
        52
       
        53
       
        54
       
        55
       
        56
       
        57
       
        58
       
        59
       
        60
       
        61
       
        62
       
        63
       
        64
       
        65
       
        66
       
        67
       
        68
       
        69
       
        70
       
        71
       
        72
       
        73
       
        74
       
        75
       
        76
       
        77
       
        78
       
        79
       
        80
       
        81
       
        82
       
        83
       
        84
       
        85
       
        86
       
        87
       
        88
       
        89
       
        90
       
        91
       
        92
       
        93
       | #!/usr/bin/env python#xiaorui.ccimportoptparse, timefrom qpid.messaging import*from qpid.util importURLfrom qpid.log importenable, DEBUG, WARNdef nameval(st):  idx = st.find("=")  ifidx >= 0:    name = st[0:idx]    value = st[idx+1:]  else:    name = st    value = None  returnname, valueparser = optparse.OptionParser(usage="usage: %prog [options] ADDRESS [ CONTENT ... ]",                               description="Send messages to the supplied address.")parser.add_option("-b", "--broker", default="localhost",                  help="connect to specified BROKER (default %default)")parser.add_option("-r", "--reconnect", action="store_true",                  help="enable auto reconnect")parser.add_option("-i", "--reconnect-interval", type="float", default=3,                  help="interval between reconnect attempts")parser.add_option("-l", "--reconnect-limit", type="int",                  help="maximum number of reconnect attempts")parser.add_option("-c", "--count", type="int", default=1,                  help="stop after count messages have been sent, zero disables (default %default)")parser.add_option("-t", "--timeout", type="float", default=None,                  help="exit after the specified time")parser.add_option("-I", "--id", help="use the supplied id instead of generating one")parser.add_option("-S", "--subject", help="specify a subject")parser.add_option("-R", "--reply-to", help="specify reply-to address")parser.add_option("-P", "--property", dest="properties", action="append", default=[],                  metavar="NAME=VALUE", help="specify message property")parser.add_option("-M", "--map", dest="entries", action="append", default=[],                  metavar="KEY=VALUE",                  help="specify map entry for message body")parser.add_option("-v", dest="verbose", action="store_true",                  help="enable logging")opts, args = parser.parse_args()ifopts.verbose:  enable("qpid", DEBUG)else:  enable("qpid", WARN)ifopts.id isNone:  spout_id = str(uuid4())else:  spout_id = opts.idifargs:  addr = args.pop(0)else:  parser.error("address is required")content = Noneifargs:  text = " ".join(args)else:  text = Noneifopts.entries:  content = {}  iftext:    content["text"] = text  fore inopts.entries:    name, val = nameval(e)    content[name] = valelse:  content = textconn = Connection(opts.broker,                  reconnect=opts.reconnect,                  reconnect_interval=opts.reconnect_interval,                  reconnect_limit=opts.reconnect_limit)try:  conn.open()  ssn = conn.session()  snd = ssn.sender(addr)  count = 0  start = time.time()  while(opts.count == 0or count < opts.count) and \        (opts.timeout isNone or time.time() - start < opts.timeout):    msg = Message(subject=opts.subject,                  reply_to=opts.reply_to,                  content=content)    msg.properties["spout-id"] = "%s:%s"% (spout_id, count)    forp inopts.properties:      name, val = nameval(p)      msg.properties[name] = val    snd.send(msg)    count += 1    print msgexcept SendError, e:  print eexcept KeyboardInterrupt:  passconn.close() | 
| 
        1
       
        2
       
        3
       
        4
       
        5
       
        6
       
        7
       
        8
       
        9
       
        10
       
        11
       
        12
       
        13
       
        14
       
        15
       
        16
       
        17
       
        18
       
        19
       
        20
       
        21
       
        22
       
        23
       
        24
       
        25
       
        26
       
        27
       
        28
       
        29
       
        30
       
        31
       
        32
       
        33
       
        34
       
        35
       
        36
       
        37
       
        38
       
        39
       
        40
       
        41
       
        42
       
        43
       
        44
       
        45
       
        46
       
        47
       
        48
       
        49
       
        50
       
        51
       
        52
       
        53
       
        54
       
        55
       
        56
       
        57
       
        58
       
        59
       
        60
       
        61
       
        62
       
        63
       
        64
       
        65
       
        66
       
        67
       
        68
       
        69
       | #!/usr/bin/env python#xiaorui.ccimportoptparsefromqpid.messaging import*fromqpid.util importURLfromqpid.log importenable, DEBUG, WARNparser =optparse.OptionParser(usage="usage: %prog [options] ADDRESS ...",                               description="Drain messages from the supplied address.")parser.add_option("-b", "--broker", default="localhost",                  help="connect to specified BROKER (default %default)")parser.add_option("-c", "--count", type="int",                  help="number of messages to drain")parser.add_option("-f", "--forever", action="store_true",                  help="ignore timeout and wait forever")parser.add_option("-r", "--reconnect", action="store_true",                  help="enable auto reconnect")parser.add_option("-i", "--reconnect-interval", type="float", default=3,                  help="interval between reconnect attempts")parser.add_option("-l", "--reconnect-limit", type="int",                  help="maximum number of reconnect attempts")parser.add_option("-t", "--timeout", type="float", default=0,                  help="timeout in seconds to wait before exiting (default %default)")parser.add_option("-p", "--print", dest="format", default="%(M)s",                  help="format string for printing messages (default %default)")parser.add_option("-v", dest="verbose", action="store_true",                  help="enable logging")opts, args =parser.parse_args()ifopts.verbose:  enable("qpid", DEBUG)else:  enable("qpid", WARN)ifargs:  addr =args.pop(0)else:  parser.error("address is required")ifopts.forever:  timeout =Noneelse:  timeout =opts.timeoutclassFormatter:  def__init__(self, message):    self.message =message    self.environ ={"M": self.message,                    "P": self.message.properties,                    "C": self.message.content}  def__getitem__(self, st):    returneval(st, self.environ)conn =Connection(opts.broker,                  reconnect=opts.reconnect,                  reconnect_interval=opts.reconnect_interval,                  reconnect_limit=opts.reconnect_limit)try:  conn.open()  ssn =conn.session()  rcv =ssn.receiver(addr)  count =0  whilenotopts.count orcount < opts.count:    try:      msg =rcv.fetch(timeout=timeout)      printopts.format%Formatter(msg)      count +=1      ssn.acknowledge()    exceptEmpty:      breakexceptReceiverError, e:  printeexceptKeyboardInterrupt:  passconn.close() | 
| 
        1
       
        2
       
        3
       
        4
       
        5
       | 服务端qpid-config add exchange topic news-service./spout news-service/news xiaorui.cc客户端:./drain -t 120news-service/#.news | 
 
                       
                             
                         
                             
                             
                           
                           
                            





 
       
           
                 
                 
                 
                 
                 
                
               
                 
                 
                 
                 
                
               
                 
                 扫一扫
扫一扫
                     
              
             
                   979
					979
					
 被折叠的  条评论
		 为什么被折叠?
被折叠的  条评论
		 为什么被折叠?
		 
		  到【灌水乐园】发言
到【灌水乐园】发言                                
		 
		 
    
   
    
   
             
            


 
            