Alena Prokharchyk created CLOUDSTACK-1551:
---------------------------------------------
Summary: Failed to list clusters due to NPE at
createClusterResponse(ApiResponseHelper.java:837)
Key: CLOUDSTACK-1551
URL: https://issues.apache.org/jira/browse/CLOUDSTACK-1551
Project: CloudStack
Issue Type: Bug
Security Level: Public (Anyone can view this level - this is the default.)
Components: API
Affects Versions: 4.2.0
Reporter: Alena Prokharchyk
Assignee: Bharat Kumar
Fix For: 4.2.0
aa40c7ee98b36370069effb68388ba751d7dc6e5
Steps to reproduce (faced on the fresh setup):
1) Added zone, pod and new cluster.
2) Added new host to the cluster
3) Tried to add storage pool to the cluster, but it failed (incorrect mount
path was specified in the API)
After that listCluster command resulted in NPE:
http://localhost:8080/client/api?command=listClusters&response=json&sessionkey=%2BJ9JQhHyFWblhnVYuWO%2BKOG6UF0%3D&page=1&pagesize=1&_=1362604226148
INFO [cloud.api.ApiServer] (ApiServer-4:) Invalid request, no command sent
ERROR [cloud.api.ApiServer] (1994818910@qtp-1007211197-20:) unhandled exception
executing api command: listClusters
java.lang.NullPointerException
at
com.cloud.api.ApiResponseHelper.createClusterResponse(ApiResponseHelper.java:837)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at
org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:319)
at
org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183)
at
org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
at
org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:80)
at
com.cloud.utils.db.TransactionContextBuilder.AroundAnyMethod(TransactionContextBuilder.java:40)
at sun.reflect.GeneratedMethodAccessor35.invoke(Unknown Source)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at
org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:621)
at
org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:610)
at
org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:65)
at
org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at
org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:90)
at
org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at
org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)
at $Proxy377.createClusterResponse(Unknown Source)
at
org.apache.cloudstack.api.command.admin.cluster.ListClustersCmd.execute(ListClustersCmd.java:137)
at com.cloud.api.ApiDispatcher.dispatch(ApiDispatcher.java:163)
at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
"cluster_details" DB table is empty:
mysql> select * from cluster_details;
Empty set (0.00 sec)
"cluster" table has an entry:
mysql> select * from cluster;
+----+------------+--------------------------------------+--------------------------------------+--------+----------------+-----------------+--------------+------------------+---------------+---------+-------+---------+-------------+--------------+
| id | name | uuid | guid
| pod_id | data_center_id | hypervisor_type | cluster_type |
allocation_state | managed_state | removed | owner | created | lastUpdated |
engine_state |
+----+------------+--------------------------------------+--------------------------------------+--------+----------------+-----------------+--------------+------------------+---------------+---------+-------+---------+-------------+--------------+
| 1 | alenazone1 | 8858f907-731a-46b7-982e-f5fbe6fddb5d |
be15d332-a3a6-c4c7-32af-8185fdf31888 | 1 | 1 | xenserver
| CloudManaged | Enabled | Managed | NULL | NULL | NULL
| NULL | Disabled |
+----+------------+--------------------------------------+--------------------------------------+--------+----------------+-----------------+--------------+------------------+---------------+---------+-------+---------+-------------+--------------+
1 row in set (0.00 sec)
The only one host in the cluster is up:
mysql> select id, name, status from host where id=2;
+----+---------------+--------+
| id | name | status |
+----+---------------+--------+
| 2 | xenserver-min | Up |
+----+---------------+--------+
1 row in set (0.00 sec)
NPE happened because api layer tries to retrieve cluster details assuming that
they are always in cluster_details table.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira