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 panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em