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)

Reply via email to