【Spring专题】,三分钟搞定分布式结构服务部署发布

  1. 基于XML的配置文件

  2. 基于注释的配置

  3. 基于Java的配置

具体实现代码我就不多说了,因为比较简单,无需列举。

Bean Scopes(Bean的执行范围)

定义时,可以选择声明该bean的作用域,最经常用的就是单例模式、多例模式

  • 原型模式:要强制Spring每次需要一个新的bean实例时,应将bean的scope属性声明为prototype。

  • 单例模式:如果希望Spring每次需要一个实例时都返回相同的bean实例,则应将bean的scope属性声明为singleton。

Spring框架支持以下五个范围,其中三个仅在使用可感知Web的ApplicationContext时才可用。

声明周期

singleton

这会将bean定义的范围限定为每个Spring IoC容器一个实例(默认)。

如果将范围设置为单例,则Spring IoC容器将创建该bean定义所定义的对象的一个实例。该单个实例存储在此类单例bean的高速缓存中,并且对该命名bean的所有后续请求和引用都返回该高速缓存的对象。

默认范围始终为单例。但是,当您只需要一个bean的一个实例时,可以在bean配置文件中将scope属性设置为singleton。

复制代码

或者@Scope注解指定!

prototype

将单个bean定义的范围限定为具有任意数量的对象实例。

如果将范围设置为prototype,则每次请求该特定bean时,Spring IoC容器都会创建该对象的新bean实例。通常,将原型作用域用于所有有状态的Bean,将单例作用域用于无状态的Bean。

要定义prototype范围,可以在bean配置文件中将scope属性设置为prototype。

复制代码

除此之外,还有其他的Request-Bean对象机制

  • request:这将bean定义的范围限定为HTTP请求。仅在可感知网络的Spring ApplicationContext上下文中有效。

  • session:这将bean定义的作用域限定为HTTP会话。仅在可感知网络的Spring ApplicationContext上下文中有效。

  • global-session:这将bean定义的作用域限定为全局HTTP会话。仅在可感知网络的Spring ApplicationContext上下文中有效。

Bean Life Cycle(Bean的声明周期)

Spring bean的生命周期很容易理解。实例化bean时,可能需要执行一些初始化以使其进入可用状态。同样,当不再需要bean并将其从容器中删除时,可能需要进行一些清理。

Bean的的初始化方式和销毁方法

两个重要的Bean生命周期回调方法,这些方法在Bean初始化及其销毁时是必需的。

要定义bean的设置和拆卸,只需使用init-method和destroy-method参数声明 。

  • init-method属性指定在实例化后立即在Bean上调用的方法。

  • destroy-method指定一种在将bean从容器中删除之前被调用的方法。

初始化回调函数

对于基于XML的配置元数据,可以使用init-method属性指定具有无效无参数签名的方法的名称。例如-

以下是类定义-

public class ExampleBean {

public void init() {

// do some initialization work

}

}

复制代码

对于基于XML的配置元数据,可以使用destroy-method属性指定具有无效无参数签名的方法的名称。

复制代码

以下是类定义

public class ExampleBean {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

技术学习总结

学习技术一定要制定一个明确的学习路线,这样才能高效的学习,不必要做无效功,既浪费时间又得不到什么效率,大家不妨按照我这份路线来学习。

最后面试分享

大家不妨直接在牛客和力扣上多刷题,同时,我也拿了一些面试题跟大家分享,也是从一些大佬那里获得的,大家不妨多刷刷题,为金九银十冲一波!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

刷刷题,为金九银十冲一波!

[外链图片转存中…(img-i2fscwmJ-1712687910393)]

[外链图片转存中…(img-QuJJLV9o-1712687910393)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-aAblL51K-1712687910394)]

  • 22
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于xxl-job改造,支持1.6jdk。改分布式任务调度特性如下: 1、简单:支持通过Web页面对任务进行CRUD操作,操作简单,一分钟上手; 2、动态:支持动态修改任务状态、暂停/恢复任务,以及终止运行中任务,即时生效; 3、调度中心HA(中心式):调度采用中心式设计,“调度中心”基于集群Quartz实现,可保证调度中心HA; 4、执行器HA(分布式):任务分布式执行,任务"执行器"支持集群部署,可保证任务执行HA; 5、任务Failover:执行器集群部署时,任务路由策略选择"故障转移"情况下调度失败时将会平滑切换执行器进行Failover; 6、一致性:“调度中心”通过DB锁保证集群分布式调度的一致性, 一次任务调度只会触发一次执行; 7、自定义任务参数:支持在线配置调度任务入参,即时生效; 8、调度线程池:调度系统多线程触发调度运行,确保调度精确执行,不被堵塞; 9、弹性扩容缩容:一旦有新执行器机器上线或者下线,下次调度时将会重新分配任务; 10、邮件报警:任务失败时支持邮件报警,支持配置多邮件地址群发报警邮件; 11、状态监控:支持实时监控任务进度; 12、Rolling执行日志:支持在线查看调度结果,并且支持以Rolling方式实时查看执行器输出的完整的执行日志; 13、GLUE:提供Web IDE,支持在线开发任务逻辑代码,动态发布,实时编译生效,省略部署上线的过程。支持30个版本的历史版本回溯。 14、数据加密:调度中心和执行器之间的通讯进行数据加密,提升调度信息安全性; 15、任务依赖:支持配置子任务依赖,当父任务执行结束且执行成功后将会主动触发一次子任务的执行, 多个子任务用逗号分隔;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值