在客户现场对某业务系统的WebLogic服务器实例做性能调优的时候,设置了自定义线程栈参数(-Xss256k),以提高系统可以创建的线程的数量。Sun JDK默认的线程栈大小为1024k,即1MB。
这个参数在我之间服务的厂家也曾经被广泛使用,都没有发现过在进程启动的时候出现异常。但是,在这个客户现场,在进程启动脚本里面的USER_MEM_ARGS里面设置了-Xss256k参数后,重启服务器的时候,会报下面的错误:
java.lang.StackOverFlowError
将启动脚本里面的-Xss256k删除以后,重启服务器进程,没有再出现StackOverFlowError的错误,进程也可以成功启动。
在网上查询资料,StackOverFlowError错误的原因是由于程序栈空间被耗尽,通常是由于Java程序代码中存在深度递归的函数导致。出现上面的报错的时候,可以将-Xss256k的设置删除,以恢复默认的线程栈大小,即1MB,如果还是报错,可以继续尝试将线程栈参数提升到-Xss2048k,直到进程启动的时候不再报错为止。