Dávid Paksy created HBASE-29011:
-----------------------------------
Summary: Append REST endpoint invoked with not existing column
family or table returns Exception stack trace
Key: HBASE-29011
URL: https://issues.apache.org/jira/browse/HBASE-29011
Project: HBase
Issue Type: Bug
Components: REST
Affects Versions: 4.0.0-alpha-1
Reporter: Dávid Paksy
h2. Scenario
Calling append REST operation with not existing column family or table.
h2. Actual result
Returns Exception stack trace in response body - *NOK* (x)
h2. Expected result
Should not return the Exception stack trace in response body.
h2. How to reproduce
TestRowResource table does NOT exists:
{code:java}
curl -vi -X PUT \
-H "Content-type: application/json" \
-H "Accept: application/json" \
-d
'{"Row":[{"key":"dGVzdHJvdzE=","Cell":[{"column":"YTox","$":"dGVzdHZhbHVlMgo="},{"column":"YToy","$":"dGVzdHZhbHVlMTIK"}]}]}'
\
"http://localhost:8080/TestRowResourcea/testrow1?check=append"
* Host localhost:8080 was resolved.
* IPv6: ::1
* IPv4: 127.0.0.1
* Trying [::1]:8080...
* Connected to localhost (::1) port 8080
> PUT /TestRowResourcea/testrow1?check=append HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/8.9.1
> Content-type: application/json
> Accept: application/json
> Content-Length: 123
>
* upload completely sent off: 123 bytes
< HTTP/1.1 404 Not Found
HTTP/1.1 404 Not Found
< X-Frame-Options: DENY
X-Frame-Options: DENY
< X-Content-Type-Options: nosniff
X-Content-Type-Options: nosniff
< X-XSS-Protection: 1; mode=block
X-XSS-Protection: 1; mode=block
< Content-Type: text/plain
Content-Type: text/plain
< Transfer-Encoding: chunked
Transfer-Encoding: chunked
<
Not found
org.apache.hadoop.hbase.TableNotFoundException: TestRowResourcea
at java.base/java.lang.Thread.getStackTrace(Thread.java:1619)
at
org.apache.hadoop.hbase.util.FutureUtils.setStackTrace(FutureUtils.java:144)
at
org.apache.hadoop.hbase.util.FutureUtils.rethrow(FutureUtils.java:163)
at org.apache.hadoop.hbase.util.FutureUtils.get(FutureUtils.java:186)
at
org.apache.hadoop.hbase.client.TableOverAsyncTable.append(TableOverAsyncTable.java:325)
at org.apache.hadoop.hbase.rest.RowResource.append(RowResource.java:702)
at org.apache.hadoop.hbase.rest.RowResource.update(RowResource.java:183)
at org.apache.hadoop.hbase.rest.RowResource.put(RowResource.java:324)
...
{code}
Create TestRowResource table with column family "a".
Call append with column family "cf":
{code:java}
curl -vi -X PUT \
-H "Accept: text/xml" \
-H "Content-Type: text/xml" \
-d '<?xml version="1.0" encoding="UTF-8" standalone="yes"?><CellSet><Row
key="cm93NQo="><Cell column="Y2Y6ZQo=">dmFsdWU1Cg==</Cell></Row></CellSet>' \
"http://localhost:8080/TestRowResource/testrow1?check=append"
* Host localhost:8080 was resolved.
* IPv6: ::1
* IPv4: 127.0.0.1
* Trying [::1]:8080...
* Connected to localhost (::1) port 8080
> PUT /TestRowResource/testrow1?check=append HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/8.9.1
> Accept: text/xml
> Content-Type: text/xml
> Content-Length: 143
>
* upload completely sent off: 143 bytes
< HTTP/1.1 404 Not Found
HTTP/1.1 404 Not Found
< X-Frame-Options: DENY
X-Frame-Options: DENY
< X-Content-Type-Options: nosniff
X-Content-Type-Options: nosniff
< X-XSS-Protection: 1; mode=block
X-XSS-Protection: 1; mode=block
< Content-Type: text/plain
Content-Type: text/plain
< Transfer-Encoding: chunked
Transfer-Encoding: chunked
<
Not found
org.apache.hadoop.hbase.regionserver.NoSuchColumnFamilyException:
org.apache.hadoop.hbase.regionserver.NoSuchColumnFamilyException: Column family
cf does not exist in region
TestRowResource,,1732811650328.776b1d03b9852a83de1f77688b16865d. in table
'TestRowResource', {TABLE_ATTRIBUTES => {METADATA =>
{'hbase.store.file-tracker.impl' => 'DEFAULT'}}}, {NAME => 'a',
INDEX_BLOCK_ENCODING => 'NONE', VERSIONS => '1', KEEP_DELETED_CELLS => 'FALSE',
DATA_BLOCK_ENCODING => 'NONE', TTL => 'FOREVER', MIN_VERSIONS => '0',
REPLICATION_SCOPE => '0', BLOOMFILTER => 'ROW', IN_MEMORY => 'false',
COMPRESSION => 'NONE', BLOCKCACHE => 'true', BLOCKSIZE => '65536 B (64KB)'},
{NAME => 'b', INDEX_BLOCK_ENCODING => 'NONE', VERSIONS => '1',
KEEP_DELETED_CELLS => 'FALSE', DATA_BLOCK_ENCODING => 'NONE', TTL => 'FOREVER',
MIN_VERSIONS => '0', REPLICATION_SCOPE => '0', BLOOMFILTER => 'ROW', IN_MEMORY
=> 'false', COMPRESSION => 'NONE', BLOCKCACHE => 'true', BLOCKSIZE => '65536 B
(64KB)'}
at
org.apache.hadoop.hbase.regionserver.HRegion.checkFamily(HRegion.java:5376)
at
org.apache.hadoop.hbase.regionserver.HRegion.checkFamily(HRegion.java:5363)
at
org.apache.hadoop.hbase.regionserver.HRegion.checkFamilies(HRegion.java:5357)
at
org.apache.hadoop.hbase.regionserver.HRegion$BatchOperation.checkAndPrepareMutation(HRegion.java:3508)
at
org.apache.hadoop.hbase.regionserver.HRegion$BatchOperation.checkAndPrepareMutation(HRegion.java:3515)
at
org.apache.hadoop.hbase.regionserver.HRegion$MutationBatchOperation$1.visit(HRegion.java:3899)
at
org.apache.hadoop.hbase.regionserver.HRegion$BatchOperation.visitBatchOperations(HRegion.java:3394)
at
org.apache.hadoop.hbase.regionserver.HRegion$MutationBatchOperation.checkAndPrepare(HRegion.java:3878)
at
org.apache.hadoop.hbase.regionserver.HRegion.batchMutate(HRegion.java:4779)
at
org.apache.hadoop.hbase.regionserver.HRegion.batchMutate(HRegion.java:4699)
at
org.apache.hadoop.hbase.regionserver.HRegion.mutate(HRegion.java:5194)
at
org.apache.hadoop.hbase.regionserver.HRegion.lambda$append$31(HRegion.java:8087)
at org.apache.hadoop.hbase.trace.TraceUtil.trace(TraceUtil.java:216)
at
org.apache.hadoop.hbase.regionserver.HRegion.append(HRegion.java:8081)
at
org.apache.hadoop.hbase.regionserver.RSRpcServices.append(RSRpcServices.java:699)
at
org.apache.hadoop.hbase.regionserver.RSRpcServices.mutate(RSRpcServices.java:2972)
at
org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos$ClientService$2.callBlockingMethod(ClientProtos.java:43506)
at org.apache.hadoop.hbase.ipc.RpcServer.call(RpcServer.java:444)
at org.apache.hadoop.hbase.ipc.CallRunner.run(CallRunner.java:124)
at org.apache.hadoop.hbase.ipc.RpcHandler.run(RpcHandler.java:102)
at org.apache.hadoop.hbase.ipc.RpcHandler.run(RpcHandler.java:82)
...
{code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)