MessageBus 开源项目教程

MessageBus 开源项目教程

message_busA reliable and robust messaging bus for Ruby and Rack项目地址:https://gitcode.com/gh_mirrors/me/message_bus

1. 项目的目录结构及介绍

MessageBus 项目的目录结构如下:

message_bus/
├── assets/
│   └── message-bus.js
├── lib/
│   ├── message_bus.rb
│   ├── message_bus/
│   │   ├── async_producer.rb
│   │   ├── client.rb
│   │   ├── connection_manager.rb
│   │   ├── message.rb
│   │   ├── middleware.rb
│   │   ├── postgresql_backend.rb
│   │   ├── redis_backend.rb
│   │   └── version.rb
│   └── message_bus.rb
├── spec/
│   ├── message_bus_spec.rb
│   ├── middleware_spec.rb
│   └── spec_helper.rb
├── .gitignore
├── .travis.yml
├── Gemfile
├── LICENSE
├── README.md
└── message_bus.gemspec

目录介绍

  • assets/: 包含 JavaScript 客户端文件 message-bus.js
  • lib/: 包含主要的 Ruby 代码文件,其中 message_bus.rb 是入口文件,message_bus/ 目录下包含各种功能模块。
  • spec/: 包含测试文件,用于项目的单元测试。
  • .gitignore: 用于指定 Git 版本控制系统忽略的文件和目录。
  • .travis.yml: Travis CI 的配置文件,用于持续集成。
  • Gemfile: 定义项目依赖的 RubyGems。
  • LICENSE: 项目的许可证文件。
  • README.md: 项目的说明文档。
  • message_bus.gemspec: 用于打包和发布 Gem 的规范文件。

2. 项目的启动文件介绍

MessageBus 项目的启动文件是 lib/message_bus.rb。这个文件是项目的入口点,负责加载和初始化 MessageBus 库。

require 'json'
require 'set'
require 'thread'
require 'securerandom'
require 'time'
require 'rack'
require 'logger'

require 'message_bus/version'
require 'message_bus/configuration'
require 'message_bus/client'
require 'message_bus/message'
require 'message_bus/async_producer'
require 'message_bus/connection_manager'
require 'message_bus/middleware'
require 'message_bus/backends/redis'
require 'message_bus/backends/postgres'

module MessageBus
  def self.configure(opts = {})
    @config = Configuration.new
    @config.configure(opts)
  end

  def self.config
    @config ||= Configuration.new
  end

  def self.logger
    config.logger
  end

  def self.reset!
    @config = nil
  end

  def self.rack_based_site_id_lookup
    config.rack_based_site_id_lookup
  end

  def self.site_id_lookup
    config.site_id_lookup
  end

  def self.user_id_lookup
    config.user_id_lookup
  end

  def self.group_ids_lookup
    config.group_ids_lookup
  end

  def self.client_filter_cache
    @client_filter_cache ||= {}
  end

  def self.client_filter_cache=(v)
    @client_filter_cache = v
  end

  def self.is_admin_lookup
    config.is_admin_lookup
  end

  def self.extra_response_headers_lookup
    config.extra_response_headers_lookup
  end

  def self.long_polling_interval
    config.long_polling_interval
  end

  def self.max_backlog_age
    config.max_backlog_age
  end

  def self.max_backlog_size
    config.max_backlog_size
  end

  def self.max_active_clients
    config.max_active_clients
  end

  def self.max_active_queues
    config.max_active_queues
  end

  def self.cluster_multicast_interval
    config.cluster_multicast_interval
  end

  def self.

message_busA reliable and robust messaging bus for Ruby and Rack项目地址:https://gitcode.com/gh_mirrors/me/message_bus

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

焦珑雯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值