我对XMPP和WEBRTC相对较新。现在,我尝试使用Jitsi Videobridge和Prostody创建简单的视频会议Web应用程序,并且我不想使用Jitsi-Meet,因为我需要知道如何使Jitsi-Videobridge的基本内容工作。到目前为止,我可以让韵律接受Jitsi-Videobridge组件。因此,当我运行./jvb.sh --domain=localhost --port=5347 --secret=componentsecret
时,它将显示以下日志:
JVB 2017-04-21 10:52:53.798 INFO: [38]
org.jitsi.videobridge.xmpp.ComponentImpl.log() RECV: <iq id="f68D9-340"
type="result" to="jitsi-videobridge.localhost" from="localhost"/>
JVB 2017-04-21 10:53:03.801 INFO: [40]
org.jitsi.videobridge.xmpp.ComponentImpl.log() RECV: <iq id="f68D9-341"
type="result" to="jitsi-videobridge.localhost" from="localhost"/>
JVB 2017-04-21 10:53:13.801 INFO: [42]
org.jitsi.videobridge.xmpp.ComponentImpl.log() RECV: <iq id="f68D9-342"
type="result" to="jitsi-videobridge.localhost" from="localhost"/>
JVB 2017-04-21 10:53:23.801 INFO: [44]
org.jitsi.videobridge.xmpp.ComponentImpl.log() RECV: <iq id="f68D9-343"
type="result" to="jitsi-videobridge.localhost" from="localhost"/>
JVB 2017-04-21 10:53:33.801 INFO: [46]
org.jitsi.videobridge.xmpp.ComponentImpl.log() RECV: <iq id="f68D9-344"
type="result" to="jitsi-videobridge.localhost" from="localhost"/>
我认为我的jitsi-videobridge正常工作(不是吗?(。但是现在我不知道下一步该怎么做。
so,如何将我的客户端(我的网络客户端使用strophe.js
(连接到jitsi-videobridge?以及我的客户如何能够将媒体(视频和音频(发送到Jitsi-Videobridge。我已经搜索了一段时间,但是我找不到任何有关如何做的文档或任何示例。P>
这是我的韵律韵律。cfg.lua:
admins = {
"agent@localhost",
"subkhan@localhost",
"subkhan@192.168.8.108",
"focus@auth.jitsi.localhost"
}
modules_enabled = {
"message_logging"; -- Enable chat archive
"tls"; -- Enable mod_tls
"roster"; -- Allow users to have a roster. Recommended ;)
"saslauth"; -- Authentication for clients and servers. Recommended if you want to log in.
"tls"; -- Add support for secure TLS on c2s/s2s connections
"dialback"; -- s2s dialback support
"disco"; -- Service discovery
"private"; -- Private XML storage (for room bookmarks, etc.)
"vcard"; -- Allow users to set vCards
"version"; -- Replies to server version requests
"uptime"; -- Report how long server has been running
"time"; -- Let others know the time here on this server
"ping"; -- Replies to XMPP pings with pongs
"pep"; -- Enables users to publish their mood, activity, playing music and more
"register"; -- Allow users to register on this server using a client and change passwords
"admin_adhoc"; -- Allows administration via an XMPP client that supports ad-hoc commands
"admin_telnet"; -- Opens telnet console interface on localhost port 5582
"bosh"; -- Enable BOSH clients, aka "Jabber over HTTP"
"http_files"; -- Serve static files from a directory over HTTP
"posix"; -- POSIX functionality, sends server to background, enables syslog, etc.
};
bosh_ports = {
{
port = 5280;
path = "http-bind";
},
{
port = 5281;
path = "http-bind";
ssl = {
key = "/var/lib/prosody/localhost.key";
certificate = "/var/lib/prosody/localhost.crt";
}
}
}
bosh_max_inactivity = 60
consider_bosh_secure = true
cross_domain_bosh = true
modules_disabled = {
-- "offline"; -- Store offline messages
-- "c2s"; -- Handle client connections
-- "s2s"; -- Handle server-to-server connections
};
allow_registration = true;
daemonize = true;
pidfile = "/var/run/prosody/prosody.pid";
ssl = {
key = "/etc/prosody/certs/localhost.key";
certificate = "/etc/prosody/certs/localhost.crt";
}
c2s_require_encryption = true
s2s_secure_auth = true
authentication = "internal_plain"
log = {
-- Log files (change 'info' to 'debug' for debug logs):
info = "/var/log/prosody/prosody.log";
error = "/var/log/prosody/prosody.err";
-- Syslog:
{ levels = { "error" }; to = "syslog"; };
}
VirtualHost "localhost"
enabled = true -- Remove this line to enable this host
ssl = {
key = "/etc/prosody/certs/localhost.key";
certificate = "/etc/prosody/certs/localhost.crt";
}
Component "conference.localhost" "muc"
restrict_room_creation = true
max_history_messages = 10
modules_enabled = {
"muc_log";
"muc_log_http";
}
muc_log_http = { -- These are the defaults
show_join = true;
show_presences = true;
show_status = true;
theme = "prosody";
url_base = "muc_log";
}
VirtualHost "jitsi.localhost"
enable = true
authentication = "internal_plain"
VirtualHost "auth.jitsi.localhost"
authentication = "internal_plain"
Component "jitsi-videobridge.localhost"
component_secret = "asdqwe123"
Include "conf.d/*.cfg.lua"
这是我的sip-communicator.properties:
org.jitsi.impl.neomedia.transform.srtp.SRTPCryptoContext.checkReplay=false
org.jitsi.videobridge.NAT_HARVESTER_LOCAL_ADDRESS=127.0.0.1
org.jitsi.videobridge.NAT_HARVESTER_PUBLIC_ADDRESS=192.168.43.110
请有任何帮助或想法吗?谢谢。
这种情况不会立即起作用。我们使用JICOFO作为焦点,这是与JVB和用户的实体"交谈"。这是它的工作原理(我假设您在网络环境上,因为您提到了strophe.js(:
- 用户通过XMPP connnect
- 用户joing muc
- jicofo是管理员,并且正在jo jo
- 另一个用户加入MUC
- Jicofo使用Colibri协议请求来自JVB的音频/视频频道
- jicofo构成了一个叮当节,并通过MUC直接消息将其发送给每个参与者
- 用户获得叮当节并将其转换为SDP
- 用户可以使用该远程SDP 来设置WEBRTC PeerConnection
- 利润?: - (
希望有帮助。免责声明:我在Jitsi上工作。