激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Redis - 通過 Redis 實現 RPC 遠程方法調用(支持多種編程語言)

通過 Redis 實現 RPC 遠程方法調用(支持多種編程語言)

2019-10-20 22:43junjie Redis

這篇文章主要介紹了通過 Redis 實現 RPC 遠程方法調用,支持多種編程語言,本文就以Ruby和Python為例,給出了實現代碼,需要的朋友可以參考下

我發現經常研究并且為之興奮的一件事就是對系統進行擴展。現在這對不同的人有著不同的意思。作為移植Monolithic應用到Microservices架構方法中的一部分,如何處理Microservices架構是我研究RPC的原因。

RPC(或者叫做遠程進程調用)是一個已經在計算機科學領域存在較長一段時間的概念。對此一種非常簡單的理解就是發送一段消息到遠程進程的能力,而不論它是在同一個系統上還是遠程的系統。總的來說這是非常模糊的,而且對許多的實現來說是開放的。在我看來,當談到RPC時,會有相當多的內容可供探討,比如消息的格式,以及你怎樣將消息發送到遠程進程上。有許多的方法來實現RPC,而這是我采用的一種,但對這篇文章來說,我準備使用‘JSON-RPC'來處理消息的格式,用Redis來發布消息。

RPC和消息隊列

原理基本上都一樣,但是使用RPC的話,客戶端會等待一個含有RPC調用結果的返回消息。如果你的消息隊列系統允許你為發送者處理回調消息,那么你很可能就可以為RPC來使用它。在大多數的消息隊列中,它們被用來觸發那些不再需要回復給客戶端的任務。

為什么用Redis而不是其它的?

你應該能夠在某個地主發現Redis是非常先進的技術,如果你說沒有發現,你是怎么了?Redis對很多事情來說都是一個偉大的工具,你應該認真研究一下。學習之路能夠平坦,并且不用學習太多的新內容,Redis都完美的符合這些想法,所以,讓我們看看我們可以干些什么。

Client

 

復制代碼代碼如下:


require 'redis'
require 'securerandom'
require 'msgpack'

 

class RedisRpcClient

  def initialize(redis_url, list_name)
    @client = Redis.connect(url: redis_url)
    @list_name = list_name.to_s
  end

  def method_missing(name, *args)
    request = {
      'jsonrpc' => '2.0',
      'method' => name,
      'params' => args,
      'id' => SecureRandom.uuid
    }

    @client.lpush(@list_name, request.to_msgpack)
    channel, response = @client.brpop(request['id'], timeout=30)

    MessagePack.unpack(response)['result']
  end

end

client = RedisRpcClient.new('redis://localhost:6379', :fib)
(1..30).each { |i| puts client.fib(i) }

 

Server

 

復制代碼代碼如下:


require 'redis'
require 'msgpack'

 


class Fibonacci

  def fib(n)
    case n
    when 0 then 0
    when 1 then 1
    else
      fib(n - 1) + fib(n - 2)
    end
  end

end


class RedisRpcServer

  def initialize(redis_url, list_name, klass)
    @client = Redis.connect(url: redis_url)
    @list_name = list_name.to_s
    @klass = klass
  end

  def start
    puts "Starting RPC server for #{@list_name}"
    while true
      channel, request = @client.brpop(@list_name)
      request = MessagePack.unpack(request)

      puts "Working on request: #{request['id']}"

      args = request['params'].unshift(request['method'])
      result = @klass.send *args

      reply = {
        'jsonrpc' => '2.0',
        'result' => result,
        'id' => request['id']
      }

      @client.rpush(request['id'], MessagePack.pack(reply))
      @client.expire(request['id'], 30)
    end

  end

end

RedisRpcServer.new('redis://localhost:6379', :fib,  Fibonacci.new).start

 

確是如此,它能工作是因為當你等待數據從服務器傳回來時,Redis有命令能夠讓你阻塞等待。這是非常優秀的做法,它讓你的客戶端代碼看上去像是在調用本地方法。

Ruby 相當酷,可是。。。

如果你想用其它語言怎么辦?沒問題,只要你的語言有很好的Redis庫,你就可以做同樣的事。讓我們瞧一瞧用Python來建立一個服務端程序。

 

復制代碼代碼如下:


import redis
import msgpack

 

