百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Guacamole安装部署

lipiwang 2025-05-15 19:03 6 浏览 0 评论

Guacamole安装部署

Guacamole简介

Guacamole是提供连接远程桌面的解决方案的开源项目(也可以说是一个远程桌面网关),通过浏览器就能远程操作服务器,适用于Chrome、Firefox、IE9+等浏览器(浏览器需要支持HTML5), 由于使用 HTML5,你可以通过浏览器在任何终端访问Guancamole从而去访问你所需要访问的主机。

其包括许多组件,架构图如下所示,核心组件为Guacamole和guacd


guacd

guacd是Guacamole的核心,插件式的动态支持远程桌面协议,根据Web应用程序发来的指令连接到远程桌面。

guacd是和Guzcamole一起被安装到机器的,以驻留后台进程形式提供代理服务,接收来自Web应用程序的Tcp连接。guacd同样也不知道具体的远程桌面协议,它只是需要决定加载那个插件并且传送特定的参数给插件。(这个插件就是用来解析具体远程桌面协议的)一旦这个插件被加载,插件就独立于guacd运行,对Web应用程序和自己之间的会话(conmunication)具有绝对的控制权,直到插件被关闭。

Web应用程序

在Guacamole中与用户打交道的就是Web应用程序。Web应用程序自己不实现任何的远程桌面协议。Web应用程序依赖guacd,只负责前端界面以及权限认证以及资源管理等


guacamole程序的流程如下:用户通过浏览器连接到Guacamole的服务端,Guacamole的客户端是用javascript编写的,Guacamole Server通过Web容器(比如Tomcat)把服务提供给用户。一旦加载,客户端通过http承载着Guacamole自己的定义的协议与服务端通信。部署在Guacamole Server这边的Web应用程序,解析到的Guacamole protocal,就传给Guacamole的代理guacd,这个代理(guacd)实际上就是解析Guacamole protocal,替用户连接到远程机器,Guacamole protocal协议本身以及guacd的存在,实现了协议的透明:Guacamole客户端(浏览器运行的JS)和Web应用程序,都不需要知道远程桌面具体用哪个协议(VNC,RDP etc)


安装过程


我们的安装环境操作系统为

CentOS Linux release 7.5.1804


Guacamole有2个部分: Guacamole-server: 提供代理和相关依赖库 guacamole-client: 提供服务端容器(如Tomcat)运行的客户端 Guacamole-client可以直接使用二进制程序, 但Guacamole-server就需要通过源码按照了

必选依赖: yum install libjpeg-turbo-devel cairo-devel libjpeg-devel libpng-devel uuid-devel autoconf automake libtool xmvn freerdp-devel

可选依赖: 不同的远程连接协议需要的依赖也不一样: VNC: libvncserver-devel, RDP: freerdp-devel - 1.0 or higher, SSH: libssh2-devel,openssl, pango-devel

我们使用的参数


yum install libjpeg-turbo-devel cairo-devel libjpeg-devel libpng-devel uuid-devel autoconf automake libtool xmvn freerdp-devel libvncserver-devel libwebp-devel libvorbis-devel pulseaudio-libs-devel libssh2-devel pango-devel ffmpeg-devel


yum install tomcat maven -y


tar -xzf guacamole-server-0.9.14.tar.gz
cd guacamole-server-0.9.14/
./configure --with-init-dir=/etc/init.d
make
make install

cd ..


