一.开篇概念明晰: 多任务: 协作式多任务:cpu可以处理多种任务,但是这些任务是排队等候的,当cpu在处理一个任务的时候,其他的任务被锁定,只有当cpu处理完当前任务,才可以继续处理下一个任务(专一暖男): 抢占式多任务:一个任务正在执行,可以被强行中断挂起,去执行其他的任务(花心大萝卜). 进程与线程: 进程:内存和资源的物理分离成为进程.分配给进程的内存只有所属的进程才可以访问.一个应用程序可以启动多个进程 线程:开发架构将程序中的一部分进行分离,使被分离的部分与程序的其余部分执行顺序不一…
前言 做java开发的,一般都避免不了要面对java线程池技术,像tomcat之类的容器天然就支持多线程. 即使是做偏后端技术,如处理一些消息,执行一些计算任务,也经常需要用到线程池技术. 鉴于线程池技术的重要性,接下来会分多篇介绍java中提供的ThreadPoolExecutor线程池实现的底层机制.只有对机制了然于胸,才能更好驾驭这把利器. 线程池技术演示流程 关键概念: 如果说怎么最容易了解线程池的实现原理,那就是一步一步动态的演示.为了便于理解,这里先介绍几个线程池用到的概念. Thr…
1. 概述 1.1 什么是线程池 与jdbc连接池类似,在创建线程池或销毁线程时,会消耗大量的系统资源,因此在java中提出了线程池的概念,预先创建好固定数量的线程,当有任务需要线程去执行时,不用再去新创建线程,而是从线程池中获取线程去执行任务,任务执行完成后将线程重新归还到线程池,这样的一个池就叫做线程池. 1.2 使用线程池的优势 第一:降低资源消耗.通过重复利用已创建的线程降低线程创建和销毁造成的消耗. 第二:提高响应速度.当任务到达时,任务可以不需要的等到线程创建就能立即执行. 第三:提…
进程.线程和协程的调度和运行原理总结. 系列文章 python并发编程之threading线程(一) python并发编程之multiprocessing进程(二) python并发编程之asyncio协程(三) python并发编程之gevent协程(四) python并发编程之Queue线程.进程.协程通信(五) python并发编程之进程.线程.协程的调度原理(六) python并发编程之multiprocessing进程windows和linux环境的对比(七) 进程.线程的调度策略介绍…
Jenkins近阶段使用的总结篇,只写了个引子,却一直未动手写完,今天补上. 前几篇文章提到在内网jenkins直接构建部署升级线上环境,job都是暴露在外面,很容易被误操作,需要做简单的权限控制,以防止误操作,导致生产环境挂掉.但jenkins本身是缺少权限控制的功能的,这里需要借助第三方插件Role Strategy Plugin完成.具体使用细节可以翻阅网络上的相关资料. 回顾下之前的几个章节: 1.利用jenkins实现自动构建.部署,提升团队开发效率 2.Jenkins构建部署后,服务…
1 # 一.创建Vue3.0工程 2 # 1.使用vue-cli创建 3 # 官方文档: https://cli.vuejs.org/zh/guide/creating-a-project.html#vue-create 4 # 查看@vue/cli版本,确保@vue/cli版本在4.5.0以上 5 vue --version 6 # 安装或者升级你的@vue/cli 7 npm install -g @vue/cli 8 # 创建 9 vue create vue_test 10 # 启动 1…
在什么情况下使用线程池? 1.单个任务处理的时间比较短 2.将需处理的任务的数量大 使用线程池的好处: 1. 降低资源消耗: 通过重复利用已创建的线程降低线程创建和销毁造成的消耗.2. 提高响应速度: 当任务到达时,任务可以不需要等到线程创建就能立即执行.3. 提高线程的可管理性: 线程是稀缺资源,如果无限制的创建.不仅仅会降低系统的稳定性,使用线程池可以统一分配,调优和监控.但是要做到合理的利用线程池.必须对于其实现原理了如指掌. 一个线程池包括以下四个基本组成部分:1.线程池管理器(Thre…
1.简介 在分析完AbstractQueuedSynchronizer(以下简称 AQS)和ReentrantLock的原理后,本文将分析 java.util.concurrent 包下的两个线程同步组件CountDownLatch和CyclicBarrier.这两个同步组件比较常用,也经常被放在一起对比.通过分析这两个同步组件,可使我们对 Java 线程间协同有更深入的了解.同时通过分析其原理,也可使我们做到知其然,并知其所以然. 这里首先来介绍一下 CountDownLatch 的用途,Co…
线程 一.内容简介: 本文主要讲述计算机中有关线程的相关内容,以及JAVA中关于线程的基础知识点,为以后的深入学习做铺垫.如果你已经是高手了,那么这篇文章并不适合你. 二.随笔正文: 1.计算机系统组成 计算机系统由计算机硬件系统和软件系统组成.我们今天要说的线程和硬件系统中的cpu中央处理器,及软件系统中的操作系统,进程等有比较紧密的联系.操作系统是软件中比较特殊的存在,与硬件系统直接交互,其他程序(软件)运行在操作系统之上. 2.cpu简单说明 硬件系统中特别重要的一项就是处理器CPU,与我…
一.HDFS概述         优点:高容错性.适合批处理.适合大数据处理.流式文件访问:一次写入,多次读取.         缺点:不适合低延迟数据访问.不适合小文件存取(受限于NameNode).不适合并发写入. 二.HDFS基本架构和原理         考虑一个问题:如何实现一个分布式文件系统?         业务场景:目前有几个T级别的大文件,有数个大容量存储主机.         初期思路:将每个文件创建几个副本,通过冗余机制,分别存放到不同的机器上.另外,通过一台专门的主机ma…