基于redis(订阅发布)实现python和java进程间通信

Posted 堕落门徒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于redis(订阅发布)实现python和java进程间通信相关的知识,希望对你有一定的参考价值。

主要结构为: python进程发布消息,java进程订阅消息。

依赖环境:

python:   pip install redis

java:  jedis

1. python端:

PubSub.py

import redis

class PubSub(object):
    def __init__(self, host, port, db):
        self.__conn = redis.Redis(host, port, db)

    def publish(self, channel, msg):
        self.__conn.publish(channel, msg)
        return True

    def subscribe(self, channel):
        pub = self.__conn.pubsub()
        pub.subscribe(channel)
        pub.parse_response()
        return pub

sub.py

from PubSub import PubSub

obj = PubSub(\'localhost\', 6379, 1)
redis_sub = obj.subscribe(\'cord\')

while True:
    msg = redis_sub.parse_response()
    msg = msg[2].decode()
    print(msg)

2. java端

RedisPub.java

import redis.clients.jedis.Jedis;
import java.util.Date;
public class RedisPub {
    private static Jedis jedis = new Jedis("localhost",6379);
    private static final String channel = "cord";
    public static void main(String[] args){
        String message = new Date().toString();
        jedis.publish(channel, message);
    }
}

参考链接:

http://www.cnblogs.com/melonjiang/p/5342383.html

以上是关于基于redis(订阅发布)实现python和java进程间通信的主要内容,如果未能解决你的问题,请参考以下文章

python中使用redis发布订阅者模型

基于Redis的发布/订阅模式实现者:RedisQ

基于Redis的发布/订阅模式实现者:RedisQ

python实现 redis订阅与发布

2020-04-05-SpringBoot+WebSocket基于Redis订阅发布实现集群化

Redis发布订阅原理与实践