Xrdp

摘要:
Xrdp是一个开源工具,允许用户通过Windows RDP访问Linux远程桌面。Xrdp现在支持TLS安全层。Xrdp需要Xrdp和xorgxrdp数据包才能侦听3389/tcp。确保防火墙接受连接。在本文中,我将向您展示如何使用Xrdp工具从Windows计算机远程连接到Ubuntu桌面。Xrdp使用端口3389,因此请确保打开它。UFW在默认情况下被禁用,因此您需要启用防火墙并为Xrdp创建规则linuxidc@linuxidc:~$sudoufwena

您多久访问一次Linux桌面? 您使用什么工具来访问远程桌面?

Xrdp是一个开源工具,允许用户通过Windows RDP访问Linux远程桌面。 除了Windows RDP之外,xrdp工具还接受来自其他RDP客户端的连接,如FreeRDP,rdesktop和NeutrinoRDP。 Xrdp现在支持TLS安全层。

Xrdp要求

  • xrdp和xorgxrdp包
  • 监听3389/tcp。 确保您的防火墙接受连接

在本文中,我将展示如何使用Xrdp工具从Windows机器远程连接到Ubuntu桌面。

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

1)在Linux上安装

在Ubuntu 18.04/Ubuntu 18.10上

首先,您需要在Ubuntu上安装Xrdp

apt install xrdp

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

您必须配置polkit规则以避免在Windows上的xrdp登录屏幕上输入用户名和密码后进行身份验证弹出窗口

linuxidc@linuxidc:~$ sudo nano /etc/polkit-1/localauthority.conf.d/02-allow-colord.conf

polkit.addRule(function(action, subject) {
if ((action.id == “org.freedesktop.color-manager.create-device” || action.id == “org.freedesktop.color-manager.create-profile” || action.id == “org.freedesktop.color-manager.delete-device” || action.id == “org.freedesktop.color-manager.delete-profile” || action.id == “org.freedesktop.color-manager.modify-device” || action.id == “org.freedesktop.color-manager.modify-profile”) && subject.isInGroup(“{group}”))
{
return polkit.Result.YES;
}
});

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

重启xrdp服务

linuxidc@linuxidc:~$ sudo systemctl restart xrdp

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

然后确保该服务正在运行

