2017-10-20 122 views
1

WSO2 API Manager 2.0.0實例正常運行,直到ec2實例用完磁盤空間。一旦磁盤被清除並且API管理器重新啓動,它將不斷拋出錯誤。它創建訪問令牌,但不能持久/驗證。由於磁盤空間不足,WSO2 API Manager失敗,重啓後無法工作

錯誤的詳細信息:

TID: [-1234] [] [2017-10-20 09:43:14,684] INFO {org.wso2.carbon.identity.oauth2.dao.TokenMgtDAO} - Thread pool size for session persistent consumer : 100 {org.wso2.carbon.identity.oauth2.dao.TokenMgtDAO} 
TID: [-1] [] [2017-10-20 09:43:15,495] ERROR {org.wso2.carbon.identity.oauth2.dao.TokenPersistenceTask} - Error occurred while persisting access token :b4f68332-4359-3718-a553-3d908618b1c6 {org.wso2.carbon.identity.oauth2.dao.TokenPersistenceTask} 
org.wso2.carbon.identity.oauth2.IdentityOAuth2Exception: Error when storing the access token for consumer key : _hWq2BEkf1kB2RFSzugOzF04VRsa 
    at org.wso2.carbon.identity.oauth2.dao.TokenMgtDAO.storeAccessToken(TokenMgtDAO.java:291) 
    at org.wso2.carbon.identity.oauth2.dao.TokenMgtDAO.persistAccessToken(TokenMgtDAO.java:343) 
    at org.wso2.carbon.identity.oauth2.dao.TokenPersistenceTask.run(TokenPersistenceTask.java:52) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:748) 
Caused by: org.h2.jdbc.JdbcSQLException: General error: "java.lang.RuntimeException: rowCount expected 663 got 665 IDN_OAUTH2_ACCESS_TOKEN.PRIMARY_KEY_F"; SQL statement: 
INSERT INTO IDN_OAUTH2_ACCESS_TOKEN (ACCESS_TOKEN, REFRESH_TOKEN, CONSUMER_KEY_ID, AUTHZ_USER, TENANT_ID, USER_DOMAIN, TIME_CREATED, REFRESH_TOKEN_TIME_CREATED, VALIDITY_PERIOD, REFRESH_TOKEN_VALIDITY_PERIOD, TOKEN_SCOPE_HASH, TOKEN_STATE, USER_TYPE, TOKEN_ID, GRANT_TYPE, SUBJECT_IDENTIFIER) SELECT ?,?,ID,?,?,?,?,?,?,?,?,?,?,?,?,? FROM IDN_OAUTH_CONSUMER_APPS WHERE CONSUMER_KEY=? [50000-140] 
    at org.h2.message.DbException.getJdbcSQLException(DbException.java:327) 
    at org.h2.message.DbException.get(DbException.java:156) 
    at org.h2.message.DbException.convert(DbException.java:279) 
    at org.h2.table.RegularTable.addRow(RegularTable.java:134) 
    at org.h2.command.dml.Insert.insertRows(Insert.java:148) 
    at org.h2.command.dml.Insert.update(Insert.java:82) 
    at org.h2.command.CommandContainer.update(CommandContainer.java:70) 
    at org.h2.command.Command.executeUpdate(Command.java:199) 
    at org.h2.jdbc.JdbcPreparedStatement.execute(JdbcPreparedStatement.java:179) 
    at org.wso2.carbon.identity.oauth2.dao.TokenMgtDAO.storeAccessToken(TokenMgtDAO.java:269) 
    ... 5 more 
Caused by: java.lang.RuntimeException: rowCount expected 663 got 665 IDN_OAUTH2_ACCESS_TOKEN.PRIMARY_KEY_F 
    at org.h2.message.DbException.throwInternalError(DbException.java:226) 
    at org.h2.table.RegularTable.checkRowCount(RegularTable.java:144) 
    at org.h2.table.RegularTable.addRow(RegularTable.java:117) 
    ... 11 more 
TID: [-1] [] [2017-10-20 09:43:16,236] INFO {org.wso2.carbon.event.processor.manager.core.internal.CarbonEventManagementService} - Starting polling event receivers {org.wso2.carbon.event.processor.manager.core.internal.CarbonEventManagementService} 
+1

請閱讀[在什麼情況下,我可以添加「緊急」或其他類似的短語到我的問題,以獲得更快的答案?](/ meta.stackoverflow.com/q/326569) - 總結是,這並不是解決志願者問題的理想方式,而且可能對獲得答案產生反作用。請不要將這添加到您的問題。 – halfer

回答

0

看起來你的H2數據庫損壞。您可以通過清除H2數據庫來恢復,但會丟失數據。

rm -r <APIM_HOME>/repository/database/* 

然後啓動服務器-Dsetup

./wso2server.sh -Dsetup 

這將再次創造H2數據庫。

由於這個確切原因(即H2數據庫的可破壞性),WSO2的建議是不要在生產中使用H2。

+0

感謝您的回答。在嘗試之前,我希望有一些解決方案來恢復數據。 – RSN

+0

您可以嘗試連接到數據庫和備份數據。 http://www.h2database.com/html/quickstart.html#h2_console – Bee

相關問題