美文网首页
Mosquitto学习笔记

Mosquitto学习笔记

作者: Juude | 来源:发表于2016-03-21 18:14 被阅读3428次

声明:

这篇笔记是我进行技术选型时候的一些记录,最终我们的推送系统并没有采用基于Mosquitto的方案,这些内容仅供参考,需要更权威消息,还请移步官网。

使用方法

mosquitto_pub

mosquitto_passwd

代码结构

数据结构

  • struct mosquitto_db
  • struct mosquitto
  • mqtt3_config : 配置文件的映射

文件结构

  • security_default.c
    • mosquitto_security_init_default
    • mosquitto_security_cleanup_default
  • net.c
    • mqtt3_socket_accept
  • logging_mosquitto.c
    • _mosquitto_log_printf
  • read_handle.c
    • mqtt3_packet_handle: 读取包
  • read_handle_client.c
    • mqtt3_handle_connack
  • read_handle_server.c
    • mqtt3_handle_connect
    • mqtt3_handle_disconnect
    • mqtt3_handle_subscribe
    • mqtt3_handle_unsubscribe
  • loop.c : 主循环
    • loop_handle_reads_writes: 循环读取/写消息
    • loop_handle_errors : 循环处理错误消息
    • do_disconnect : 断开连接
    • mosquitto_main_loop: 启用主循环
  • lib/net.c
    • _mosquitto_packet_write
    • _mosquitto_net_write
    • _mosquitto_net_read
  • lib/memory_mosq.c
    • _mosquitto_calloc
    • _mosquitto_free
  • conf.c
    • _conf_attempt_resolve
    • _config_init_reload
    • mqtt3_config_init
    • mqtt3_config_cleanup
    • mqtt3_config_parse_args
  • sys_tree.c
    • _sys_update_clients
    • _sys_update_memory
    • calc_load
    • mqtt3_db_sys_update
  • subs.c : subscription
    • _subs_process
    • _sub_topic_tokenise
    • _sub_add
    • _sub_remove
    • _sub_search
    • mqtt3_sub_add
    • mqtt3_sub_remove
    • mqtt3_db_messages_queue
    • _subs_clean_session
    • mqtt3_subs_clean_session
    • mqtt3_sub_tree_print
    • _retain_process 预留的信息
    • mqtt3_retain_queue

标识符

username_flag:
connect_flags

Demos to write

  1. login with ssl
  2. use passwd to login

Connect 流程

start=>start: Start
mqtt3_packet_handle=>operation: mqtt3_packet_handle
mqtt3_handle_connect=>operation: read_handle_server#mqtt3_handle_connect
start->mqtt3_packet_handle->mqtt3_handle_connect

ACL

ACL流程

start=>start: Start
mqtt3_handle_publish=>operation: mqtt3_handle_publish
mosquitto_acl_check=>operation: mosquitto_acl_check
start->mqtt3_handle_publish->mosquitto_acl_check

ACL topic 与pattern区别

Clients

  1. 异步与同步

Questions

  1. database 放在什么地方?
  2. pid_file /var/run/mosquitto.pid 作用?
  3. 数据库的格式是什么?
    • 二进制的
  4. 为何不用mysql等数据库访问
  5. 数据库中存放了哪些信息?
  6. 所有的配置选项:./mosquitto.conf
  7. what is briges?
  8. 如何接受离线消息
    • set cleansession = False
    • set qos to 2
  9. 离线的消息是存储在哪里的?
  10. 如何让某个账号给权限获取离线消息
  11. ssl 是如何正确运行的?
  12. 从接受消息到发送消息的过程是怎样的?
  13. 启动服务器的过程是怎样的?
  14. contexts作用?
  15. WITH_SYS_TREE 干嘛的?
  16. lib目录下的是否有用
    • 有用
  17. 如何保证推送成功
    • qos0? \
  18. 数据库与sql数据库有什么关系?
  19. 如何读取$SYS信息

参考

mosquitto源码分析 : http://wenku.baidu.com/link?url=iICdhK4CbSxFfHO5-MkobVoJ8BXdZNuMHulUzfCg-oMFUpfKWvL07APDQVLur0iPG9DdYrDRiBKrZ8wD9klG6N9xdRp1Qt7TQgBN4GToahy
Mosquitto : http://eclipse.org/mosquitto/

如果对我的文章感兴趣,也可以关注 我的github.

相关文章

网友评论

      本文标题:Mosquitto学习笔记

      本文链接:https://www.haomeiwen.com/subject/djiklttx.html