tar -xzf guacamole-client-0.9.14.tar.gz
cd guacamole-client-0.9.14/
mvn package
cp guacamole/target/guacamole-0.9.14.war /var/lib/tomcat/webapps/guacamole.war
guacamole-client不编译从官网下载guacamole.war包也可systemctl start tomcatsystemctl enable tomcat/etc/init.d/guacd startchkconfig --add guacdchkconfig  guacd on安装配置Guacamole默认方式为从user-mapping.xml读取所有的用户和连接. 这种方式适合最小化部署 配置简单 我们不采用这种方式,采用数据库验证方式无论使用何种身份验证方法,Guacamole的配置总是由两个主要部分组成:一是GUACAMOLE_HOME环境变量,它是配置文件的主要搜索位置,二是guacamole.properties文件,它是Guacamole及其扩展使用的主配置文件默认配置文件路径为/etc/guacamole$GUACAMOLE_HOME目录中包含如下文件: guacamole.properties: 决定Guacamole如何连接到guacd, 也可以定义插件 api-session-timeout: 单位: 分钟 默认: 60 Guacamole会话的空连接时间 guacd-host: Guacamole代理的监听地址, 默认localhost guacd-port: Guacamole代理的监听端口, 默认4822 guacd-ssl: Web应用和guacd之间是否使用SSL/TLS, 默认false logback.xml: Guacamole使用Logabck来记录日志, 默认记录到console, 也可以指定自己的Logback配置文件 服务代理程序默认会记录日志.extensions目录 存放Guacamole的插件, 启动时默认会加载所有以.jar结尾的文件 lib目录Guacamole会在这里寻找插件所需要的依赖, 该目录下的.jar文件对所有插件可读创建guacamole配置文件和目录mkdir /etc/guacamole/mkdir /etc/guacamole/extensionsmkdir /etc/guacamole/libcp extensions/guacamole-auth-jdbc/modules/guacamole-auth-jdbc-mysql/target/guacamole-auth-jdbc-mysql-0.9.14.jar /etc/guacamole/extensions/下载mysql-connector-java 放到指定位置cp mysql-connector-java-8.0.13.jar /etc/guacamole/lib/创建propertiesvim  /etc/guacamole/guacamole.propertiesmysql-hostname: localhostmysql-port: 3306mysql-database: guacamole_dbmysql-username: guacamolemysql-password: guacamole目录结构如下。配置数据库yum install maridb mariadb-server -ysystemctl start mariadbsystemctl enable mariadbmysql_secure_installation创建数据库CREATE DATABASE guacamole_dbCREATE USER 'guacamole'@'localhost' IDENTIFIED BY 'guacamole';GRANT SELECT,INSERT,UPDATE,DELETE ON guacamole_db.* TO 'guacamole'@'localhost';FLUSH PRIVILEGES;quit导入数据结构cd ./extensions/guacamole-auth-jdbc/modules/guacamole-auth-jdbc-mysql/schemacat ./*.sql | mysql -u root -p guacamole_db配置环境变量vim /etc/profileGUACAMOLE_HOME=/etc/guacamoleexport GUACAMOLE_HOMEsource /etc/profile重启tomcatsystemctl restart tomcat使用配置添加连接访问http://192.168.79.132:8080/guacamole  登陆管理员账号guacadmin密码guacadmin 添加连接资源测试我们以添加VNC连接为例受控VNC配置为VNC认证方式,其他方式不通过在控制期间页面,可Ctrl+Alt+Shift 调出和关闭控制侧边栏新添加机器不能立即显示,需退出重新登陆即可显示功能介绍画质调整数值越小画质越差屏幕缩放屏幕大小会随着浏览器大小自动调整,在此基础上,可以手动调整网络模型为,客户端通过Guacamole去连接受控主机,不是直连支持VNC中继转发剪切板剪切板不支持中文的的拷贝本地往浏览器中服务器复制要先复制到Guacamole剪切板中 然后可以ctrl + C到服务器中服务器往本地复制可直接ctrl + C  ctrl + V传送文件VNC模式传送依赖于SFTP  windows无此功能,需安装第三方工具如freesshd安装之后如下配置 另外,要添加防火墙策略,放开端口Guacamole主机处作如下配置上传页面如下多显示器Guacamole界面VM界面权限和用户管理登陆管理员用户可执行,用户,会话,连接资源,全局配置等管理管理会话查看连接历史记录用户管理,我们可以创建用户,并给用户设置密码,属性,权限,以及可以连接哪些服务器资源等创建连接资源,并且可以创建主机资源组,方便管理注意事项若配置SHH终端出现显示错位,可下载一个等宽字体,放到服务器中即可新添加机器不能立即显示,需退出重新登陆即可显示若发送Ctrl+alt+del 需通过内置虚拟键盘发送

相关推荐

前端入门——css 网格轨道详细介绍

上篇前端入门——cssGrid网格基础知识整体大概介绍了cssgrid的基本概念及使用方法,本文将介绍创建网格容器时会发生什么?以及在网格容器上使用行、列属性如何定位元素。在本文中,将介绍:...

Islands Architecture(孤岛架构)在携程新版首页的实践

一、项目背景2022,携程PC版首页终于迎来了首次改版,完成了用户体验与技术栈的全面升级。作为与用户连接的重要入口,旧版PC首页已经陪伴携程走过了22年,承担着重要使命的同时,也遇到了很多问题:维护/...

HTML中script标签中的那些属性

HTML中的<script>标签详解在HTML中,<script>标签用于包含或引用JavaScript代码,是前端开发中不可或缺的一部分。通过合理使用<scrip...

CSS 中各种居中你真的玩明白了么

页面布局中最常见的需求就是元素或者文字居中了,但是根据场景的不同,居中也有简单到复杂各种不同的实现方式,本篇就带大家一起了解下,各种场景下,该如何使用CSS实现居中前言页面布局中最常见的需求就是元...

CSS样式更改——列表、表格和轮廓

上篇文章主要介绍了CSS样式更改篇中的字体设置Font&边框Border设置,这篇文章分享列表、表格和轮廓,一起来看看吧。1.列表List1).列表的类型<ulstyle='list-...

一文吃透 CSS Flex 布局

原文链接:一文吃透CSSFlex布局教学游戏这里有两个小游戏,可用来练习flex布局。塔防游戏送小青蛙回家Flexbox概述Flexbox布局也叫Flex布局,弹性盒子布局。它决定了...

css实现多行文本的展开收起

背景在我们写需求时可能会遇到类似于这样的多行文本展开与收起的场景:那么,如何通过纯css实现这样的效果呢?实现的难点(1)位于多行文本右下角的展开收起按钮。(2)展开和收起两种状态的切换。(3)文本...

css 垂直居中的几种实现方式

前言设计是带有主观色彩的,同样网页设计中的css一样让人摸不头脑。网上列举的实现方式一大把,或许在这里你都看到过,但既然来到这里我希望这篇能让你看有所收获,毕竟这也是前端面试的基础。实现方式备注:...

WordPress固定链接设置

WordPress设置里的最后一项就是固定链接设置,固定链接设置是决定WordPress文章及静态页面URL的重要步骤,从站点的SEO角度来讲也是。固定链接设置决定网站URL,当页面数少的时候,可以一...

面试发愁!吃透 20 道 CSS 核心题,大厂 Offer 轻松拿

前端小伙伴们,是不是一想到面试里的CSS布局题就发愁?写代码时布局总是对不齐,面试官追问兼容性就卡壳,想跳槽却总被“多列等高”“响应式布局”这些问题难住——别担心!从今天起,咱们每天拆解一...

3种CSS清除浮动的方法

今天这篇文章给大家介绍3种CSS清除浮动的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。首先,这里就不讲为什么我们要清楚浮动,反正不清除浮动事多多。下面我就讲3种常用清除浮动的...

2025 年 CSS 终于要支持强大的自定义函数了?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!1.什么是CSS自定义属性CSS自...

css3属性(transform)的一个css3动画小应用

闲言碎语不多讲,咱们说说css3的transform属性:先上效果:效果说明:当鼠标移到a标签的时候,从右上角滑出二维码。实现方法:HTML代码如下:需要说明的一点是,a链接的跳转需要用javasc...

CSS基础知识(七)CSS背景

一、CSS背景属性1.背景颜色(background-color)属性值:transparent(透明的)或color(颜色)2.背景图片(background-image)属性值:none(没有)...

CSS 水平居中方式二

<divid="parent"><!--定义子级元素--><divid="child">居中布局</div>...

取消回复欢迎 发表评论: