《大众金融》企业级开发实战

news/2024/5/3 15:11:43/文章来源:https://blog.csdn.net/m0_45209551/article/details/130006301

目录

主要内容

1 配置中心简介

1.1 什么是配置

1.2 传统配置形式存在的问题

1.3 配置中心的作用

2 Apollo简介

2.3 Apollo特性

2.4 产品对比

 2.5 Apollo初体验

2.5.1 访问控制台


应用配置中心Apollo-讲义

 

主要内容

1)了解配置中心的概念以及使用场景
2)了解主流配置中心和Apollo
3)掌握如何部署和使用Apollo
4)会通过springBoot集成Apollo

1 配置中心简介

1.1 什么是配置

        配置伴随着应用的整个生命周期,主要用于提升应用程序的灵活性、可扩展性和可维护性

1.2 传统配置形式存在的问题

1. 缺少权限控制:由于配置能改变程序的行为,不正确的配置甚至能引起灾难,所以对配置的修改必须有比较完善的权限控制
2. 缺少版本控制:在整个开发过程中,配置会经常发生修改,版本控制非常必要
3. 缺少实时控制:配置发生变化后,需要重启才能生效,费时费力,迫切需要实时生效(热发布)
4. 微服务化和分布式带来的挑战
  • 当系统从一个单体应用,被拆分成分布式系统上一个个服务节点后,配置文件也必须跟着迁移(分割),这样配置就变得非常分散,造成使用和管理难度变大。不仅如此,各个节点服务的配置中难 免会包含很多冗余代码。
  •  同一个应用程序在不同的环境(开发,测试,生产)和不同的集群经常需要有不同的配置,需要能 方便得进行动态切换。

1.3 配置中心的作用

        配置中心将配置从各个应用中剥离出来,自成一体,对所有的配置进行单独的统一管理,优雅的解决了上述诸多问题。在系统架构中,和安全、日志、监控等非功能需求一样,配置管理也是一种非功能需求。配置中心是整个微服务基础架构体系中的一个组件。总得来说,配置中心就是一种统一管理各种应用配置的基础服务组件。

 

2 Apollo简介

2.3 Apollo特性

基于配置的特殊性,所以Apollo从设计之初就立志于成为一个有治理能力的配置发布平台,目前提供了以下的特性:
        统一管理不同环境、不同集群的配置
  • Apollo提供了一个统一界面集中式管理不同环境(environment)、不同集群(cluster)、 不同命名空间(namespace)的配置。
  • 同一份代码部署在不同的集群,可以有不同的配置,比如zookeeper的地址等
  • 通过命名空间(namespace)可以很方便地支持多个不同应用共享同一份配置,同时还允许 应用对共享的配置进行覆盖
配置修改实时生效(热发布)
  • 用户在Apollo修改完配置并发布后,客户端能实时(1秒)接收到最新的配置,并通知到应用 程序
版本发布管理
  • 所有的配置发布都有版本概念,从而可以方便地支持配置的回滚
灰度发布
  • 支持配置的灰度发布,比如点了发布后,只对部分应用实例生效,等观察一段时间没问题后 再推给所有应用实例
权限管理、发布审核、操作审计
  • 应用和配置的管理都有完善的权限管理机制,对配置的管理还分为了编辑和发布两个环节, 从而减少人为的错误。
  • 所有的操作都有审计日志,可以方便地追踪问题
客户端配置信息监控
  • 可以在界面上方便地看到配置在被哪些实例使用
