Eugene Koifman created HIVE-17647:
-------------------------------------
Summary: DDLTask.generateAddMmTasks(Table tbl) should not start
transactions
Key: HIVE-17647
URL: https://issues.apache.org/jira/browse/HIVE-17647
Project: Hive
Issue Type: Sub-task
Components: Transactions
Reporter: Eugene Koifman
This method has
{noformat}
if (txnManager.isTxnOpen()) {
mmWriteId = txnManager.getCurrentTxnId();
} else {
mmWriteId = txnManager.openTxn(new Context(conf), conf.getUser());
txnManager.commitTxn();
}
{noformat}
this should throw if there is no open transaction. It should never open one.
In general the logic seems suspect. Looks like the intent is to move all
existing files into a delta_x_x/ when a plain table is converted to MM table.
This seems like something that needs to be done from under an Exclusive lock to
prevent concurrent Insert operations writing data under table/partition root.
But this is too late to acquire locks which should be done from the
Driver.acquireLocks() (or else have deadlock detector since acquiring them
here would bread all-or-nothing lock acquisition semantics currently required
w/o deadlock detector)
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)