Ejabberd:从客户端连接时无法启动BOSH会话

问题描述 投票:0回答:2

今天我将服务器从Ubuntu 16.04升级到18.04,这也包括从ejabberd 16.01跳到18.01。现在我们遇到了从客户端连接的问题(使用strophe.js)

[info] <0.359.0>@ejabberd_listener:accept:302 (<0.876.0>) Accepted connection 127.0.0.1:60552 -> 127.0.0.1:8088
[error] <0.876.0>@ejabberd_bosh:start:133 Failed to start BOSH session: {error,{noproc,{gen_server,call,[ejabberd_c2s_sup,{start_child,[{xmpp_socket,{socket_state,ejabberd_bosh,{http_bind,<0.877.0>,{{9x,1xx,2xx,1xx},60552}},infinity,undefined,none,<0.877.0>}},[{receiver,<0.877.0>},{xml_socket,true}]]},infinity]}}}
[error] <0.877.0>@gen_server:call CRASH REPORT Process <0.877.0> with 0 neighbours exited with reason: no such process or port in call to gen_server:call(ejabberd_c2s_sup, {start_child,[{xmpp_socket,{socket_state,ejabberd_bosh,{http_bind,<0.877.0>,{{9x,1xx,2xx,1xx},60552}},...}},...]}, infinity) in p1_fsm:init_it/6 line 392
[error] <0.617.0>@gen_server:call Supervisor 'mod_bosh_chat3.myserver.com' had child undefined started with {ejabberd_bosh,start_link,undefined} at <0.877.0> exit with reason no such process or port in call to gen_server:call(ejabberd_c2s_sup, {start_child,[{xmpp_socket,{socket_state,ejabberd_bosh,{http_bind,<0.877.0>,{{9x,1xx,2xx,1xx},60552}},...}},...]}, infinity) in context child_terminated

我知道mod_http_bind被mod_bosh取代。客户端通过apache代理从端口80连接到8088.请求:80 / http-bind /因此将传递给:8088 / bosh /

升级后我还完全擦除了mnesia数据库,以确保它没有损坏或弃用。

According to this question,我还检查了curl是否已启用。

在loglevel调试中,似乎启动了mod_bosh模块:

[debug] <0.329.0>@gen_mod:start_module:193 loading mod_bosh at jabber.myserver.com
[debug] <0.329.0>@gen_mod:start_module:193 loading mod_push at jabber.myserver.com
[debug] <0.600.0> Supervisor ejabberd_gen_mod_sup started ejabberd_tmp_sup:start_link('mod_bosh_jabber.myserver.com', ejabberd_bosh) at pid <0.651.0>

这是我的完整配置:

loglevel: 5

log_rotate_size: 0
log_rotate_date: ""
log_rate_limit: 100

hosts:
  - "localhost"
  - "jabber.myserver.com"
  - "chat3.myserver.com"
  - "test-chat3.myserver.com"

define_macro:
  'TLS_CIPHERS': "HIGH:!aNULL:!eNULL:!3DES:@STRENGTH"
  'TLS_OPTIONS':
    - "no_sslv3"
    - "no_tlsv1"
    - "cipher_server_preference"
    - "no_compression"

c2s_ciphers: 'TLS_CIPHERS'
s2s_ciphers: 'TLS_CIPHERS'
c2s_protocol_options: 'TLS_OPTIONS'
s2s_protocol_options: 'TLS_OPTIONS'

listen: 

  - 
    port: 8088
    ip: "127.0.0.1"
    module: ejabberd_http
    request_handlers:
      "/bosh": mod_bosh
    web_admin: true
    tls: false

disable_sasl_mechanisms: "digest-md5"
s2s_use_starttls: false
auth_password_format: plain
auth_method: sql

sql_type: mysql
sql_server: "10.0.0.51"
sql_database: "databasename"
sql_username: "username"
sql_password: "secret-as-hell"

shaper:
  normal: 1000
  fast: 50000

max_fsm_queue: 10000

acl:
  admin:
    user:
      - "": "localhost"
      - "admin": "test-chat3.myserver.com"
      - "admin": "chat3.myserver.com"
  local: 
    user_regexp: ""
  loopback:
    ip:
      - "127.0.0.0/8"

shaper_rules:
  max_user_sessions: 10
  max_user_offline_messages:
    - 5000: admin
    - 100
  c2s_shaper:
    - none: admin
    - normal
  s2s_shaper: fast


access_rules:
  local:
    - allow: local
  c2s:
    - deny: blocked
    - allow
  announce:
    - allow: admin
  configure:
    - allow: admin
  muc_create:
    - allow: local
  pubsub_createnode:
    - allow: local
  register:
    - allow
  trusted_network:
    - allow: loopback

