我正在尝试为我的一个项目创建一个poc,它允许我使用odbc连接字符串连接到hive。
我已经成功地使用dsn方法连接到hive。但这对我不起作用,因为我需要允许在运行时创建连接,在运行时连接源可以从一个主机更改到另一个主机。
我正在使用下面的连接字符串(使用microsoftobc驱动程序),这是我从http://www.codeproject.com/tips/738141/how-to-communicate-to-hadoop-via-hive-using-net-cs
var conn = new OdbcConnection {
ConnectionString = @
"DRIVER={Microsoft Hive ODBC Driver};
Host=<IP>;
Port=10000;
User Name=root;Password=<PWD>;
Database=default;
HiveServerType=2;
ApplySSPWithQueries=1;
TrustedCerts=C:\Program Files\Microsoft Hive ODBC Driver\lib\cacerts.pem;
AsyncExecPollInterval=100;
AuthMech=0;
CAIssuedCertNamesMismatch=0;"
}
using(conn) {
conn.Open();
DataTable dt = new DataTable();
OdbcCommand cmd = conn.CreateCommand();
cmd.CommandText =
"SELECT * FROM categories;";
DbDataReader dr = await cmd.ExecuteReaderAsync();
dt.Load(dr);
}
当我试图打开连接时,网络超时。
ERROR [HY000] [Microsoft][HiveODBC] (34) Error from Hive: ETIMEDOUT.
我不知道怎么解决这个问题。
2条答案
按热度按时间8dtrkrch1#
我找到了解决办法。您缺少用户名,连接字符串中的pwd更改如下:
t40tm48m2#
在浏览了这篇博文的信息后,我发现它起了作用。
这是我使用的连接字符串。