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

Apollo操作说明

前言

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

Apollo环境部署

一、环境构建

软件名称 版本 相关文章推荐
Git 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15996063.html
JDK 1.8 https://www.cnblogs.com/liuyangfirst/p/14334385.html
Maven 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15981202.html
MySQL 5.6.10 https://www.cnblogs.com/liuyangfirst/p/15997667.html
DBeaver 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15997753.html
IntelliJ IDEA 尽量使用比较新的版本 https://www.jetbrains.com/idea/

二、官方地址

三、数据库脚本使用

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

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

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

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

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

四、配置Apollo文件

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

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

五、启动Apollo

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

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

  • 3.关闭命令

六、访问Apollo

  • 3.访问成功进入主页

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

Apollo产品使用

一、修改部门

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

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

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

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

    • 旧版是这样的。

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

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

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

      [{"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.删除用户,由于界面没有开发删除功能,所以想要删除用户(在如图位置),需要自己删除数据库的数据(谨慎操作).


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

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

四、系统权限管理

1、创建应用权限配置

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

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

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

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

    
    role.create-application.enabled = true
    
    

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

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

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

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

2、创建应用权限配置

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

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

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

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

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

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

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

    
    role.manage-app-master.enabled = true
    
    

  • 对其设置.

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

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

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

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

3、与旧版比对

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

五、系统参数

  • 可以通过这里配置.

1、PortalDB 配置管理

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

新增配置

  • 就相当于项目里的properties

编辑配置

查询配置

删除配置

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

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

2、ConfigDB 配置管理

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

新增配置

  • 就相当于项目里的properties

编辑配置

查询配置

删除配置

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

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

六、系统信息

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

七、配置导出导入

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

1、配置导出

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

2、配置导入

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

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

1、应用信息配置

  • 查看应用操作.

2、管理应用配置

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

  • 查看应用操作

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

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

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

  • 点击启用

4、添加集群配置

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

    删除集群

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

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

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

  • 删除成功后.

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

    集群没有修改名称的操作

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

    
    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
JDK 1.8 https://www.cnblogs.com/liuyangfirst/p/14334385.html
Maven 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15981202.html
MySQL 5.6.10 https://www.cnblogs.com/liuyangfirst/p/15997667.html
DBeaver 尽量最新 https://www.cnblogs.com/liuyangfirst/p/15997753.html
IntelliJ IDEA 尽量使用比较新的版本 https://www.jetbrains.com/idea/

二、构建微服务项目

参考文章

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

三、微服务接入Apollo

1、 修改pom

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

    
    <dependency>
        <groupId>com.ctrip.framework.apollo</groupId>
        <artifactId>apollo-client</artifactId>
        <version>1.1.0</version>
    </dependency>
    
    
  • 项目的父类中添加。

2、修改properties

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

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

# 这个是最有用的
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中进行如下配置
# 项目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如下:

-Denv=DEV -Dapollo.cluster=DEFAULT

B、其他描述
  • Environment

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

    
    # 通过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的作用?

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

结语

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

posted @ 2023-09-30 14:20  北极的大企鹅  阅读(2599)  评论(0编辑  收藏  举报
阅读 - 79万