基本介绍:

Guacamole 是一个基于 HTML 5 和 JavaScript 的 VNC 查看器,服务端基于 Java 的 VNC-to-XML 代理开发。要求浏览器支持HTML5

 

Apache Guacamole is a clientless remote desktop gateway. It supports standard protocols like VNC, RDP, and SSH.

We call it clientless because no plugins or client software are required.

Thanks to HTML5, once Guacamole is installed on a server, all you need to access your desktops is a web browser.

Apache Guacamole 是一个无客户端远程桌面网关。支持标准协议,如VNC、RDP、SSH。称他为无客户端,是因为没有插件和客户端软件被要求。由于HTML5,一旦Guacamole 被安装到服务端,通过web 浏览器就可以访问你的桌面。

 

改进:

  • RDP 增加对声音的支持
  • 对 UI 进行重新设计
  • 显著提升了对移动设备的支持
  • 文档改为在线图书格式

 

配置:

  /etc/sysconfig/guaca

 

 

命令:

  guacd    

  Guacamole proxy daemon,guacamole-server一部分, built along with libguac and all protocol support by the guacamole-server package.

  通过man guacd查看更多信息。

guacd(8)                           Guacamole                          guacd(8)

NAME
       guacd - Guacamole proxy daemon

SYNOPSIS
       guacd [-b HOST] [-l PORT] [-p PID FILE] [-L LOG LEVEL] [-C CERTIFICATE FILE] [-K KEY FILE] [-f]

DESCRIPTION
       guacd is the Guacamole proxy daemon used by the Guacamole web application and framework. As JavaScript cannot handle binary protocols (like VNC
       and remote desktop) efficiently, a new text-based protocol was developed which would contain a common superset of  the  operations  needed  for
       efficient  remote  desktop access, but would be easy for JavaScript programs to process.  guacd is the proxy which translates between arbitrary
       protocols and the Guacamole protocol.

OPTIONS
       -b HOST
              Changes the host or address that guacd listens on.

       -l PORT
              Changes the port that guacd listens on (the default is port 4822).

       -p FILE
              Causes guacd to write the PID of the daemon process to the specified file. This is useful for init scripts and is used by  the  provided
              init script.

       -L LEVEL
              Sets  the  maximum  level  at  which guacd will log messages to syslog and, if running in the foreground, the console.  Legal values are
              debug, info, warning, and error.  The default value is info.

       -f     Causes guacd to run in the foreground, rather than automatically forking into the background.

SSL/TLS OPTIONS

     If libssl was present at the time guacd was compiled, it will contain SSL/TLS support, and connections between the web application and guacd
     can be encrypted if a certificate file is given.

     When using a chain of certificates, you must append the additional certificates to your server certificate. This can be done easily with the
     standard cat command. Beware that the certificate for guacd must be the first certificate in the file.

     -C CERTIFICATE FILE
     Enables SSL/TLS using the given cerficiate file. Future connections to this instance of guacd will require SSL/TLS enabled in the client
     (the web application). If this option is not given, communication with guacd must be unencrypted.

     -K KEY FILE
     Enables SSL/TLS using the given private key file. Future connections to this instance of guacd will require SSL/TLS enabled in the
     client (the web application). If this option is not given, communication with guacd must be unencrypted.

 SEE ALSO
     guacd.conf(5)

 AUTHOR
     Written by Michael Jumper <mike.jumper@guac-dev.org>

 

guacd.conf

  

NAME
       /etc/guacamole/guacd.conf - Configuration file for guacd

DESCRIPTION
       /etc/guacamole/guacd.conf  is the configuration file for the Guacamole proxy daemon used by the Guacamole web application and framework, guacd.
       Use of this file is entirely optional, and all of its options can be specified from the command line when running guacd.  If you  provide  both
       the guacd.conf file and command line options, the command line options will take precedence.

SYNTAX
       guacd.conf  is  made  up  of sections, where each section contains a set of parameter/value pairs. The parameters available are dictated by the
       section in use, and parameters may only be specified within a section.

       The beginning of each section is denoted with a section name in brackets, and each section ends implicitly with the beginning of a new section,
       or at the end of the file.

       [server]
              Contains parameters which control how guacd behaves as a server, from a network perspective.

       [daemon]
              Parameters which configure how guacd behaves as a daemon, such as what file should contain the PID, if any.

       [ssl]  Parameters  which  control the SSL support of guacd, such as the certificate and private key used for encryption of the Guacamole proto-
              col. This section and its parameters are only valid if guacd was built with SSL support.

       Parameters within sections are written as a parameter name, followed by an equals sign, followed by the parameter value, all on one line.  Com-
       ments may be placed anywhere, and consist of arbitrary text following a # symbol until end-of-line:

       name = value # Some arbitrary comment text

       Beware  that  it  is  the  combination  of the section name with the parameter name that makes up the fully qualified name of a parameter. Each
       parameter absolutely must be placed only within its proper section, or guacd.conf will fail to be parsed, and guacd will not start.

     If special characters need to be placed within a parameter value, such as whitespace, #, ", or \, the entire value must be enclosed in double
     quotes, and each occurrence of " or \ within the value must be escaped with backslashes:


     name = "quoted # value \\ with \" special characters"


