• 2023年最新版Apollo保姆级使用手册(超级详尽版本)


    Apollo操作说明#

    前言#

    • 研究了一下apollo,发现官方文档还是很多地方写的不是很明确(对比Nacos),因此,写了一份更加简洁,更加易用,特别适合新手使用的文档,希望对你有帮助,本文在于详尽,图示清晰,简单易用,十分方便,无论是开发,产品,测试,还是不接触代码的人,都可以看的清楚明白.

    Apollo环境部署#

    一、环境构建#

    二、官方地址#

    三、数据库脚本使用#

    • 1.找到下载好的脚本。

    • 2.打开DBeaver,右键一个数据库,选择工具--->执行脚本.

    • 3.选择文件所在路径.额外命令里添加配置.
    Copy Highlighter-hljs
    --default-character-set=utf8

    • 4.选择一个文件,点击确认.

    • 5.填好后,如图,选择开始,不报错执行完毕,就是成功了,成功后,会生成如图两个数据库.

    四、配置Apollo文件#

    • 1.找到下载好的文件,找到demo文件,对其备份。

    • 2.打开demo文件,进行如图修改(你的账户密码,不一样,自行修改)。

    五、启动Apollo#

    • 1.右键选择git工具.(保证8080\8090\8070 端口不被占用)

    • 2.输入命令启动.
    Copy Highlighter-hljs
    ./demo.sh start
    • 输入后,进入等待状态,一直等所有启动后才是成功.

    • 3.关闭命令

    六、访问Apollo#

    • 3.访问成功进入主页

    • 4.访问地址:官方样例,可以查看官网如何使用的.

    Apollo产品使用#

    一、修改部门#

    • 1、Apollo的部门设计很不好,需要进行修改,修改方式如下。

      • 正常的新建,这时候,只有这个样例部门,没有正常的部门,所以要修改。

    • 2、修改方式类似于json修改,首先找到如图的参数修改。

    • 3.点击如图修改,新版的这个可以看到这个配置列表了,旧版需要输入关键字。

      • 旧版是这样的。

      • 需要输入:organizations,点击查询。

    • 4.新版修改了样式,操作还是一样的,就是按照格式修改json。

      • 修改样例。(自己编的,你也可以自定义)

        Copy Highlighter-hljs
        [{"orgId":"micro_service","orgName":"研发部"},{"orgId":"002","orgName":"销售部"},{"orgId":"003","orgName":"行政部"},{"orgId":"004","orgName":"财务部"},{"orgId":"005","orgName":"商务部"},{"orgId":"006","orgName":"保洁部"},{"orgId":"007","orgName":"保安部"},{"orgId":"008","orgName":"餐饮部"},{"orgId":"009","orgName":"运营部"},{"orgId":"010","orgName":"客服部"},{"orgId":"011","orgName":"公关部"},{"orgId":"012","orgName":"法务部"},{"orgId":"013","orgName":"后勤保障部"}]
      • 修改新版的,粘贴到这里。

      • 保存后如图。一定要格式对,否则会报错,整个都不好使了。

      • 添加成功,再看新进内,就这样了。

    二、应用操作#

    • 1.新建应用。点击如图位置,添加相关参数,点击保存,再返回主界面,就可以看到自己创建的应用了。

    • 2.修改应用,选择如图,修改添加时候的信息,点击修改应用信息,就可以修改了。

    • 3.在总列表里,可以看到添加的应用。

    • 4.删除应用,这个功能就需要吐槽下,本来应该在展示界面里就有,可是它却在管理员工具里,这个button设置的不好。

      • 本来在首页设置直接点删除很好操作,结果在管理中,而且,还是需要自己输入ID,这就更费劲操作了。

      • 删除成功后,提示信息。再点击返回首页,才能看到成功删除,不会自动跳转。

    三、用户操作#

    • 1.添加用户,进入用户界面后,添加信息,点击添加。

    • 旧版的就可以设置简单的密码.

    • 新建用户后,可以进入登陆界面进行登陆.

    • 成功后如图显示,但是,这里的用户没有管理员工具.很多功能需要授权使用.

    • 2.编辑用户,修改用户的信息。

    • 可以在列表里选择禁用,但是,为什么不把删除放在这里呢?这个界面不是很友好。

    • 选择过滤进行查询,选择重置,就会删除关键字(没什么用的设计)。

    • 3.删除用户,由于界面没有开发删除功能,所以想要删除用户(在如图位置),需要自己删除数据库的数据(谨慎操作).

    Copy Highlighter-hljs
    # 一定加好where条件,不然全部用户删了,就不用用了 delete from users where id = 2

    • 技能好的可以源码拷贝下来,二次开发加上删除用户的button,技能不好的,想要删除,就像这样删除数据库的用户,这是在用户没有赋权的简单模式下删除,赋权后,还要同步删除权限.

    四、系统权限管理#

    1、创建应用权限配置

    • 1)操作之前保证新建了一个用户(详情看用户添加),保证有多个可以测试的应用.

    • 2)使用前需要开启这个功能,才能配置,否则配置无效.

      • 要在系统配置页面,首先将这个参数添加进去.

      • 输入配置的信息,点击提交

      Copy Highlighter-hljs
      role.create-application.enabled = true

    • 登陆普通用户:zhangsan,就会发现在首页应用这里,图标都没了.

    • 管理员这里是有这个图标的.

    • 3)登陆超级管理员apollo,使用这里的授权功能进行授权,再登陆zhangsan(普通用户查看),发现这里的图标又出现了.

    • 在这个列表里可以选择.给用户添加创建应用的权限(用户默认就有这个权限)

    2、创建应用权限配置

    • 1 ) 进入首页,选择一个应用进入.

    • 2 )点击进入后,发现这里有个管理应用.

      • 先给普通用户添加这个应用的管理员权限.

    • 3 ) 登陆普通用户zhangsan,查看其应用.

      • 点击下拉框发现普通用户,也可以修改应用的管理员.

    • 4 ) 进入apollo账户下,添加参数到系统参数中.

    • 添加参数,到配置中,点击提交.

      Copy Highlighter-hljs
      role.manage-app-master.enabled = true

    • 对其设置.

    • 如图位置找到,选择点击.(系统权限管理应该叫做用户应用权限管理,更加恰当,应该是产品起的名字,奇奇怪怪的)

    • 可以将管理员的应用授权给普通用户使用权限(那么就没什么变化,所以这里要禁用其功能).

    • 5 ) 重新登陆zhangsan账户,点击进入应用详情.

    • 这时就会看到管理员分配的功能没有了,只有一个查看的功能了.

    3、与旧版比对

    • 旧版是没有这个模块的,这是新增的一个模块,对两个权限进行了修改,全网和官网都没有相关配置,这里是作者反复测试得到的结果.

    五、系统参数#

    • 可以通过这里配置.

    1、PortalDB 配置管理

    • 这个模块对应的数据库就是这个的表.

    新增配置

    • 就相当于项目里的properties

    编辑配置

    查询配置

    删除配置

    • 界面没有开发删除功能,所以,要在数据库操作删除.

    • 谨慎操作,不要轻易操作

    2、ConfigDB 配置管理

    • 这个模块对应的数据库就是这个的表.

    新增配置

    • 就相当于项目里的properties

    编辑配置

    查询配置

    删除配置

    • 界面没有开发删除功能,所以,要在数据库操作删除.

    • 谨慎操作,不要轻易操作

    六、系统信息#

    • 主要是查看功能,就跟Euraka的主页一样.

    七、配置导出导入#

    • 会把配置信息导出成应用配置的信息.

    1、配置导出

    • 导出后会产生这样的文档.打开查看都是json格式的数据.

    2、配置导入

    八、应用配置(核心功能使用)#

    • 在主页点击应用进入应用配置.

    1、应用信息配置

    • 查看应用操作.

    2、管理应用配置

    • 查看第四章系统权限管理

    • 查看应用操作

    3、管理密钥配置(新版才有,旧版没有)

    • 进入密钥详情,点击添加进行添加.

    • 可以点击启用或者删除.

    • 点击启用

    4、添加集群配置

    • 集群就是多个服务器或者多个服务同时使用.

      删除集群

    • 在首页找到管理员工具里的删除功能.另一个页面打开记住集群的名字,复制粘贴过来.

    • 一个打开记录集群名称.

    • 进入删除集群界面.复制集群名称粘贴进来.

    • 删除成功后.

    • 再次查看应用详情中,删除成功.

      集群没有修改名称的操作

    • 可以通过修改数据库实现 .

      Copy Highlighter-hljs
      UPDATE cluster SET Name='HandSomeBoy' where Id = 7 and IsDeleted=0;

    • 修改成功,再查看界面.

    5、添加Namespace配置

    • 进入内部的NameSpace配置界面,

    • 有两个模块:创建Namespace和关联公共组件Namespace

    • 其他功能.

    A、创建Namespace配置

    创建新的Namespace

    • 类型:公有就是其他项目也可以使用,私有就是只有当前的项目可以使用,建法一样,就是看你是自己项目用还是大家一起用.

    设置Namespace

    • 点击新增配置

    • 具体配置信息描述.

    • 另一种就是通过文本添加,当产生配置表之后,可以进行文本配置的.

    • 配置成功后生成列表.

    • 点击这里进行修改

    • 点击叉进行删除

    • 其他配置可以按需求修改.

    • 最后发布配置文件,就相当于上线了的配置文件,可以用服务连接使用了.

    B、关联公共组件Namespace
    • 就是两个或者多个项目,共同使用一个配置的namespace,也相当于共用的properties.

    建立关联的namespace

    • 选择另一个应用进入,找到namespace设置,选择关联公共namespace

    • 本来没有namespace,这样就共用了一个公有的namespace.达到多个项目共用一个公有公共的namespace.

      • 创建成功选择回到首页.

    • 还可以进行覆盖修改操作.

      • key重复了,但是,在这个项目里单独的被覆盖修改了.

    C、删除Namespace

    应用内删除namespace

    • 选中一个应用进入,看到namespace列表,选择这个地方,选择删除.

    • 选择删除namespace.

    管理员工具中删除namespace

    • 功能建立的很散,所以,只能这样写了.

    • 点击进入,查看到删除namespace的地方.

    • 需要查看列表里的名字,双开浏览器比较方便操作,不然不好复制粘贴.

    • 回到首页的应用,点击进入,查看到没有了.

    九、开放平台授权管理#

    • 需要有这个需求的项目作为前提.

    • 首先要把第三方的应用接入到apollo平台里,否则,这里无法使用

    • 进入主页分为两个模块:创建第三方应用 和赋权

    • 模拟填写一下.

    • 模拟填写一下.

    • 填写无误创建成功,就会返回到如图的列表中,列表就会显示出来.

    Apollo 开发使用#

    一、构建开发环境#

    二、构建微服务项目#

    参考文章

    软件名称 版本 相关文章推荐
    Git 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15996063.html

    三、微服务接入Apollo#

    1、 修改pom

    • 在pom.xml中添加Apollo客户端 。

      Copy Highlighter-hljs
      <dependency> <groupId>com.ctrip.framework.apollogroupId> <artifactId>apollo-clientartifactId> <version>1.1.0version> dependency>
    • 项目的父类中添加。

    2、修改properties

    • 主要添加在consumer的路径下,就是调用apollo服务的模块。(由于是分布式,所以Apollo就相当于一个公共的服务,公共服务的东西被项目通过服务的方式调用。)

    • 在resources目录下新建apollo-env.properties文件

    Copy Highlighter-hljs
    # 这个是最有用的 dev.meta=http://localhost:8080 # 功能验收测试环境 fat.meta=http://211.103.136.242:7134 # 用户验收测试环境 uat.meta=http://172.17.0.83:8080 # 生产环境 pro.meta=http://itcast.xxx.com
    • application.properties中进行如下配置
    Copy Highlighter-hljs
    # 项目ID app.id=account-service # 启动阶段就注入配置(提高优先级) apollo.bootstrap.enabled = true # 使用哪些命名空间中的配置项 apollo.bootstrap.namespaces = application,micro_service.spring-boot-http,springrocketmq # 服务端口 server.port=63000

    3、编译启动

    A.配置启动参数
    • 完整的VM Options如下:
    Copy Highlighter-hljs
    -Denv=DEV -Dapollo.cluster=DEFAULT
    B、其他描述
    • Environment

      Copy Highlighter-hljs
      # 可以通过Java的System Property的env来指定环境: -Denv=DEV
    • Cluster(集群)

      Copy Highlighter-hljs
      # 通过Java的System Property的apollo.cluste来指定集群: -Dapollo.cluster=DEFAULT

    4、模块启动顺序

    序号 模块 描述
    1 启动Apollo 启动Apollo的jar包
    2 DiscoveryServer 注册中心
    3 GatewayServerGatewayServer 网关
    4 ConsumerService 用户中心
    • 启动无误,就是配置成功了.

    五、调用流程图#

    • 对应关系

    六、版本对应#

    版本对应关系

    • springboot/springcloud/apollo-client 对应版本
    年份 springboot springcloud apollo-client jdk
    2023.2.1 3.0.2 2022.0.0 2.1.0 1.8
    2023.X.X 2.6.8 2021.0.2 2.1.0 1.8
    自行使用版本 2.1.3.RELEASE Greenwich.RELEASE 1.2.0 1.8
    • spring对应版本
    年份 spring apollo-client jdk
    2023.2.1 3.1.1.RELEASE 2.1.0 1.8
    • springboot/springcloud 对应版本(官网)

    apollo-client已有版本

    七、注意#

    1、配置 集体放在Apollo配置中心,怎么被应用获取呢?

    • 通过Apollo客户端。在项目里就是加个pom依赖,然后修改相关配置。

    • 客户端的作用:从配置中心取配置

    2、配置properties的作用?

    • 虽然有了配置中心的客户端,但是,客户端不知道要取什么配置,去哪里取。
    • 配置中心在哪里存放,要从配置中心的哪个项目里,取哪个环境的,取哪个集群的,哪个命名空间里的什么配置。

    结语#

    呕心沥血,爆肝两个星期(需要写配置环境的文档,还要反复测试,以便为各位看官老爷提供最好的精品文章),希望点赞,收藏,评论,转发,您的支持就是本博主前进的动力.

  • 相关阅读:
    爽爆了!字节架构师纯手打Java技术小册(故事版)开源分享
    CogVLM & CogAgent模型部署
    FFTW库在Windows中的安装和使用
    鼠标拖拽围绕某个物体旋转展示
    Linux - 输入输出
    二维数组前缀和(JAVA)
    Nodejs 发送 TCP 消息的正确姿势
    linux线程创建等待及退出总结
    数据结构之队列
    css背景图片的相关知识
  • 原文地址:https://www.cnblogs.com/liuyangfirst/p/17726702.html