jjzjj

连接HiveServer2的图形化工具SQuirrel和Dbeaver

小小明-代码实体 2023-04-09 原文

文章目录


本文介绍的工具可以通过下面链接下载:

链接:https://pan.baidu.com/s/19-EMQieTiqNmba4QzDlAsA
提取码:th23

SQuirrel SQL Client简介

SQuirrel SQL Client是一个用Java写的数据库客户端,用JDBC统一数据库访问接口以后,可以通过一个统一的用户界面来操作MySQL、PostgreSQL、MSSQL、Oracle、Hive等等任何支持JDBC访问的数据库。使用起来非常方便。SQuirrel SQL Client还是java的一个Swing程序,也算是Swing的一个比较成功的应用了。

通过SQuirrel SQL Client这个java写的图形化工具,就可以跨平台连接Hive,也包括了windows。

SQuirrel SQL Client的官网及下载地址为:http://squirrel-sql.sourceforge.net/#installation

目前最新版本的下载地址是:https://sourceforge.net/projects/squirrel-sql/files/1-stable/4.1.0/squirrel-sql-4.1.0-standard.jar/download

过几秒钟后会弹出真实下载链接:

https://jaist.dl.sourceforge.net/project/squirrel-sql/1-stable/4.1.0/squirrel-sql-4.1.0-standard.jar

注意:国内可能网速不佳,下载缓慢

视频演示

视频地址:https://www.bilibili.com/video/BV14541147XF/

安装SQuirrel SQL Client

我是之前下载的4.0.0的版本。如果你使用官网提供的exe安装包双击安装的JDK,那么你下载后只需要双击squirrel-sql-4.0.0-standard.jar,即可启动安装程序。

但如果你按照我前面发布的视频中的方法,直接解压已经安装好的jdk并配置环境变量,那么就可能出现直接双击无法运行jar包的情况。

此时我们需要在命令行执行以下命令来启动安装程序:

java -jar squirrel-sql-4.0.0-standard.jar

然后不停的点击next,直到:

我们勾选简体中文,然后继续,后面的步骤,怎么选也无所谓。

启动hdfs和hiveserver2

安装完成之后,就可以开始配置连接hive了。

不过在此之前,我们先启动hdfs和hiveserver2:

C:\Users\Administrator>start-dfs

C:\Users\Administrator>hive --service hiveserver2

hiveserver2启动完成后就是这样。

可以通过http://localhost:10002/访问UI界面:

配置SQuirrel SQL Client

安装完成后,通过菜单搜索sql可以搜索到这个工具快速打开,然后开始配置:

地址示例写的是:

jdbc:hive2://<hostname>:10000/default

然后在附加类中添加:

D:\jdk\apache-hive-2.1.0-bin\jdbc\hive-jdbc-2.1.0-standalone.jar
D:\jdk\hadoop\share\hadoop\common\hadoop-common-2.7.2.jar
D:\jdk\hadoop\share\hadoop\common\lib\slf4j-api-1.7.10.jar
D:\jdk\hadoop\share\hadoop\common\lib\slf4j-log4j12-1.7.10.jar

具体根据你本地hive和hadoop的路径。

并在类名中添加:

org.apache.hive.jdbc.HiveDriver

然后单击确定即可。

此时准备开始连接hive,地址修改为正确的ip地址,本机可以为localhost:

测试一下:

登陆成功后即可查看hive表:

使用SQuirrel SQL Client访问hive

查询一下看看效果:

鼠标移动到的列会自动显示一些信息:

点击指定的值会只显示指定的值:

现在看一下Charts:

再点击open char window后会看到如下效果:

更多功能还需大家自行探索,先介绍到这里了。

hiveServer2的UI界面可以查看到已经被查询过的sql:

使用Cloudera提供的hive连接驱动进行连接

下载地址:

https://www.cloudera.com/downloads/connectors/hive/jdbc/2-6-10.html

可以修改下载其他版本。

我下载的是:

https://downloads.cloudera.com/connectors/ClouderaHiveJDBC-2.6.10.1012.zip

压缩包内的文件有点多,我选择只解压ClouderaHiveJDBC-2.6.10.1012.zip\ClouderaHiveJDBC-2.6.10.1012\ClouderaHiveJDBC4-2.6.10.1012下的HiveJDBC4.jar:

用Cloudera提供的驱动程序则只需要添加这一个驱动jar包即可,但类名记得修改为com.cloudera.hive.jdbc.HS2Driver

Dbeaver的安装及使用

DBeaver安装包下载地址:https://dbeaver.io/download/