提供Java.Net原生客户端
  • 提供了Java.Net的原生客户端,方便应用集成
  • 支持Spring Placeholder, AnnotationSpring BootConfifigurationProperties,方便应用 使用(需要Spring 3.1.1+
  • 同时提供了Http接口,非Java.Net应用也可以方便地使用
提供开放平台API
  • Apollo自身提供了比较完善的统一配置管理界面,支持多环境、多数据中心配置管理、权 限、流程治理等特性。不过Apollo出于通用性考虑,不会对配置的修改做过多限制,只要符 合基本的格式就能保存,不会针对不同的配置值进行针对性的校验,如数据库用户名、密 码,Redis服务地址等
  • 对于这类应用配置,Apollo支持应用方通过开放平台APIApollo进行配置的修改和发布,并 且具备完善的授权和权限控制

一句话:Apollo集成了数据库+Eureka+版本控制+权限管理+Http Long Polling ... ...

2.4 产品对比

 2.5 Apollo初体验

2.5.1 访问控制台

体验URL:**********,账号/密码: apollo/admin

 

上图是Apollo配置中心中一个项目的配置首页
  • 在页面左上方的环境列表模块展示了所有的环境和集群,用户可以随时切换。
  • 页面中央展示了两个namespace(applicationFX.apollo)的配置信息,默认按照表格模式展示、
  • 编辑。用户也可以切换到文本模式,以文件形式查看、编辑。
  • 页面上可以方便地进行发布、回滚、灰度、授权、查看更改历史和发布历史等操作

2.5.2 添加/修改配置项

用户可以通过配置中心界面方便的添加/修改配置项

输入配置信息:

 2.5.3 发布配置

配置项发生变化后,必须进行发布才能生效

 填写发布信息:

 2.5.4 浏览全貌

 3 使用Apollo

3.1 运行环境

1. Java
  • Apollo服务端:JDK 1.8+
  • Apollo客户端:JDK 1.7+  由于需要同时运行服务端和客户端,所以应该安装JDK 1.8+,另外请配置JAVA_HOME环境变量。

2. MySQL

  • 版本要求:5.6.5+

3.2 搭建数据库环境

Apollo服务端共需要两个数据库:ApolloPortalDBApolloConfifigDBApolloPortalDB只需要在生产环境部署一个即可,ApolloConfifigDB需要在每个环境部署一套。
1. 执行ApolloConfifigDB_initialization.sql创建ApolloPortalDB数据库
2. 执行ApolloPortalDB_initialization.sql创建ApolloPortalDB数据库

3.3 启动Apollo

1. 确保端口未被占用:
        Apollo会在启动3个服务,分别使用8070, 8080, 8090端口,请确保这3个端口当前没有被使用

 2. 打开runApollo.bat,修改数据库连接地址,数据库以及密码

3. 运行启动脚本:runApollo.bat,等待三个服务全部启动完毕
4. 访问管理页面:http://localhost:8070 账号密码:apollo/admin

3.4 核心概念

1. 项目(应用)
  • 这个很好理解,就是实际使用Apollo配置中心的应用,该应用一般指的就是我们自己的微服务工 程。通过引入Apollo客户端,就可以在运行时去配置中心获取对应的配置
        关键字:appId
2. environment (环境)
  • 配置对应的环境,Apollo客户端在运行时需要知道当前应用处于哪个环境,从而可以去获取应用的 配置
        关键字:env
3. cluster (集群)
  • 一个应用下不同实例的分组,比如典型的可以按照数据中心进行划分,把上海机房的应用实例分为 一个集群,把北京机房的应用实例分为另一个集群。
        关键字:cluster
4. namespace (命名空间)
  • 一个应用下不同配置的分组,可以简单地把namespace类比为文件,不同类型的配置存放在不同 的文件中,如数据库配置文件,RPC配置文件,应用自身的配置文件等
关键字:namespaces

3.5 玩转Apollo

3.5.1 基础设置
1. 部门管理
        apollo 默认有两个样例部门,一般都不用,可以自己修改部门,在系统参数中修改:

 输入key查询已存在的部门设置:organizations

 

2. 用户管理
账号apollo是默认的超级管理员,我们可以自己添加新用户。在管理员工具菜单中点击用户管

3.5.2 创建项目

1. 打开apollo-portal主页:http://localhost:8070/
2. 点击创建项目

 

3. 输入项目信息
  • 部门:选择应用所在的部门
  • 应用AppId:用来标识应用身份的唯一id,格式为string,需要和项目配置文件
  • applications.properties中配置的app.id对应
  • 应用名称:应用名,仅用于界面展示
  • 应用负责人:选择的人默认会成为该项目的管理员,具备项目权限管理、集群创建、
  • Namespace创建等权限

 4. 点击提交

创建成功后,会自动跳转到项目首页

 2. 添加公共Namespace

进入common-template项目管理页面:http://localhost:8070/confifig.html?#/appid=common
template

 

 3.5.4 添加配置项

1. 通过表格模式添加配置
  • 点击新增配置
  •  输入配置项

 2. 通过文本模式编辑

Apollo除了支持表格模式,逐个添加、修改配置外,还提供文本模式批量添加、修改。 这个对于
从已有的properties文件迁移尤其有用
  • 切换到文本编辑模式

  •  输入配置项,并点击提交修改
server.servlet.context-path = /
spring.http.encoding.enabled = true
spring.http.encoding.charset = UTF-8
spring.http.encoding.force = true

 3. 发布配置

3.5.5 关联公共组件Namespace

1. 打开之前创建的account-service项目:http://localhost:8070/confifig.html?#/appid=account
service
2. 点击左侧的添加Namespace
3. 添加Namespace

 4. 根据需求可以覆盖引入公共Namespace中的配置,下面以覆盖server.servlet.context-path为例

 

 5. 修改server.servlet.context-path为:/account-service

 3.5.6 添加私有Namespace

1. 添加项目私有Namespace

 2. 添加配置项

3. 发布配置

 3.6 集群配置

在有些特殊情况下,应用有需求对不同的集群做不同的配置,比如部署在A机房的应用连接的
RocketMQ服务器地址和部署在B机房的应用连接的RocketMQ服务器地址不一样。在这种情况下,可以通过在Apollo创建不同的集群来解决。
1. 点击页面左侧的添加集群按钮

 2. 输入集群名称,选择环境并提交:添加上海金桥数据中心为例

3. 切换到对应的集群,修改配置并发布即可

4 微服务集成Apollo客户端

4.1 添加依赖

pom.xml中添加Apollo客户端
<dependency><groupId>com.ctrip.framework.apollo</groupId><artifactId>apollo-client</artifactId><version>1.1.0</version>
</dependency>

4.2 添加配置

4.2.1 配置文件

1. resources目录下新建apollo-env.properties文件
# 开发环境
dev.meta=http://localhost:8080
# 功能验收测试环境
fat.meta=http://apollo.fat.xxx.com
# 用户验收测试环境
uat.meta=http://apollo.uat.xxx.com
# 生产环境
pro.meta=http://apollo.xxx.com

2. application.properties中进行如下配置

# 项目ID
app.id=account-service
# 启动阶段就注入配置(提高优先级)
apollo.bootstrap.enabled = true
# 使用哪些命名空间中的配置项
apollo.bootstrap.namespaces = application,micro_service.spring-boot-http,springrocketmq
# 服务端口
server.port=63000

4.2.2 启动参数

完整的VM Options如下:
-Denv=DEV -Dapollo.cluster=DEFAULT
1. Environment
        可以通过JavaSystem Propertyenv来指定环境: -Denv=DEV
2. Cluster(集群)
        通过JavaSystem Propertyapollo.cluste来指定集群: -Dapollo.cluster=DEFAULT

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_283060.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单元测试系列 | 如何更好地测试依赖外部接口的方法

背景 在现在这个微服务时代&#xff0c;我们项目中经常都会遇到很多业务逻辑是依赖其他服务或者第三方接口。工作中各位同学对于这类型场景的测试方式也是五花八门&#xff0c;有些是直接构建一个外部mock服务&#xff0c;返回一些固定的response;有些是单元测试都不写&#x…

Linux复习 / 命令与权限部分QA梳理

文章目录前言Q&AshellQ&#xff1a;什么是shell&#xff1f;Q&#xff1a;shell的作用&#xff1f;Q&#xff1a;为什么要有shell&#xff1f;Q&#xff1a;shell的生命周期多长&#xff1f;Q&#xff1a;shell的原理/实现是怎样的&#xff1f;Q&#xff1a;为什么会有内建…

Scrum Master 应该采取哪些措施来提高团队效率?

项目经理应该从这5方面提高团队的开发效率 1、目标明确有时间节点 提高团队开发效率&#xff0c;最重要的是明确目标与期限。制定SMART目标&#xff0c;明确告知成员要实现什么&#xff0c;输出什么&#xff0c;标准以及时限等&#xff0c;需要考虑目标的可达成性和目标与项目的…

【牛客刷题专栏】0x17:JZ17打印从1到最大的n位数(C语言编程题)

前言 个人推荐在牛客网刷题(点击可以跳转)&#xff0c;它登陆后会保存刷题记录进度&#xff0c;重新登录时写过的题目代码不会丢失。个人刷题练习系列专栏&#xff1a;个人CSDN牛客刷题专栏。 题目来自&#xff1a;牛客/题库 / 在线编程 / 剑指offer&#xff1a; 目录前言问题…

Java初阶(异常)

文章目录一、异常的结构体系二、异常的处理2.1 防御式编程2.2 异常的抛出2.4 异常的捕获&#xff08;异常的具体处理方式&#xff09;&#xff08;1&#xff09;异常声明 throws&#xff08;2&#xff09; 捕获处理 try-catch2.4 异常的处理流程三、自定义异常类一、异常的结构…

go学习线路图

1. go学习线路图 1.1.2. 资源 先决条件 GoSQL 通用开发技能 学习 GIT&#xff0c;在 GitHub 上建立一些仓库&#xff0c;与其它人分享你的代码了解 HTTP(S) 协议&#xff0c;request 方法&#xff08;GET, POST, PUT, PATCH, DELETE, OPTIONS&#xff09;不要害怕使用 Google&a…

和数软件荣获上海市“专精特新”企业荣誉认定

近日&#xff0c;上海市经济和信息化委员会公示了2022年上海市“专精特新”企业名单。根据《关于组织开展2022年创新型中小企业评价、专精特新中小企业认定和复核工作的通知》&#xff08;沪经信企〔2022〕776号&#xff09;&#xff0c;经专家评审和综合评估&#xff0c;上海和…

学会吊打面试官之map

小白&#xff1a;大牛&#xff0c;我最近学习了一些C的STL容器&#xff0c;但是我还是有一些疑惑&#xff0c;特别是对于map&#xff0c;我不太理解它的底层实现和具体用法。能否跟我讲一下&#xff1f; 大牛&#xff1a;当然可以啊&#xff0c;map是一种非常常用的关联式容器…

小企业选择什么样的CRM系统比较合适,有什么特点?

CRM客户管理系统已经成为各种规模的企业&#xff0c;特别是小型企业的重要工具。CRM系统帮助小型企业更有效地管理客户数据和互动&#xff0c;简化销售流程&#xff0c;并提高客户满意度。市场上有如此多的选择&#xff0c;小企业该如何选择合适的CRM系统&#xff1f; 什么是C…

深圳CPDA|如何着手商业数据分析?

商业数据分析是一项非常重要的工作&#xff0c;可以帮助企业做出更明智的决策。 下面是一些着手商业数据分析的步骤&#xff1a; 1.确定你的问题 首先需要明确你想要解决什么问题。 这通常需要与业务团队沟通&#xff0c;以便了解他们正在寻找哪些信息。 2.收集数据 收集数…

linux语言学习记录

文章目录前言一、linux文件结构二、指令三、Gvim编辑器1、命令模式2、底行命令四、正则表达式1、表达式匹配举例2、对文件里面内容进行操作3、使用 \( 和 )\ 符号括起正规表达式&#xff0c;即可在后面使用\1和\2等变量来访问和中的内容前言 记录自己学习linux的笔记&#xff…

IFPUG功能点度量5:计算功能规模

功能点计数类型&#xff1a;开发项目、升级项目、应用 一、 三种功能能规模计算&#xff1a; 1、开发项目计算 DFP&#xff08;开发项目功能规模&#xff09;ADD&#xff08;交付用户的功能规模&#xff09;CFP&#xff08;转换功能的功能规模&#xff09; 2、升级项目计算 …

【代码笔记】Pytorch学习 DataLoader模块详解

Pytorch DataLoader模块详解dataloader整体结构DataLoaderinit 初始化参数解释代码解析IterableDataset 判断构建Sampler&#xff0c;单样本构建BatchSampler&#xff0c;组建batch构建collate_fn 对获取的batch进行处理其他的一些逻辑判断_get_iterator代码解析multiprocessin…

【Python】轻松掌握基础语法(一)

文章目录常量和表达式变量和类型变量的定义变量的使用变量的类型intfloatstrbool动态类型注释输入和输出输出输入运算符算数运算符关系运算符逻辑运算符赋值运算符其他常量和表达式 print(1 2 * 3)print是Python内置的一个函数&#xff0c;作用为输入打印到控制台形如1 2 * …

人工智能前沿——「全域全知全能」人类新宇宙ChatGPT

&#x1f680;&#x1f680;&#x1f680;OpenAI聊天机器人ChatGPT——「全域全知全能」人类全宇宙大爆炸&#xff01;&#xff01;&#x1f525;&#x1f525;&#x1f525; 一、什么是ChatGPT?&#x1f340;&#x1f340; ChatGPT是生成型预训练变换模型&#xff08;Chat G…

1.半导体基础知识

1.半导体基础知识本征半导体什么是半导体&#xff1f;什么是本征半导体&#xff1f;本征半导体的结构本征半导体中的两种载流子为什么将自然界导电性能中等的半导体材料制成本征半导体杂质半导体N型半导体P型半导体PN结PN结中的扩散运动漂移运动和PN结的形成PN结的单向导电性PN…

uniapp开发小程序-swiper点击预览大图(商品详情页轮播图)

1.实现效果&#xff1a; 2.具体代码&#xff1a; <view class"swiper_box"><!--轮播图--><swiper class"ms_swiper" :autoplay"true" circular"true" change"swiperChange"><swiper-item v-for"…

【动态规划模板】神似的01和完全背包、多重背包和分组背包问题

神似的01背包与完全背包&#x1f349; 【经典题目】01背包采药 题目描述 &#x1f388; 辰辰是个天资聪颖的孩子&#xff0c;他的梦想是成为世界上最伟大的医师。为此&#xff0c;他想拜附近最有威望的医师为师。医师为了判断他的资质&#xff0c;给他出了一个难题。医师把他…

【Redis学习】SpringBoot集成Redis

总体概述 jedis-lettuce-RedisTemplate三者的联系 本地Java连接Redis常见问题 bind配置请注释掉 保护模式设置为no Linux系统的防火墙设置 redis服务器的IP地址和密码是否正确 忘记写访问redis的服务端口号和auth密码 集成jedis 简介 Jedis Client是Redis官网推荐的一个面…

【c语言】文件的读写

文件读写使用二进制读写比较方便&#xff0c;分别使用fread和fwrite函数进行。 一、函数定义 以二进制形式读取文件&#xff0c;从stream流中读取内容&#xff0c;读到ptr指向的空间中&#xff0c;读取size大小的count个内存单元。 返回值为读取到的字符个数。 以二进制形式读…