为远程桌面强制设置 xdmcp udp v4

为远程桌面强制设置 xdmcp udp v4

我正在尝试将远程桌面设置为 Debian Stretch 发行版,我设置了文件/etc/gdm3/daemon.conf.

[daemon]
WaylandEnable = false

[security]
DisallowTCP = false

[xdmcp]
Enable = true
Port = 177

[chooser]

[debug]
# Uncomment the line below to turn on debugging
# More verbose logs
# Additionally lets the X server dump core if it crashes
Enable = true

但是当我重新启动 debian 系统时,我在 netstat 上看到以下输出:

udp6       0      0 :::177                  :::*                                11059/gdm3    

那是使用 udp6 而不是 udp4。

我尝试使用以下几行禁用系统中的inet6 /etc/sysctl.conf

net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.lo.disable_ipv6 = 1

我使用 刷新设置sysctl -p,并使用 重新启动服务sudo init 3; sudo unit 5,但没有任何变化。我什至重新启动了虚拟机,但还是一样。

知道如何强制 xdcmp 监听 UDP v4 而不是 udp6 吗?提前致谢。

我这样做是为了弄清楚另一台具有相同Linux发行版的机器所需的设置,我想在其中设置对桌面的远程访问(所以,我会遇到同样的问题)。实际上我可以使用运行到其他主机的 xvnc 进行访问,但我想设置 xdmcp 来请求远程访问登录。

我正在运行的确切系统:

$ lsb_release -a
No LSB modules are available.
Distributor ID: Debian
Description:    Debian GNU/Linux 9.4 (stretch)
Release:    9.4
Codename:   stretch

$ apt-cache show gdm3
Package: gdm3
Version: 3.22.3-3+deb9u1
. . .

答案1

我想我已经找到了我的问题的答案。我已经下载了 gdm3 的源代码,并且找到了为 xdmcp 设置套接字的位置。

static gboolean
open_port (GdmXdmcpDisplayFactory *factory)
{
        struct sockaddr_storage serv_sa = { 0 };

        g_debug ("GdmXdmcpDisplayFactory: Start up on host %s, port %d",
                 factory->priv->hostname ? factory->priv->hostname : "(null)",
                 factory->priv->port);

        /* Open socket for communications */
#ifdef ENABLE_IPV6
        factory->priv->socket_fd = do_bind (factory->priv->port, AF_INET6, &serv_sa);
        if (factory->priv->socket_fd < 0)
#endif
                factory->priv->socket_fd = do_bind (factory->priv->port, AF_INET, &serv_sa);

        if G_UNLIKELY (factory->priv->socket_fd < 0) {
                g_warning (_("Could not create socket!"));
                return FALSE;
        }

        fd_set_close_on_exec (factory->priv->socket_fd);

        if (factory->priv->use_multicast) {
                setup_multicast (factory);
        }

        return TRUE;
}

从这里可以看出,如果包被构建为支持 IP6 并且绑定操作正确完成,则套接字将仅侦听 UDP6,而不侦听 UDP4。

解决方案应该在不支持 IP6 的情况下重建软件包,或者修改源代码,以便包含一个新参数来从文件中启用/禁用 IP6 /etc/gdm3/daemon.conf


从评论中更新了更多信息。

static int
create_socket (struct addrinfo *ai)
{
        int sock;

        sock = socket (ai->ai_family, ai->ai_socktype, ai->ai_protocol);
        if (sock < 0) {
                g_warning ("socket: %s", g_strerror (errno));
                return sock;
        }

#if defined(ENABLE_IPV6) && defined(IPV6_V6ONLY)
    if (ai->ai_family == AF_INET6) {
        int zero = 0;
        if (setsockopt(sock, IPPROTO_IPV6, IPV6_V6ONLY, &zero, sizeof(zero)) < 0)
            g_warning("setsockopt(IPV6_V6ONLY): %s", g_strerror(errno));
    }
#endif

        if (bind (sock, ai->ai_addr, ai->ai_addrlen) < 0) {
                g_warning ("bind: %s", g_strerror (errno));
                close (sock);
                return -1;
        }

        return sock;
}

我们可以在 proc 文件系统中看到以下内容:

$ cat /proc/sys/net/ipv6/bindv6only 
0

所以,看起来没有进行双重绑定。应该是因为定义了IPV6_V6ONLY。


重建不支持 ip6 的软件包后:

udp        0      0 0.0.0.0:177             0.0.0.0:*                           - 

相关内容