技术-技术方案优化策略--多线程与分布式

    xiaoxiao2021-03-25  204

    使用场景:

    离线任务、异步任务、大数据任务、耗时较长任务的运行**,适当地利用,可达到加速的效果。

    注意:线上对响应时间要求较高的场合,尽量少用多线程,尤其是服务线程需要等待任务线程的场合(很多重大事故就是和这个息息相关),如果一定要用,可以对服务线程设置一个最大等待时间。

    常用方案:

    1)单机多线程,可以引入线程池的机制,目标: 提高性能,节省线程创建和销毁的开销;限流。给线程池一个固定的容量,达到这个容量值后再有任务进来,就进入队列进行排队,保障机器极限压力下的稳定处理能力在使用JDK自带的线程池时,一定要仔细理解构造方法的各个参数的含义,如core pool size、max pool size、keepAliveTime、worker queue等,在理解的基础上通过不断地测试调整这些参数值达到最优效果; 2)多机多线程--分布式系统 引入一个单独的节点,作为调度器,其他的机器节点都作为执行器节点; 调度器来负责拆分任务,和分发任务到合适的执行器节点; 执行器节点按照多线程的方式(也可能是单线程)来执行任务; 整个任务系统就由单击演变成一个集群的系统,而且不同的机器节点有不同的角色,各司其职,各个节点之间还有交互。这个时候除了有多线程、线程池等机制,像RPC、心跳等网络通信调用的机制也不可少。
    转载请注明原文地址: https://ju.6miu.com/read-779.html

    最新回复(0)