在我们使用ubuntu远程桌面时,会经常遇到这样的问题。在连接远程桌面时,我打开的是会话a,我在会话a下处理一些工作的事情。由于自己不小心把这个远程桌面给关闭了,或者今天工作完毕关闭该远程桌面会话。等再进行连接远程桌面时,发现ubuntu会给出一个新的远程桌面会话b,而不是我们刚刚连接过的那个会话a,或者是昨天连接的那个会话a。
以上这个问题,我们在实际的工作中是经常遇到的。
那么我们该如何解决这个问题呢?或者换一种说法,我们该如何再次连接到上一次的远程桌面会话a呢?
<b>注意:本篇文章中的ubuntu远程桌面全部是基于xrdp协议。</b>
要解决以上的问题,我们就要了解基于xrdp协议的ubuntu远程桌面与vncserver之间的关系。
为什么需要vncserver的支持呢?<b>是因为我们在通过3389端口连接ubuntu远程桌面时,xrdp会把所有通过3389端口数据都转发到vncserver的端口上,同时vncserver只监听127.0.0.1这个地址,所以vncserver的端口是不对外开放的。</b>
<b>除此之外,vncserver还为每一次远程桌面会话分配一个系统端口,注意这个端口很重要。</b><b></b>
<b>如果我们要连接上一次的远程桌面会话a的,我们只需要连接会话a所在vncserver端口即可。</b>
那么我们如何才能连接和查看这个vncserver端口呢?这就需要我们修改xrdp的相关配置。
为什么要讲解这个原理?是因为只有我们理解了这个原理,那么我们才能很容易的解决ubuntu远程桌面会话的问题,而且也能很容易的理解,我们对xrdp配置文件的相关修改。
xrdp配置文件有两个,分别是/etc/xrdp目录下的xrdp.ini和sesman.ini文件。
xrdp.ini配置文件,关键部分在globals,具体内容如下:
[globals]
bitmap_cache=yes 位图缓存
bitmap_compression=yes 位图压缩
port=3389 xrdp监听的端口(重要)
crypt_level=low 加密程度(low为40位,high为128位,medium为双40位)
channel_code=1
max_bpp=24 xrdp最大连接数
[xrdp1]
name=sesman-xvnc xrdp的连接模式
lib=libvnc.so
username=ask
password=ask
ip=127.0.0.1
port=-1
注意:在xrdp.ini配置文件中,需要注意max_bpp参数,这参数定义xrdp最大的连接数。
要解决本文所提出的问题,我们只需要修改sesman-xvnc模式中的port参数。修改后的prot参数,如下:
cat /etc/xrdp/xrdp.ini

sesman.ini配置文件,内容如下:
listenaddress=127.0.0.1 监听ip地址(默认即可)
listenport=3350 监听端口(默认即可)
enableuserwindowmanager=1 1为开启,可让用户自定义自己的启动脚本
userwindowmanager=startwm.sh
defaultwindowmanager=startwm.sh
[security]
allowrootlogin=1 允许root登陆
maxloginretry=4 最大重试次数
terminalserverusers=tsusers 允许连接的用户组(如果不存在则默认全部用户允许连接)
terminalserveradmins=tsadmins 允许连接的超级用户(如果不存在则默认全部用户允许连接)
[sessions]
maxsessions=10 每个用户最大会话数
killdisconnected=0 是否立即关闭断开的连接(如果为1,则断开连接后会自动注销)
idletimelimit=0 空闲会话时间限制(0为没有限制)
disconnectedtimelimit=0 断开连接的存活时间(0为没有限制)
[logging]
logfile=./sesman.log 登陆日志文件
loglevel=debug 登陆日志记录等级(级别分别为,core,error,warn,info,debug)
enablesyslog=0 是否开启日志
sysloglevel=debug 系统日志记录等级
现在我们来通过远程桌面来连接ubuntu,如下:
注意:图中标记出来的端口号
远程桌面连接进入后,打开终端创建一个文件test,如下:
test创建完毕后,然后关闭这个远程桌面连接。
注意:为了下面的演示效果,创建该文件的界面,我没有关闭。
此时我们再通过ssh登录进入ubuntu,查看此时vncserver所使用的端口,如下:
netstat –tunlp
ps -ef |grep 1673
通过上图,我们可以知道目前这个会话,vncserver使用的是5912这个端口。
现在我们修改下xrdp的配置文件xrdp.ini,如下:
sudo vi /etc/xrdp/xrdp.ini
以上修改完毕后,我们要重新启动xrdp,如下:
sudo /etc/init.d/xrdp restart
重启完毕后,我们再次连接远程桌面,如下:
注意:上图中的port端口,我们填写的是5912这个端口,也就是上边那个远程桌面会话vncserver所使用的端口。
远程桌面进去后,如下:
通过上图,我们可以很明显的看出,我们确实连接到了上次本关闭的那个远程桌面界面。
ps:如果不知道每一次的连接的端口的话,我们也可以通过上查看用户的xrdp日志进行查看。具体步骤,如下:
sudo cat /var/log/xrdp-sesman.log
通过xrdp日志查看用户启动xrdp的pid。
然后再根据pid,查看启动的xrdp进程,如下:
ps -ef |grep 1693
通过上图,基本可以看出此xrdp进程所使用的是5912端口。
为了更清晰的确认端口号,使用netstat命令,如下:
netstat -tunlp
通过上图,可以很明显的看出pid为1693的xrdp,使用的是5912 端口。
到此有关ubuntu远程桌面会话的问题全部结束。