可以选择安装版或zip解压版本:

我下载的zip版本:

https://dbeaver.io/files/dbeaver-ce-latest-win32.win32.x86_64.zip

解压后双击dbeaver.exe打开:

打开后创建hive连接:

填写正确的连接信息后,点击编辑驱动设置:

先删除原有的驱动:

然后再添加我们前面下载的Cloudera提供的hive连接驱动:

完成后,就可以查看hive的数据了:

点击sql查询器之后就可以开始进行sql查询了:

注意:Cloudera提供的Hive JDBC驱动不需要考虑驱动包依赖的问题,默认的将Hive驱动所依赖的包都打包在里面。驱动类需要指定为com.cloudera.hive.jdbc.HS2Driver,与原生的org.apache.hive.jdbc.HiveDriver有区别

有关连接HiveServer2的图形化工具SQuirrel和Dbeaver的更多相关文章

  1. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  2. ruby - 无法在 60 秒内获得稳定的 Firefox 连接 (127.0.0.1 :7055) - 2

    我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类

  3. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

  4. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

  5. ruby-on-rails - 连接字符串时如何在 <%=%> block 内输出 html_safe? - 2

    考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://

  6. ruby - Faye WebSocket,关闭处理程序被触发后重新连接到套接字 - 2

    我有一个super简单的脚本,它几乎包含了FayeWebSocketGitHub页面上用于处理关闭连接的内容:ws=Faye::WebSocket::Client.new(url,nil,:headers=>headers)ws.on:opendo|event|p[:open]#sendpingcommand#sendtestcommand#ws.send({command:'test'}.to_json)endws.on:messagedo|event|#hereistheentrypointfordatacomingfromtheserver.pJSON.parse(event.d

  7. ruby-on-rails - 什么会导致与 APNS 的连接间歇性断开连接? - 2

    我有一个ruby​​脚本可以打开与Apple推送服务器的连接并发送所有待处理的通知。我看不出任何原因,但当Apple断开我的脚本时,我遇到了管道损坏错误。我已经编写了我的脚本来适应这种情况,但我宁愿只是找出它发生的原因,这样我就可以在第一时间避免它。它不会始终根据特定通知断开连接。它不会以特定的字节传输大小断开连接。一切似乎都是零星的。您可以在单个连接上发送的数据传输或有效负载计数是否有某些限制?看到人们的解决方案始终保持一个连接打开,我认为这不是问题所在。我看到连接在3次通知后断开,我看到它在14次通知后断开。我从未见过它能超过14点。有没有人遇到过这种类型的问题?如何处理?

  8. ruby - 如何断开现有的 ruby​​ 续集与数据库的连接? - 2

    我的意思是之前建立的那个DB=Sequel.sqlite('my_blog.db')或DB=Sequel.connect('postgres://user:password@localhost/my_db')或DB=Sequel.postgres('my_db',:user=>'user',:password=>'password',:host=>'localhost')等等。Sequel::Database类没有名为“disconnect”的公共(public)实例方法,尽管它有一个“connect”。也许有人已经遇到过这个问题。我将不胜感激。 最佳答案

  9. ruby-on-rails - 遗留数据库的 ActiveRecord 连接表 - 2

    我有一个遗留数据库,我正在努力让ActiveRecord使用它。我遇到了连接表的问题。我有以下内容:classTvShow然后我有一个名为tvshowlinkepisode的表,它有2个字段:idShow、idEpisode所以我有2个表和它们之间的连接(多对多关系),但是连接使用非标准外键。我的第一个想法是创建一个名为TvShowEpisodeLink的模型,但没有主键。我的想法是,由于外键是非标准的,我可以使用set_foreign_key并进行一些控制。最后,我想说一些类似TvShow.find(:last).episodes或Episode.find(:last).tv_sho

  10. ruby - rails 3.2.2(或 3.2.1)+ Postgresql 9.1.3 + Ubuntu 11.10 连接错误 - 2

    我正在使用PostgreSQL9.1.3(x86_64-pc-linux-gnu上的PostgreSQL9.1.3,由gcc-4.6.real(Ubuntu/Linaro4.6.1-9ubuntu3)4.6.1,64位编译)和在ubuntu11.10上运行3.2.2或3.2.1。现在,我可以使用以下命令连接PostgreSQLsupostgres输入密码我可以看到postgres=#我将以下详细信息放在我的config/database.yml中并执行“railsdb”,它工作正常。开发:adapter:postgresqlencoding:utf8reconnect:falsedat

随机推荐