linuxidc@linuxidc:~$ systemctl status xrdp
● xrdp.service - xrdp daemon
  Loaded: loaded (/lib/systemd/system/xrdp.service; enabled; vendor preset: ena
  Active: active (running) since Mon 2018-10-29 21:16:31 CST; 2min 0s ago
    Docs: man:xrdp(8)
          man:xrdp.ini(5)
  Process: 5543 ExecStop=/usr/sbin/xrdp $XRDP_OPTIONS --kill (code=exited, statu
  Process: 5565 ExecStart=/usr/sbin/xrdp $XRDP_OPTIONS (code=exited, status=0/SU
  Process: 5557 ExecStartPre=/bin/sh /usr/share/xrdp/socksetup (code=exited, sta
 Main PID: 5566 (xrdp)
    Tasks: 1 (limit: 2305)
  Memory: 1.2M
  CGroup: /system.slice/xrdp.service
          └─5566 /usr/sbin/xrdp

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

现在确保在系统启动时自动启动服务

linuxidc@linuxidc:~$ systemctl enable xrdp
Synchronizing state of xrdp.service with SysV service script with /lib/systemd/systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable xrdp
PolicyKit daemon disconnected from the bus.
We are no longer a registered authentication agent.
Failed to reload daemon: Message recipient disconnected from message bus without replying
PolicyKit daemon disconnected from the bus.
We are no longer a registered authentication agent.
Failed to reload daemon: Message recipient disconnected from message bus without replying
PolicyKit daemon disconnected from the bus.
We are no longer a registered authentication agent.
Failed to enable unit: Message recipient disconnected from message bus without replying

现在您需要检查您的IP地址,因为您将需要它来进行连接

linuxidc@linuxidc:~$ ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
      valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
      valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
    link/ether 00:0c:29:e4:b3:cf brd ff:ff:ff:ff:ff:ff
    inet 192.168.182.146/24 brd 192.168.182.255 scope global dynamic noprefixroute ens33
      valid_lft 1116sec preferred_lft 1116sec
    inet6 fe80::3f83:c7da:950a:e08/64 scope link noprefixroute
      valid_lft forever preferred_lft forever

我的IP地址是192.168.182.146。 所以请记住。

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

Xrdp使用端口3389,所以一定要打开它。 默认情况下禁用UFW,因此您需要启用防火墙并为xrdp创建规则

linuxidc@linuxidc:~$ sudo ufw enable
[sudo] linuxidc 的密码:
在系统启动时启用和激活防火墙
linuxidc@linuxidc:~$ sudo ufw allow 3389/tcp
规则已添加
规则已添加 (v6)

如果这时候出现所说的Ubuntu安中装的xrdp,桌面共享设置为允许,虚拟机设置的是桥接,虚拟机内外可以互相ping 通;
在Windows下用 mstsc 连接Ubuntu桌面,跳出账号密码页面,登录后自动退出(闪退)的解决方法:

sudo apt-get install xfce4
echo xfce4-session > ~/.xsession
touch .session
sudo vim /etc/xrdp/startwm.sh
在. /etc/X11/Xsession前面加
xfce4-session

然后重启 sudo service xrdp restart。

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

现在,您可以在Windows端继续配置。

CentOS/RedHat 7上

确保之前安装了Epel存储库

# rpm -Uvh https://dl.Fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

Xrdp - 通过Windows的RDP连接Ubuntu Linux远程桌面

现在安装xrdp包

# yum update && yum -y install xrdp tigervnc-server

Xrdp - 通过Windows的RDP连接Ubuntu Linux远程桌面

在防火墙中添加规则。 CentOS/RedHat不是ufw,而是firewalld来配置

[root@localhost ~]# firewall-cmd --permanent --zone=public --add-port=3389/tcp
success

然后重新加载防火墙
[root@localhost ~]# firewall-cmd --reload
success

现在启用并重新启动xrdp服务
[root@localhost ~]# systemctl enable xrdp && systemctl restart xrdp
Created symlink from /etc/systemd/system/multi-user.target.wants/xrdp.service to /usr/lib/systemd/system/xrdp.service.

检查您的IP地址以获取Windows上的远程连接

[root@localhost ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
      valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
      valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 00:0c:29:93:77:6f brd ff:ff:ff:ff:ff:ff
    inet 192.168.182.148/24 brd 192.168.182.255 scope global noprefixroute dynamic ens33
      valid_lft 1285sec preferred_lft 1285sec
    inet6 fe80::72bf:712e:7c0b:ca6d/64 scope link noprefixroute
      valid_lft forever preferred_lft forever
3: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
    link/ether 52:54:00:02:67:f9 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
      valid_lft forever preferred_lft forever
4: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN group default qlen 1000
    link/ether 52:54:00:02:67:f9 brd ff:ff:ff:ff:ff:ff

2)从Windows连接

在我们的Windows机器上,例如Windows 10,启动默认的远程桌面连接工具。

输入IP地址和用户名

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

您需要输入机器的IP地址,系统会要求您输入用户名

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

Ubuntu上的

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

访问CentOS的远程桌面

现在确认信息并启动连接。 如果您未在本地注销,则远程登录将失败。现在您将被要求输入密码

Xrdp - 通过Windows的RDP连接Linux远程桌面(Ubuntu/CentOS/Redh

现在确认您的凭据。 您可以在顶部和登录页面上看到我的Ubuntu的IP地址, 输入您的密码连接。

如果你知道还有他工具, 请在评论里告知我们。

Linux公社的RSS地址:https://www.linuxidc.com/rssFeed.aspx

本文永久更新链接地址https://www.linuxidc.com/Linux/2018-10/155073.htm

免责声明:文章转载自《Xrdp》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇vue+vant+js实现购物车原理小demo(基础版)Angular 学习笔记 (version 6 小笔记)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Linux目录及常用命令

Linux目录1. bin.用于存放可执行的二进制文件(ll,mkdir)2. boot 存放用于系统引导时使用的各种文件3. dev 用于存放设备文件 如打印机4. etc.存放系统配置文件 如MySQL的配置文件5. home. 存放所有用户的根目录 user6. lib 存放跟文件系统汇总的程序运行所需要的共享库及内核模块 依赖如Spring Spr...

SQL Serve允许远程连接的解决方法

(一)用户需要做的第一件事是检查SQL数据库服务器中是否允许远程链接。在SQL 2008服务器中可以通过打开SQL Server 2008管理项目(SQL Server 2008 Management Studio,)来完成这项检查。其具体操作为: (1)右击SQL Server 2008选项,选择SQL Server 2008 Management St...

win2008 安装 配置 mysql

安装的是windows Server 2008 R2 操作系统  按照国际管理,安装了数据库 MYSQL 5.0.    一路顺利,可以通过外部连接MYSQL的时候出现了问题,无论如何也连接不上  发现这方面的资料很少,几经摸索,终于知道是防火墙的问题    解决方法如下:  选择:网络->windows 防火墙->高级设置->入站规则 ...

初识linux

linux: ifconfig = ip add 查看IP 改IP : dhclient(自动获取ip) ip add 静态 vi /etc/sysconfig/networkscripts/ifcfg-ens33 INSERT BOOTPROTO=static onboot =yes IPADDR=ip地址 NETMASK=255.255.255.0...

SOCKS5协议

SOCKS5 是一个代理协议,这种协议对本身所代理的内容并不关心,可用于穿越防火墙。 例如我有一台web服务器,用户可以登陆上去查询公司的关键数据,这样的服务器我肯定是不想放到公网上让别人能随便访问,但是有时候我在外地又想登录上去。所以我就把这台服务器放置在内网,所有的对外接口由另外一台安装了防火墙的服务器提供。 我在这台有防火墙的服务器上安装SOCKS5代...

防火墙规则修改

防火墙规则netsh advfirewall firewall命令 命令 说明 add 添加新入站或出站防火墙规则 delete 删除所有匹配的防火墙规则 set 为现有规则的属性设置新值 show 显示指定的防火墙规则 add rule命令 netsh advfirewall firewall add rule name=...