Tried to obtain the web lock from a thread解决方法之一

本文详细解释了在iOS开发中,当UIViewController内部使用异步线程执行任务时,在任务未完成前尝试退出该视图控制器所导致的crash问题。通过引入特定的release方法实现机制,确保所有资源在正确线程中释放,避免crash。同时,提供了具体代码实现和案例分析,帮助开发者理解和应用这一解决方案。

项目中一个UIViewController内使用异步线程,异步线程未执行完时pop退出此画面,程序crash。控制台打出错误如下:


Tried to obtain the web lock from a thread other than the main thread...


经调查,发现是由于UIViewController的release方法没有在主线程中调用造成的crash,修改方法如下:


- (oneway void) release {
   if (![NSThread isMainThread]) {
       [self performSelectorOnMainThread:@selector(release) withObject:nil waitUntilDone:NO];
   } else {
       [super release];
   }
}


添加以上代码到UIViewController中,当不在主线程中执行release时,强行回到主线程中执行。

{"@timestamp":"2025-09-28T07:27:58.069Z", "log.level":"ERROR", "message":"fatal exception while booting Elasticsearch", "ecs.version": "1.2.0","service.name":"ES_ECS","event.dataset":"elasticsearch.server","process.thread.name":"main","log.logger":"org.elasticsearch.bootstrap.Elasticsearch","elasticsearch.node.name":"4b8cc7e637b3","elasticsearch.cluster.name":"docker-cluster","error.type":"java.lang.IllegalStateException","error.message":"failed to obtain node locks, tried [/usr/share/elasticsearch/data]; maybe these locations are not writable or multiple nodes were started on the same data path?","error.stack_trace":"java.lang.IllegalStateException: failed to obtain node locks, tried [/usr/share/elasticsearch/data]; maybe these locations are not writable or multiple nodes were started on the same data path?\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.env.NodeEnvironment.<init>(NodeEnvironment.java:294)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.node.NodeConstruction.validateSettings(NodeConstruction.java:513)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.node.NodeConstruction.prepareConstruction(NodeConstruction.java:281)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.node.Node.<init>(Node.java:201)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.bootstrap.Elasticsearch$2.<init>(Elasticsearch.java:421)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.bootstrap.Elasticsearch.initPhase3(Elasticsearch.java:421)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:100)\nCaused by: java.io.IOException: failed to obtain lock on /usr/share/elasticsearch/data\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.env.NodeEnvironment$NodeLock.<init>(NodeEnvironment.java:239)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.env.NodeEnvironment$NodeLock.<init>(NodeEnvironment.java:207)\n\tat org.elasticsearch.server@8.18.7/org.elasticsearch.env.NodeEnvironment怎么解决
最新发布
09-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值