api_permissions:
  "console commands":
    from:
      - ejabberd_ctl
    who: all
    what: "*"
  "admin access":
    who:
      - access:
        - allow:
          - acl: loopback
          - acl: admin
      - oauth:
        - scope: "ejabberd:admin"
        - access:
          - allow:
            - acl: loopback
            - acl: admin
    what:
      - "*"
      - "!stop"
      - "!start"
  "public commands":
    who:
      - ip: "127.0.0.1/8"
    what:
      - "status"
      - "connected_users_number"

language: "en"

acme:
  contact: "mailto:[email protected]"
  ca_url: "https://acme-v01.api.letsencrypt.org"


modules: 
  mod_adhoc: {}
  mod_admin_extra: {}
  mod_announce: # recommends mod_adhoc
    access: announce
  mod_blocking: {} # requires mod_privacy
  mod_caps: {}
  mod_carboncopy: {}
  mod_client_state: {}
  mod_configure: {} # requires mod_adhoc
  mod_disco: {}
  mod_echo: {}
  mod_irc: {}
  mod_bosh: {}
  mod_last: {}
  mod_muc: 
    access:
      - allow
    access_admin:
      - allow: admin
    access_create: muc_create
    access_persistent: muc_create
  mod_muc_admin: {}
  mod_offline: 
    access_max_user_messages: max_user_offline_messages
  mod_ping: {}
  mod_privacy: {}
  mod_private: {}
  mod_pubsub: 
    access_createnode: pubsub_createnode
    ignore_pep_from_offline: true
    last_item_cache: false
    plugins: 
      - "flat"
      - "hometree"
      - "pep" # pep requires mod_caps
  mod_push: {}
  mod_push_keepalive: {}
  mod_roster:
    versioning: true
  mod_shared_roster: {}
  mod_stats: {}
  mod_time: {}
  mod_vcard:
    search: false
  mod_vcard_xupdate: {}
  mod_version: {}
  mod_stream_mgmt:
    resend_on_timeout: if_offline
  mod_s2s_dialback: {}
  mod_http_api: {}

allow_contrib_modules: true

非常感谢任何提示:-)

xmpp ejabberd ubuntu-18.04 bosh
2个回答
2
投票

您的配置中的问题似乎是您删除了ejabberd_c2s侦听器。它是必需的,您可以在错误消息中看到它。所以,通过添加它来解决问题,至少在我的情况下,例如:

listen:
  -
    port: 5222
    module: ejabberd_c2s
  - 
    port: 8088
    ip: "127.0.0.1"
    module: ejabberd_http
    request_handlers:
      "/bosh": mod_bosh
    web_admin: true
    tls: false

ejabberd文档中没有提到这样的要求,所以我现在已经添加了它。


0
投票

更新:忘掉下面的一切。请参阅Badlop的答案


完全重新安装了ejabberd:

apt-get --purge autoremove ejabberd

(确保/ etc / ejabberd为空)

apt-get update
apt-get upgrade
apt-get install ejabberd

这里是ejabberd.yml的相关部分。我没有改变任何其他事情:

hosts:
  - "localhost"
  - "chat3.myserver.com" <- the public domain

listen:
  - 
    port: 5222
    ...
  -
    port: 5269
    ...
  -
    ##port: 5280
    port: 8088      <- use any port you like
    ip: "127.0.0.1" <- listen only on localhost
    module: ejabberd_http
    request_handlers:
      "/ws": ejabberd_http_ws
      "/bosh": mod_bosh
      "/api": mod_http_api
    ##  "/pub/archive": mod_http_fileserver
    web_admin: true
    ## register: true
    ## captcha: true
    tls: false  <- no need for tls on localhost
    protocol_options: 'TLS_OPTIONS'

auth_method: sql
sql_type: mysql
sql_server: "server"
sql_database: "ejabberd_live"
sql_username: "ejabberd"
sql_password: "secret"

acl:
  admin:
  user:
    - "": "localhost"
    - "admin": "chat3.myserver.com"

如果你想知道我在apache中的代理配置。这些是我的chat3.myserver.com虚拟主机的相关行:

ProxyPass /http-bind/ http://127.0.0.1:8088/bosh
ProxyPassReverse /http-bind/ http://127.0.0.1:8088/bosh
ProxyPass /admin/ http://127.0.0.1:8088/admin/
ProxyPassReverse /admin/ http://127.0.0.1:8088/admin/

您将导致还需要获取mysql数据库架构from here ......等等......

我不知道是什么原因造成了连接错误。我想ejabberd的升级在某种程度上是错误的。至少我很确定这不是一个已知的bug。我使用这个版本的ejabberd(18.01)在互联网上爬了4个小时而没有找到类似的东西。而且错误信息 - 即使在loglevel 5下 - 也非常模糊。如果这是一个配置错误,我相信错误消息将更加具体。

© www.soinside.com 2019 - 2024. All rights reserved.