Apollo-open-capacity-platform 微服务能力开发平台 (转)
来自大佬的apollo整合微服务的教程:欢迎大家点评和star,链接如下:https://gitee.com/owenwangwen/open-capacity-platform
官方demo链接:https://github.com/ctripcorp/apollo
开发中的坑:
我的坑:
Java客户端使用指南:链接
open-capacity-platform 微服务能力开发平台
项目简介
1.用户登录
2.用户管理
3.角色管理
4.菜单管理
5.角色菜单管理
6.注册中心
7.配置中心
8.应用列表以及资料列表页面正在开发中,敬请期待
项目组织结构分析
├ apollo -- 阿波罗配置中心
├ ├── apollo-adminservice
├ ├── apollo-assembly
├ ├── apollo-biz
├ ├── apollo-buildtools
├ ├── apollo-client
├ ├── apollo-common
├ ├── apollo-configservice
├ ├── apollo-core
├ ├── apollo-demo
├ ├── apollo-portal
├ └── apollo-zuul 整合zuul案例
├ cachecloud-open-parent -- 搜狐redis云平台
├ ├── cachecloud-open-client
├ ├── cachecloud-open-common
├ └── cachecloud-open-web
├ open-api-gateway -- 服务网关[9000]
├ open-config-cloud --基于spring cloud config 的配置中心
├ ├── config-bus --基于spring cloud bus的服务总线[8201]
├ ├── config-client ----基于spring cloud client端[7001]
├ ├── config-server ----基于spring cloud server端[7201]
├ └── config-zuul ----基于config-client项目整合网关[5555]
├ open-db-core -- 数据库逻辑封装
├ open-layui-web -- 基于token的layui后台管理系统
├ open-zipkin-cloud -- 链路跟踪
├ ├── open-zipkin-kafka-server -- kafka链路跟踪服务端[9411]
├ ├── open-zipkin-kafka-client -- kafka链路跟踪客户端[9412]
├ ├── open-zipkin-memery-server -- 内存跟踪服务端[9411]
└ └─ open-zipkin-memery-client -- 内存链路跟踪客户端[9412]
一. 阿波罗配置中心详解
- 前言
携程 Apollo 配置中心 学习笔记, Windows 系统搭建基于携程Apollo配置中心分布式模式, 在此基础上,介绍如何使用阿波罗整合zuul实现动态路由。
2.环境搭建
效果预览
apollo-configservice
修改如下配置将apollo-configservice 注册到已有的eureka服务器,同时提供提供配置的读取、推送等功能. 修改apollo-configservice的数据源apollo-adminservice
修改apollo-adminservice的数据源apollo-portal
修改apollo-portal代码及数据源apollo-core
修改开发环境环境读取配置文件的地址,填入apollo-configservice注册到eureka服务器的地址,如果apollo-configservice启动多台,可以引入nginx负载均衡
3.阿波罗整合zuul服务注册中心
效果预览
访问http://127.0.0.1:9999/test163即可读取阿波罗页面配置参数,页面修改后可刷新所有阿波罗客户端apollo-zuul
apollo-zuul项目用的是Eureka作为服务注册与发现,因此这里我加入了Eureka Client的依赖,同时需要加入zuul网关的依赖实现微服务的路由 pom.xml文件加入以下依赖<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>com.ctrip.framework.apollo</groupId>
<artifactId>apollo-client</artifactId>
<version>0.10.0-SNAPSHOT</version>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
<scope>true</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
</dependencies>
3.1.1 下载项目
在官方github项目中,把项目下载下来 https://github.com/ctripcorp/apollo,导入到Eclipse工程中。如下图
由于官方给出的分布式搭建需要加入很多启动参数,过于繁琐,可以考虑https://gitee.com/234gdfgsdf/open-capacity-platform/tree/master/apollo-master下载
项目组织结构(功能)[端口]
├── apollo -- 阿波罗配置中心
├ ├── apollo-configservice (提供配置的修改、发布等功能,服务对象是Apollo Portal) [8080]
├ ├── apollo-adminservice (提供配置的读取、推送等功能,服务对象是Apollo客户端)[8090]
├ ├── apollo-portal (管理界面) [8070]
├ └── apollo-zuul (阿波罗整合zuul网关)
└── open-eureka-server (服务注册中心)[1111]
3.2 application.properties 配置写入到Apollo配置中心 3.2.1 application.properties 如下原本是写在spring boot 工程中的配置信息,接下来写入到配置中心中。
spring.application.name=sop-api-gateway
server.port=9999
zuul.ignored-services="*"
3.2.2 创建apollo项目
这里我已经创建好了,就不做过多演示了。
将信息上传写入到配置文件中,然后在把工程中的application.properties文件删除。 3.2.3 新建app.properties文件
3.2.4 配置刷新zuul配置
配置页面发布即时更新zuul配置
application.java启动类
@RestController
@EnableZuulProxy
@EnableApolloConfig
@EnableDiscoveryClient
@SpringBootApplication
public class ApiGateWayApp {
public static void main(String[] args) {
SpringApplication.run(ApiGateWayApp.class, args);
}
}
注意加注解。
然后直接启动即可。。。。。。。
二. 搜狐cachecloud云平台管理
修改配置
项目编译
项目运行
主机规划
19 ls
20 mkdir -p /opt/cachecloud
21 ls
22 cd /opt/cachecloud
23 ls
24 vi init.sh
25 ls
26 chmod 777 init.sh
27 ./init.sh
28 cd /opt/cachecloud/
29 ls
30 ./init.sh root
31 ./init.sh cachecloud
32 ll
33 chown cachecloud.cachecloud -R /opt/cachecloud
34 ls
35 ll
36 ls
37 cd data
38 ls
39 cd ..
40 ls 41 cd conf
42 ls
43 cd ..
44 ls
45 cd redis/
46 ls
47 ifconfig
48 history效果预览
详细搭建可以参考http://www.ywnds.com/?p=10610
三. open-capacity-platform能力开放平台管理
1.注册中心
2.配置中心
3.认证服务器-->认证中心
3.1本认证中心采取的的数据库管理应用信息的方式来管理client_id client_secret,同时token的生成方式支持redis集群或者jwt
3.2由于spring security oauth 默认定义的/oauth/token 会验证client_id以及client_secret,如果不在数据库中会弹框,所以根据源码,自定义/oauth2/token节点以password方式的获取token,并给出友好提示 效果如下
一.错误的打开方式
1无效的client_id
2.无效的client_secret
3.用户名密码错误
二.正确的打开方式
4.部署
1.cd /root/sop/eureka-server/bin/ && ./start.sh 启动注册中心服务
2.cd /root/sop/config-center/configservice/bin/ && ./start.sh 启动配置中心configservice服务
3.cd /root/sop/config-center/adminservice/bin/ && ./start.sh 启动配置中心adminservice 服务
4.cd /root/sop/config-center/portalservice/bin/ && ./start.sh 启动配置中心portalservice服务
5.cd /root/sop/apollo-zuul/bin/ && ./start.sh 启动演示apollo-zuul项目
启动后效果预览
待续。。。。。。。。
Apollo-open-capacity-platform 微服务能力开发平台 (转)的更多相关文章
- Aooms_微服务基础开发平台实战_002_工程构建
一.关于框架更名的一点说明 最近在做年终总结.明年规划.还有几个项目需要了结.出解决方案,事情还比较多,死了不少脑细胞,距离上一篇文章发出已经过了3天,是不是有些人会认为我放弃了又不搞了,NONO,一 ...
- Aooms_微服务基础开发平台实战_001_开篇
一.引子 “ 微服务”近年来很火的一个词,如今的热度不亚于当年的SSH组合,各种开发框架.中间件.容器.概念层出不穷. 比如:dubbo.motan.zookeeper.springboot.spri ...
- Aooms_微服务基础开发平台实战_003_配置文件与简单的web环境搭建
一.前言 本篇文章介绍两个重点 (1) 工程核心配置文件application.yml (2) 如何在一个标准的的SpringCloud工程上构建起一个基本的web结构 二.配置文件applicati ...
- 携程框架Apollo实现.NET Core微服务统一配置(测试环境-单机)
Apollo实现.NET Core微服务统一配置(测试环境-单机) https://www.cnblogs.com/guolianyu/p/10065999.html 一.前言 注:此篇只是为测试环境 ...
- 流量染色与gRPC服务托管 微服务协作开发、灰度发布之流量染色 灰度发布与流量染色
大规模微服务场景下灰度发布与流量染色实践 https://mp.weixin.qq.com/s/UBoRKt3l91ffPagtjExmYw [go-micro]微服务协作开发.灰度发布之流量染色 - ...
- 微服务项目开发学成在线_day02 CMS前端开发
1 Vue.js与Webpack研究 开发版的浏览器:https://www.google.cn/intl/zh-CN/chrome/dev/ 前端的开发框架:微服务项目开发学成在线_Vue.js与W ...
- Dapr微服务应用开发系列2:Hello World与SDK初接触
题记:上篇介绍了Dapr的环境配置,这次我们来动手尝试一下Dapr应用的开发 Hello World Dapr应用的Hello World其实和其他的Hello World一样简单: 首先用你喜欢的语 ...
- 专题开发十三:JEECG微云高速开发平台-附录
专题开发十三:JEECG微云高速开发平台-附录 12.1UI库经常使用控件參考演示样例 序号 控件 解决方式 參考演示样例 1 datagrid数据列表.字段採用数据字典显示文本 <t:dgCo ...
- 开发指南专题八:JEECG微云高速开发平台数据字典
开发指南专题八:JEECG微云高速开发平台数据字典的使用 1.标签中使用数据字典 数据字典为系统中可能用到的字典类型数据提供了使用的便利性和可维护性.下面拉框标签<t:dictSele ...
随机推荐
- Codeforces 832 B. Petya and Exam-字符串匹配
补的若干年以前的题目,水题,太菜啦_(:з」∠)_ B. Petya and Exam time limit per test 2 seconds memory limit per test ...
- Missing Ranges -- LeetCode
Given a sorted integer array where the range of elements are [lower, upper] inclusive, return its mi ...
- POJ 3057 Evacuation(二分图匹配+BFS)
[题目链接] http://poj.org/problem?id=3057 [题目大意] 给出一个迷宫,D表示门,.表示人,X表示不可通行, 每个门每时间单位只允许一个人通过, 每个人移动一格的为一时 ...
- Extjs Ext.grid.column.Column 隐藏显示列
1.根据字段名字 grid.down("gridcolumn[dataIndex=PLAN_QTY]").show();//hide() 2.根据列号 grid.columns[1 ...
- log4j配置文件中的additivity属性
它是 子Logger 是否继承 父Logger 的 输出源(appender)的标志位.具体说,默认情况下子Logger会继承父Logger的appender,也就是说子Logger会在父Logger ...
- 【视频】 Linux高级程序设计01.2开发平台及Linux环境限制
[课程笔记] Linux环境限制 遵循规范,使用现有资源,明确系统限制,增量开发. (1)规范问题 编码的规范,让程序更易读.Linux编码规范. “见着如意”:变量,函数命名等能够让人看到名称就知道 ...
- 彻底理解Javascript 中的 Promise(-------------------------------***---------------------------------)
ES6原生提供了 Promise 对象. 到底是何方妖怪呢?打出来看看: 所谓 Promise,就是一个对象,用来传递异步操作的消息.它代表了某个未来才会知道结果的事件(通常是一个异步操作),并且这个 ...
- numpy自动生成数组
1 np.arange(),类似于range,通过指定开始值,终值和步长来创建表示等差数列的一维数组,注意该函数和range一样结果不包含终值. >>> np.arange(10) ...
- 新人补钙系列教程之:AS3 与 PHP 简单通信基础
package { import flash.display.Loader; import flash.events.Event; import flash.net.URLLoader; import ...
- 机器学习第4课:多变量线性回归(Linear Regression with Multiple Variables)
4.1 多维特征 目前为止,我们探讨了单变量/特征的回归模型,现在我们对房价模型增加更多的特征, 例如房间数楼层等,构成一个含有多个变量的模型,模型中的特征为(x1,x2,...,xn).