SERVER PARAMETERS
     bind_host = HOSTNAME
     Requires guacd to bind to a specific host when listening for connections. By default, guacd will bind to localhost only.


     bind_port = PORT
     Requires guacd to bind to a specific port when listening for connections. By default, guacd will bind to port 4822.


DAEMON PARAMETERS
     log_level = LEVEL
     Sets the maximum level at which guacd will log messages to syslog and, if running in the foreground, the console. Legal values are
     debug, info, warning, and error. The default value is info.


     pid_file = FILE
     Causes guacd to write its PID to the specified file upon startup. Note that guacd must have sufficient privileges to create or write
     this file, or it will fail to start. This parameter is typically needed for startup scripts, such that the script can report on the sta-
     tus of guacd and kill it if necessary.


SSL PARAMETERS
     If guacd was built with SSL support, then connections between the web application and guacd can be encrypted if an SSL certificate and key file
     are given.


     When using a chain of certificates, you must append the additional certificates to your server certificate. This can be done easily with the
     standard cat command. Beware that the certificate for guacd must be the first certificate in the file.

 

     server_certificate = CERTIFICATE FILE
       Enables SSL/TLS using the given cerficiate file. Future connections to guacd will require SSL/TLS enabled in the client (the web appli-
cation).

     server_key = KEY FILE
       Enables SSL/TLS using the given private key file. Future connections to guacd will require SSL/TLS enabled in the client (the web appli-
cation).

EXAMPLE
     #
     # guacd.conf example
     #

     [daemon]

     pid_file = /var/run/guacd.pid

     [server]

     bind_host = localhost
     bind_port = 4822

     [ssl]

     server_certificate = /etc/ssl/certs/guacd.crt
     server_key = /etc/ssl/private/guacd.key

AUTHOR
     Written by Michael Jumper <mike.jumper@guac-dev.org>

 

  

日志:

  /var/log/messages

 

缺省端口号:4822

 

打包:

编译:

部署:

 

只要安装三个rpm包:

 

FAQ:

  Q1. 访问远程桌面,失败,在/var/log/messages 文件中出现如下日志:

    Feb 23 00:12:43 localhost guacd[2939]: Protocol "rdp" selected
    Feb 23 00:12:43 localhost guacd[2939]: Connection ID is "$2deb5a3e-8a6c-4cd5-8123-4d68a9af985a"
    Feb 23 00:12:43 localhost guacd[2939]: No security mode specified. Defaulting to RDP.
    Feb 23 00:12:43 localhost guacd[2939]: Loading keymap "base"
    Feb 23 00:12:43 localhost guacd[2939]: Loading keymap "en-us-qwerty"
    Feb 23 00:12:43 localhost guacd[2939]: Failed to load cliprdr plugin. Clipboard will not work.
    Feb 23 00:12:43 localhost guacd[2939]: Error connecting to RDP server
    Feb 23 00:12:43 localhost guacd[2939]: Connection did not succeed

    A: 验证config中的ip能够访问。

 

  Q2: /var/log/messages  如下问题:

2017-02-27T19:42:58.103149+08:00 info daemon vClass-ftYDC guacd[65887]:  Protocol "rdp" selected
2017-02-27T19:42:58.611918+08:00 info daemon vClass-ftYDC guacd[65887]:  Connection ID is "$e5990f8a-5d91-443a-aca4-21b331ccbf9a"
2017-02-27T19:42:58.612866+08:00 info daemon vClass-ftYDC guacd[65887]:  No security mode specified. Defaulting to RDP.
2017-02-27T19:42:58.616809+08:00 info daemon vClass-ftYDC guacd[65887]:  Loading keymap "base"
2017-02-27T19:42:58.616868+08:00 info daemon vClass-ftYDC guacd[65887]:  Loading keymap "en-us-qwerty"
2017-02-27T19:42:58.695393+08:00 warning daemon vClass-ftYDC guacd[65887]:  Failed to load cliprdr plugin. Clipboard will not work.
2017-02-27T19:42:58.792808+08:00 warning daemon vClass-ftYDC guacd[65887]:  Failed to load guacdr plugin. Drive redirection and printing will not work. Sound MAY not work.
2017-02-27T19:42:58.795447+08:00 warning daemon vClass-ftYDC guacd[65887]:  Failed to load guacsnd alongside guacdr plugin. Sound will not work. Drive redirection and printing MAY not work.

    A2: 由于远程机器的防火墙的问题。

 

  

  Q3. 生成rpm,在安装时,出现

    /sbin/ldconfig: /lib/libgcc-4.4.5.so 不是 ELF 文件 - 它起始的魔数错误。

    /sbin/ldconfig: /usr/lib64/libreadline.so.5 不是符号连接

 

参考:

  1.  官网:http://guacamole.incubator.apache.org/

  2.  Guacamole on Fedora and CentOS/RHEL 6

  3.  http://pkgs.fedoraproject.org/cgit/rpms/guacamole-server.git/

  4.  http://rpm.pbone.net/index.php3/stat/4/idpl/31089280/dir/fedora_other/com/guacamole-0.9.8-1.fc23.noarch.rpm.html

  5.  源码: https://github.com/apache/incubator-guacamole-server

  

posted on 2017-02-21 19:48  doscho  阅读(7263)  评论(0编辑  收藏  举报