解决vnc view看不到图形界面的问题

本文介绍了解决VNCView无法正常显示远程Linux桌面图形界面的方法,包括配置xstartup文件、重启VNCServer服务及调整分辨率等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决vnc view看不到图形界面的问题

有时候用VNC View打开远程linux桌面时,桌面显示不出来,只有一个灰色背景加上一个命令行。这时候需要在vnc server上设置一下:
编辑 /root/.vnc/xstartup
[root@localhost ~]# vi /root/.vnc/xstartup

去掉下面两行的注释:
unset SESSION_MANAGER
exec /etc/X11/xinit/xinitrc

执行下面的命令重启vnc server
[root@localhost ~]# vncserver -kill :1
[root@localhost ~]# vncserver :1

如果要改变VNC server的分辨率 (默认的分辨率是1024×768):
1. 可以用一下命令启动VNC server
[root@localhost ~]# vncserver -geometry 1280×1024

这种修改,在重启机器以后就会丢失。

2. 也可以通过修改配置,使之重启以后也能生效:
[root@localhost ~]# vi /usr/bin/vncserver

修改下面这一行:
$geometry = “1280×1024″;


转自:http://blog.csuboy.com/vnc-view-fail-to-see-a-graphical-interface-problem/

### 如何在 Vue 2 项目中集成 noVNC 要在 Vue 2 项目中集成 noVNC,可以按照以下方法实现。noVNC 是一个基于 HTML5 的 VNC 客户端库,允许通过浏览器访问远程桌面服务。以下是详细的说明: #### 1. 添加 noVNC 到 Vue 项目 可以通过 npm 或直接引入 CDN 来安装 noVNC。 ##### 使用 npm 安装 运行以下命令来安装 noVNC: ```bash npm install novnc --save ``` 然后,在 Vue 组件中导入并初始化 noVNC: ```javascript import { RFB } from 'novnc/core/rfb'; export default { mounted() { const rfb = new RFB(document.getElementById('vncCanvas'), 'ws://your-vnc-server-url'); rfb.scaleViewport(true); rfb.viewOnly(false); // 设置为 false 表示可交互模式 } }; ``` 这里使用了 `RFB` 类作为核心接口[^1]。 ##### 使用 CDN 引入 如果不想通过 npm 安装,可以直接在 HTML 文件中添加如下脚本标签: ```html <script src="https://cdn.jsdelivr.net/npm/novnc/core/websock.js"></script> <script src="https://cdn.jsdelivr.net/npm/novnc/core/rfb.js"></script> ``` 随后可以在组件的生命周期钩子函数中实例化 `RFB` 对象。 #### 2. 配置 WebSocket 连接 noVNC 基于 WebSocket 协议连接到服务器。因此需要提供有效的 WebSocket 地址。例如: ```javascript const wsUrl = 'ws://localhost:6080/websocket'; // 替换为实际地址 rfb.connect(wsUrl, '', ''); // 参数分别为 WebSocket URL、用户名和密码 ``` 确保目标服务器支持 WebSocket 并正确配置防火墙规则[^2]。 #### 3. 渲染 Canvas 元素 noVNC 将其图形界面渲染在一个 `<canvas>` 元素上。需在模板文件中定义该元素: ```html <template> <div id="app"> <canvas id="vncCanvas" width="800" height="600"></canvas> </div> </template> ``` 此 `<canvas>` 元素会被 noVNC 自动检测并与之绑定。 #### 4. 处理事件 为了增强用户体验,可以监听一些重要事件,比如键盘输入或鼠标点击操作: ```javascript rfb.addEventListener('connect', () => { console.log('Connected to VNC server.'); }); rfb.addEventListener('disconnect', () => { console.error('Disconnected from VNC server.'); }); ``` --- ### 示例代码 完整的 Vue 2 组件可能看起来像这样: ```vue <template> <div id="app"> <h1>VNC Viewer</h1> <canvas id="vncCanvas" width="800" height="600"></canvas> </div> </template> <script> import { RFB } from 'novnc/core/rfb'; export default { mounted() { const canvas = document.getElementById('vncCanvas'); const rfb = new RFB(canvas, 'ws://your-vnc-server-url'); rfb.scaleViewport(true); rfb.viewOnly(false); rfb.addEventListener('connect', () => { console.log('Connected to VNC server.'); }); rfb.addEventListener('disconnect', () => { console.error('Disconnected from VNC server.'); }); }, }; </script> <style scoped> #vncCanvas { border: 1px solid black; } </style> ``` --- ### 注意事项 - 确保 WebSocket 地址有效且网络可达。 - 如果遇到跨域问题,请确认服务器启用了 CORS 支持。 - 测试环境建议先部署本地 VNC 服务以便调试[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值