分布式 Java 中间件

本贴最后更新于 2198 天前,其中的信息可能已经时移世易

关键词:java 线程

    中间件是为软件应用提供操作系统所提供的服务之外的服务的,如远程过程调用和对象访问中间件、消息中间件、数据访问中间件

一、Java 线程

    线程操作的 jvm 内存是主内存和工作内存这两个概念的!!!

    1、**线程池:**有效复用线程而不用每次都创建线程,ThreadPoolExecutor、ScheduledThreadPoolExecutor(定时)、Executors.newCachedThreadPool(没有线程上限)

    2、**可见性:**指在一个线程中修改变量的值之后,在其他线程中能够看到这个值

    2、**synchronized 关键字:**声明方法(静态方法则同步锁属于类、成员方法则同步锁属于对象)、代码块(该关键字后的参数,用于同步的锁所属的对象,可以是任意对象) =>(线程间互斥作用、块中变量的可见性作用【在主内存与工作内存中同步变量的值,因此是可见的】)【独占锁】

    3、ReentrantLock 类:类似于修饰代码块时的 syschronized,不过需要显示地进行 unlock(一般写在 finally 中);另有 tryLock 方法,且构造函数可选择构造公平锁(严格按照顺序,所以效率相对低些)与非公平锁(可抢占,可能会导致饿死);ReentrantReadWriteLock 读写锁,主要用于读多写少且读不需要互斥的场景

    4、volatile 关键字:只是保证所修饰的同一个变量在多线程中的可见性,常用于修饰作为开关状态的变量;同一个变量线程间的可见性与多个线程中操作互斥是两码事;【显示锁和原子变量】

    对于一般的变量,如 get 方法的调用获取的都是当前线程工作内存中的副本,因此不一定是最新的值;

    被 volatile 修饰的变量,变量不会有线程的本地副本,只会放在主存中,因此一定是最新的;

    被 sychronized 修饰的变量,则是可以保证线程的本地副本与主存的同步,因此也一定是最新的;

    5、**Atomic*类:**提供一些原子操作,比较明显地提升性能,主要在于如 AtomicInteger 内部通过 JNI 的方式使用了硬件支持的 CAS 指令;

    6、wait、notify、notifyAll 方法:均是 Object 对象的方法,wait 是进行等待的,notify 和 notify 都是唤醒调用同一个对象 wait 方法的线程,区别在于前者唤醒一个等待线程而后者唤醒全部,,且这三个方法的调用都必须在 sychronized 块中

    7、CountDownLatch 类:当多个线程都到达了预期状态或完成预期工作时触发事件,其他线程可以等待这个事件来触发自己后续的工作;

    8、CyclicBarrier 类:循环屏障,可以协同多个线程并让多个线程在这个屏障前等待,直到所有线程都到达了这个屏障时,再一起继续执行后面的动作;

    9、Semaphore 类:用于管理信号量的,构造的时候传入可供管理的信号量的数值,总数也即控制并发的数量

    10、Exchanger 类:用于在两个线程之间进行数据交换

    11、**Future 接口和 FutureTask 类:**回调

二、并发容器:

    并发容器是线程安全的一种,但是更加强调的是容器的并发性,也即不仅仅只追求线程安全,还要考虑并发性,提升并发环境下的性能;

    **加锁互斥:**线程安全,但降低了并发性,其实就是串行了

    CopyOnWrite:是在更改容器的时候,把容器写一份进行修改,保证正在读的线程不受影响,适合于读多写少的场景会非常好,实质上在写的时候重建了一次容器

    Concurrent:实现思路是尽量保证读不加锁,并且修改时不影响读,所以会达到比使用读写锁更高的并发性能

三、动态代理:

    代理模式

    静态代理

    动态代理:Proxy.newProxyInstance()     invoke()

四、反射

    Java 反射机制是指在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性

五、网络通信

    三个模型:BIO、NIO、AIO

    通信框架:MINA,Netty

【读书系列】

    《大型网站系统与 Java 中间件实践》,曾宪杰,电子工业出版社

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • V2Ray
    1 引用 • 15 回帖 • 2 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 411 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖 • 1 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 2 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 476 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 483 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 384 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 660 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 59 关注
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 3 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖 • 4 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 652 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖 • 1 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 4 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖 • 1 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 763 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 644 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 631 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖
  • 音乐

    你听到信仰的声音了么?

    60 引用 • 511 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    543 引用 • 672 回帖 • 1 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    53 引用 • 40 回帖 • 1 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    47 引用 • 25 回帖
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 65 关注