spark 大型项目实战(六):用户访问session分析(六) --开发配置管理组件

本文主要是介绍spark 大型项目实战(六):用户访问session分析(六) --开发配置管理组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章地址:http://www.haha174.top/article/details/259340
1.简述

配置管理组件
*

  • 1、配置管理组件可以复杂,也可以很简单,对于简单的配置管理组件来说,只要开发一个类,可以在第一次访问它的
  •  时候,就从对应的properties文件中,读取配置项,并提供外界获取某个配置key对应的value的方法
    
  • 2、如果是特别复杂的配置管理组件,那么可能需要使用一些软件设计中的设计模式,比如单例模式、解释器模式
  •  可能需要管理多个不同的properties,甚至是xml类型的配置文件
    
  • 3、我们这里的话,就是开发一个简单的配置管理组件,就可以了
    具体的代码和注释如下
import java.io.InputStream;
import java.util.Properties;/*** 配置管理组件* * 1、配置管理组件可以复杂,也可以很简单,对于简单的配置管理组件来说,只要开发一个类,可以在第一次访问它的* 		时候,就从对应的properties文件中,读取配置项,并提供外界获取某个配置key对应的value的方法* 2、如果是特别复杂的配置管理组件,那么可能需要使用一些软件设计中的设计模式,比如单例模式、解释器模式* 		可能需要管理多个不同的properties,甚至是xml类型的配置文件* 3、我们这里的话,就是开发一个简单的配置管理组件,就可以了* * @author haha174**/
public class ConfigurationManager {// Properties对象使用private来修饰,就代表了其是类私有的// 那么外界的代码,就不能直接通过ConfigurationManager.prop这种方式获取到Properties对象// 之所以这么做,是为了避免外界的代码不小心错误的更新了Properties中某个key对应的value// 从而导致整个程序的状态错误,乃至崩溃private static Properties prop = new Properties();/*** 静态代码块* * Java中,每一个类第一次使用的时候,就会被Java虚拟机(JVM)中的类加载器,去从磁盘上的.class文件中* 加载出来,然后为每个类都会构建一个Class对象,就代表了这个类* * 每个类在第一次加载的时候,都会进行自身的初始化,那么类初始化的时候,会执行哪些操作的呢?* 就由每个类内部的static {}构成的静态代码块决定,我们自己可以在类中开发静态代码块* 类第一次使用的时候,就会加载,加载的时候,就会初始化类,初始化类的时候就会执行类的静态代码块* * 因此,对于我们的配置管理组件,就在静态代码块中,编写读取配置文件的代码* 这样的话,第一次外界代码调用这个ConfigurationManager类的静态方法的时候,就会加载配置文件中的数据* * 而且,放在静态代码块中,还有一个好处,就是类的初始化在整个JVM生命周期内,有且仅有一次,也就是说* 配置文件只会加载一次,然后以后就是重复使用,效率比较高;不用反复加载多次*/static {try {// 通过一个“类名.class”的方式,就可以获取到这个类在JVM中对应的Class对象// 然后再通过这个Class对象的getClassLoader()方法,就可以获取到当初加载这个类的JVM// 中的类加载器(ClassLoader),然后调用ClassLoader的getResourceAsStream()这个方法// 就可以用类加载器,去加载类加载路径中的指定的文件// 最终可以获取到一个,针对指定文件的输入流(InputStream)InputStream in = ConfigurationManager.class.getClassLoader().getResourceAsStream("application.properites");// 调用Properties的load()方法,给它传入一个文件的InputStream输入流// 即可将文件中的符合“key=value”格式的配置项,都加载到Properties对象中// 加载过后,此时,Properties对象中就有了配置文件中所有的key-value对了// 然后外界其实就可以通过Properties对象获取指定key对应的valueprop.load(in);  } catch (Exception e) {e.printStackTrace();  }}/*** 获取指定key对应的value* * 第一次外界代码,调用ConfigurationManager类的getProperty静态方法时,JVM内部会发现* ConfigurationManager类还不在JVM的内存中* * 此时JVM,就会使用自己的ClassLoader(类加载器),去对应的类所在的磁盘文件(.class文件)中* 去加载ConfigurationManager类,到JVM内存中来,并根据类内部的信息,去创建一个Class对象* Class对象中,就包含了类的元信息,包括类有哪些field(Properties prop);有哪些方法(getProperty)* * 加载ConfigurationManager类的时候,还会初始化这个类,那么此时就执行类的static静态代码块* 此时咱们自己编写的静态代码块中的代码,就会加载application.properites文件的内容,到Properties对象中来* * 下一次外界代码,再调用ConfigurationManager的getProperty()方法时,就不会再次加载类,不会再次初始化* 类,和执行静态代码块了,所以也印证了,我们上面所说的,类只会加载一次,配置文件也仅仅会加载一次* * @param key * @return value*/public static String getProperty(String key) {return prop.getProperty(key);}}

欢迎关注,更多福利

这里写图片描述

这篇关于spark 大型项目实战(六):用户访问session分析(六) --开发配置管理组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097553

相关文章

Python在二进制文件中进行数据搜索的实战指南

《Python在二进制文件中进行数据搜索的实战指南》在二进制文件中搜索特定数据是编程中常见的任务,尤其在日志分析、程序调试和二进制数据处理中尤为重要,下面我们就来看看如何使用Python实现这一功能吧... 目录简介1. 二进制文件搜索概述2. python二进制模式文件读取(rb)2.1 二进制模式与文本

Django调用外部Python程序的完整项目实战

《Django调用外部Python程序的完整项目实战》Django是一个强大的PythonWeb框架,它的设计理念简洁优雅,:本文主要介绍Django调用外部Python程序的完整项目实战,文中通... 目录一、为什么 Django 需要调用外部 python 程序二、三种常见的调用方式方式 1:直接 im

SpringBoot整合 Quartz实现定时推送实战指南

《SpringBoot整合Quartz实现定时推送实战指南》文章介绍了SpringBoot中使用Quartz动态定时任务和任务持久化实现多条不确定结束时间并提前N分钟推送的方案,本文结合实例代码给大... 目录前言一、Quartz 是什么?1、核心定位:解决什么问题?2、Quartz 核心组件二、使用步骤1

VSCode开发中有哪些好用的插件和快捷键

《VSCode开发中有哪些好用的插件和快捷键》作为全球最受欢迎的编程工具,VSCode的快捷键体系是提升开发效率的核心密码,:本文主要介绍VSCode开发中有哪些好用的插件和快捷键的相关资料,文中... 目录前言1、vscode插件1.1 Live-server1.2 Auto Rename Tag1.3

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法