class Fibonacci:

  def fib(self,n):
    if n == 0:
      return 0
    elif n == 1:
      return 1
    else:
      return self.fib(n-1) + self.fib(n-2)


class RedisRpcServer:

  def __init__(self, redis_url, list_name, klass):
    self.client = redis.from_url(redis_url)
    self.list_name = list_name
    self.klass = klass

  def start(self):
    print("Starting RPC server for " + self.list_name)
    while True:
      channel, request = self.client.brpop('fib')
      request = msgpack.unpackb(request, encoding='utf-8')

      print("Working on request: " + request['id'])

      result = getattr(self.klass, request['method'])(*request['params'])

      reply = {
        'jsonrpc': '2.0',
        'result': result,
        'id': request['id']
      }

      self.client.rpush(request['id'], msgpack.packb(reply, use_bin_type=True))
      self.client.expire(request['id'], 30)


RedisRpcServer('redis://localhost:6379', 'fib', Fibonacci()).start()

 

結論

這很好的證明了你頭腦中的一些想法,當然,還需要更多的工作來處理異常。如果你用這個方法遇到任何的問題,我樂意幫助你。我的確希望在同樣想法的一此地方使用RabbitMQ,但如果你已經在你的項目中使用了Redis,這將會是一個非常不錯的方法。

延伸 · 閱讀

精彩推薦
  • Redisredis實現排行榜功能

    redis實現排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實現排行榜功能,本文就來簡單的介紹一下如何使用,具有一定的參考價值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • RedisRedis的配置、啟動、操作和關閉方法

    Redis的配置、啟動、操作和關閉方法

    今天小編就為大家分享一篇Redis的配置、啟動、操作和關閉方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡5312019-11-14
  • Redis詳解Redis復制原理

    詳解Redis復制原理

    與大多數db一樣,Redis也提供了復制機制,以滿足故障恢復和負載均衡等需求。復制也是Redis高可用的基礎,哨兵和集群都是建立在復制基礎上實現高可用的...

    李留廣10222021-08-09
  • RedisRedis如何實現數據庫讀寫分離詳解

    Redis如何實現數據庫讀寫分離詳解

    Redis的主從架構,能幫助我們實現讀多,寫少的情況,下面這篇文章主要給大家介紹了關于Redis如何實現數據庫讀寫分離的相關資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    這篇文章主要給大家介紹了關于redis中如何使用lua腳本讓你的靈活性提高5個逼格的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具...

    一線碼農5812019-11-18
  • RedisRedis全量復制與部分復制示例詳解

    Redis全量復制與部分復制示例詳解

    這篇文章主要給大家介紹了關于Redis全量復制與部分復制的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Redis爬蟲具有一定的參考學習...

    豆子先生5052019-11-27
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友...

    xiaojin21cen10152021-07-27
  • RedisRedis 事務知識點相關總結

    Redis 事務知識點相關總結

    這篇文章主要介紹了Redis 事務相關總結,幫助大家更好的理解和學習使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
主站蜘蛛池模板: 成人午夜免费网站 | 香蕉视频1024 | 成人小视频在线播放 | 精精国产xxxx视频在线播放7 | 国产在线精品一区二区三区 | 精品亚洲一区二区三区 | 亚洲国产精品二区 | 在线播放视频一区二区 | 在线视频成人永久免费 | 亚洲一区二区欧美 | a网站在线 | 久久久久久久九九九九 | jizzjizz中国少妇中文 | 亚洲小视频在线播放 | 99re3 | 欧美一区在线观看视频 | 九九热在线免费观看视频 | 91性高湖久久久久久久久网站 | 日韩欧美电影一区二区三区 | 国产亚洲精品久久 | 一区二区三区日本在线观看 | 永久在线观看电影 | 亚洲日本欧美 | 午夜国产精品成人 | 久久久免费电影 | 精品国产乱码久久久久久丨区2区 | 成人欧美日韩一区二区三区 | 九九热免费在线观看 | 午夜视频久久久 | 日本一区二区不卡高清 | 国产大片免费看 | 免费的毛片 | 国产毛片在线 | 精品乱码久久久久 | 亚洲国产视频网 | 一区二区久久精品66国产精品 | 欧美日韩大片在线观看 | 黄色成人av在线 | 91网站免费在线观看 | 久久看视频 | 天天鲁在线视频免费观看 |