According to different scenarios, apolloconfig deployment architecture will have a variety of, here do not discuss the details, only from the macro perspective of the deployment architecture, to introduce the various deployment options
Use flowchart to express the deployment method, here first introduce some basic concepts
Dependencies are expressed with
graph LR
1 --> 2
Indicates that 1 depends on 2, i.e. 2 must exist for 1 to work properly, e.g.
flowchart LR
Application --> MySQL
Means that the application needs to use MySQL to work properly
Dependencies can be complex, as well as having multiple layers of dependencies, for example
flowchart LR
SA[Service A] --> RC[Registration Center]
SA[Service A] --> B[Service B] --> MySQL
SA[Service A] --> Redis
Service A needs registry, Service B, Redis
And Service B needs MySQL
The containment relationship is specified with
graph
subgraph a
b
end
Indicates that a contains b, i.e. b is part of a. The containment relationship may be nested, e.g.
flowchart LR
subgraph Linux-Server
subgraph JVM1
Thread1.1
Thread1.2
end
subgraph JVM2
Thread2.1
end
MySQL
Redis
end
Means that on a Linux server, there are MySQL, Redis and 2 JVMs running, and there are Threads in each JVM
The scenario of standalone deployment is usually for novice learners, or for testing environments with low performance requirements within the company, not for production environments
This is the simplest and most convenient way to deploy standalone
Requires:
PortalDB
and ConfigDB
As shown below, all modules are deployed on the same Linux machine, with a total of 3 JVM processes
flowchart LR
m[Meta Server]
e[Eureka]
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server
subgraph JVM8080
m
e
c
end
subgraph JVM8090
a
end
subgraph JVM8070
p
end
end
c --> configdb
a --> configdb
p --> portaldb
JVM8080: the network port exposed to the public is 8080, there are Meta Server, Eureka, Config Service inside, and Config Service uses ConfigDB
JVM8090: the network port exposed to the public is 8090, there is Admin Service inside, and Admin Service uses ConfigDB
JVM8070: the network port exposed to the public is 8070, there is Portal inside, and Portal uses PortalDB
If you add the dependency between modules, flowchart will become
flowchart LR
m[Meta Server]
e[Eureka]
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server
subgraph JVM8080
m
e
c
end
subgraph JVM8090
a
end
subgraph JVM8070
p
end
end
c --> configdb
a --> configdb
p --> portaldb
m --> e
c --> e
a --> e
p --> m
p --> a
Config Service and Admin Service will register themselves to Eureka
Portal discovers Admin Service through Meta Server service
To make flowchart look more concise, you can just represent the dependencies between processes
flowchart LR
m[Meta Server]
e[Eureka]
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server
subgraph JVM8080
m
e
c
end
subgraph JVM8090
a
end
subgraph JVM8070
p
end
end
JVM8080 --> configdb
JVM8090 --> configdb
JVM8070 --> portaldb
jvm8090 --> jvm8080
jvm8070 --> jvm8090
Process JVM8070 depends on process JVM8090 and PortalDB
Process JVM8090 depends on process JVM8080 and ConfigDB
Process JVM8080 depends on process JVM8080 and ConfigDB
The 3 JVM processes can also be spread across 3 Linux machines
Required.
2 databases
flowchart LR
m[Meta Server]
e[Eureka]
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server 1
subgraph JVM8080
m
e
c
end
end
subgraph Linux Server 2
subgraph JVM8090
a
end
end
subgraph Linux Server 3
subgraph JVM8070
p
end
end
JVM8080 --> configdb
JVM8090 --> configdb
JVM8070 --> portaldb
jvm8090 --> jvm8080
jvm8070 --> jvm8090
But usually we deploy Config Service and Admin Service on a single Linux server
Required:
2 databases
flowchart LR
m[Meta Server]
e[Eureka]
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server 1
subgraph JVM8080
m
e
c
end
subgraph JVM8090
a
end
end
subgraph Linux Server 2
subgraph JVM8070
p
end
end
JVM8080 --> configdb
JVM8090 --> configdb
JVM8070 --> portaldb
jvm8090 --> jvm8080
jvm8070 --> jvm8090
Later, in order to flowchart more concise, the content in JVM8080 will be simplified, only the Config Service will be displayed, and the Meta Server and Eureka inside will no longer be displayed
flowchart LR
subgraph JVM8080
m[Meta Server]
e[Eureka]
c[Config Service]
end
subgraph new-JVM8080[JVM8080]
new-c[Config Service]
end
JVM8080 --> |simplify| new-JVM8080
So the deployment architecture can be simplified and represented as
flowchart LR
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server 1
subgraph JVM8080
c
end
subgraph JVM8090
a
end
end
subgraph Linux Server 2
subgraph JVM8070
p
end
end
JVM8080 --> configdb
JVM8090 --> configdb
JVM8070 --> portaldb
jvm8090 --> jvm8080
jvm8070 --> jvm8090
A single environment basically can not meet the actual application scenario, for example, the company has SIT test environment and UAT test environment, then you need to deploy two environments to provide configuration services
It is easy to think of the deployment architecture as follows, repeat the single machine, single environment deployment architecture 2 times
Required:
4 databases
flowchart LR
subgraph SIT
c1[SIT Config Service]
a1[SIT Admin Service]
p1[SIT Portal]
configdb1[(SIT ConfigDB)]
portaldb1[(SIT PortalDB)]
subgraph SIT Linux Server
subgraph sit-jvm-8080[SIT JVM8080]
c1
end
subgraph sit-jvm-8090[SIT JVM8090]
a1
end
subgraph sit-jvm-8070[SIT JVM8070]
p1
end
end
sit-jvm-8080 --> configdb1
sit-jvm-8090 --> configdb1
sit-jvm-8070 --> portaldb1
sit-jvm-8090 --> sit-jvm-8080
sit-jvm-8070 --> sit-jvm-8090
end
subgraph UAT
c2[UAT Config Service]
a2[UAT Admin Service]
p2[UAT Portal]
configdb2[(UAT ConfigDB)]
portaldb2[(UAT PortalDB)]
subgraph UAT Linux Server
subgraph uat-jvm-8080[UAT JVM8080]
c2
end
subgraph uat-jvm-8090[UAT JVM8090]
a2
end
subgraph uat-jvm-8070[UAT JVM8070]
p2
end
end
uat-jvm-8080 --> configdb2
uat-jvm-8090 --> configdb2
uat-jvm-8070 --> portaldb2
uat-jvm-8090 --> uat-jvm-8080
uat-jvm-8070 --> uat-jvm-8090
end
But this solution, there will be 2 Portal interface, can not be 1 interface to manage 2 environments, the use of experience is not very good, Portal can actually be deployed only 1 set, the recommended deployment architecture is as follows
3 databases: 1 PortalDB + 1 SIT's ConfigDB + 1 UAT's ConfigDB
flowchart LR
p[Portal]
portaldb[PortalDB]
p --> portaldb
subgraph Portal Linux Server
subgraph JVM8070
p
end
end
subgraph SIT
c1[SIT Config Service]
a1[SIT Admin Service]
configdb1[(SIT ConfigDB)]
subgraph SIT Linux Server
subgraph sit-jvm-8080[SIT JVM8080]
c1
end
subgraph sit-jvm-8090[SIT JVM8090]
a1
end
end
sit-jvm-8080 --> configdb1
sit-jvm-8090 --> configdb1
sit-jvm-8090 --> sit-jvm-8080
end
subgraph UAT
c2[UAT Config Service]
a2[UAT Admin Service]
configdb2[(UAT ConfigDB)]
subgraph UAT Linux Server
subgraph uat-jvm-8080[UAT JVM8080]
c2
end
subgraph uat-jvm-8090[UAT JVM8090]
a2
end
end
uat-jvm-8080 --> configdb2
uat-jvm-8090 --> configdb2
uat-jvm-8090 --> uat-jvm-8080
end
jvm8070 --> sit-jvm-8090
jvm8070 --> uat-jvm-8090
Assuming that the usage scenario of 3 environments, SIT, UAT and PP, now needs to be satisfied.
On top of the previous dual environments, add 1 more PP environment Linux service and ConfigDB can be added, Portal to manage these 3 environments by modifying the configuration
flowchart LR
p[Portal]
portaldb[PortalDB]
p --> portaldb
subgraph Portal Linux Server
subgraph JVM8070
p
end
end
subgraph SIT
c1[SIT Config Service]
a1[SIT Admin Service]
configdb1[(SIT ConfigDB)]
subgraph SIT Linux Server
subgraph sit-jvm-8080[SIT JVM8080]
c1
end
subgraph sit-jvm-8090[SIT JVM8090]
a1
end
end
sit-jvm-8080 --> configdb1
sit-jvm-8090 --> configdb1
sit-jvm-8090 --> sit-jvm-8080
end
subgraph UAT
c2[UAT Config Service]
a2[UAT Admin Service]
configdb2[(UAT ConfigDB)]
subgraph UAT Linux Server
subgraph uat-jvm-8080[UAT JVM8080]
c2
end
subgraph uat-jvm-8090[UAT JVM8090]
a2
end
end
uat-jvm-8080 --> configdb2
uat-jvm-8090 --> configdb2
uat-jvm-8090 --> uat-jvm-8080
end
subgraph PP
c3[PP Config Service]
a3[PP Admin Service]
configdb3[(PP ConfigDB)]
subgraph PP Linux Server
subgraph pp-jvm-8080[PP JVM8080]
c3
end
subgraph pp-jvm-8090[PP JVM8090]
a3
end
end
pp-jvm-8080 --> configdb3
pp-jvm-8090 --> configdb3
pp-jvm-8090 --> pp-jvm-8080
end
jvm8070 --> sit-jvm-8090
jvm8070 --> uat-jvm-8090
jvm8070 --> pp-jvm-8090
The principle is the same as above, 1 Linux server per environment + 1 ConfigDB
Then Portal can add the information of the new environment
1 environment only 1 Config Service process, can not meet the high availability, in order to avoid a single point of downtime affect the availability of the system, the need for multi-instance deployment, that is, the deployment of multiple Java processes on different Linux servers
Returning to the common non-high-availability deployment approach, the
flowchart LR
c[Config Service]
a[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
subgraph Linux Server 1
subgraph JVM8080
c
end
subgraph JVM8090
a
end
end
subgraph Linux Server 2
subgraph JVM8070
p
end
end
JVM8080 --> configdb
JVM8090 --> configdb
JVM8070 --> portaldb
JVM8090 --> JVM8080
JVM8070 --> JVM8090
When Linux Server 1 is down, the client can only read the config-cache on the local disk. If you need to prevent a single Linux from going down and making the Config Service unavailable, you can try adding another Linux machine.
Required:
2 databases
flowchart LR
c-1[Config Service]
c-2[Config Service]
a-1[Admin Service]
a-2[Admin Service]
p[Portal]
configdb[(ConfigDB)]
portaldb[(PortalDB)]
JVM8080-1[JVM8080]
JVM8080-2[JVM8080]
JVM8090-1[JVM8090]
JVM8090-2[JVM8090]
subgraph Linux Server 1.1
subgraph JVM8080-1[JVM8080]
c-1
end
subgraph JVM8090-1[JVM8090]
a-1
end
end
subgraph Linux Server 1.2
subgraph JVM8080-2[JVM8080]
c-2
end
subgraph JVM8090-2[JVM8090]
a-2
end
end
subgraph Linux Server 2
subgraph JVM8070
p
end
end
JVM8080-1 --> configdb
JVM8090-1 --> configdb
JVM8080-2 --> configdb
JVM8090-2 --> configdb
JVM8070 --> portaldb
JVM8090-1 --> JVM8080-1
JVM8090-2 --> JVM8080-2
JVM8070 --> JVM8090-1
JVM8070 --> JVM8090-2
With this deployment, if Linux Server 1.1 or Linux Server 1.2 is down, the system is still available.
On the basis of the above, if the number of clients is large (e.g. tens of thousands of Java processes), you can horizontally extend the Config Service by introducing Linux Server 1.3, Linux Server 1.4, ...
Admin Service can be much less than Config Service in terms of number due to only Portal access.
Please refer to Apollo Performance Test Report for details on how to evaluate the number of Config Service.
As in 2.3 Single machine, dual environment, if you want to make both SIT and UAT highly available, you only need to add more machines to each environment, as shown below, each environment has 2 Linux Servers, if you have performance requirements, you can use more machines in each environment to deploy Config Service that can be
flowchart LR
p[Portal]
portaldb[(PortalDB)]
p --> portaldb
subgraph Portal Linux Server
subgraph JVM8070
p
end
end
subgraph SIT
sit-c1[SIT Config Service]
sit-a1[SIT Admin Service]
sit-c2[SIT Config Service]
sit-a2[SIT Admin Service]
sit-configdb[(SIT ConfigDB)]
subgraph SIT Linux Server 2.1
subgraph sit-c1-jvm-8080[SIT JVM8080]
sit-c1
end
subgraph sit-c1-jvm-8090[SIT JVM8090]
sit-a1
end
end
subgraph SIT Linux Server 2.2
subgraph sit-c2-jvm-8080[SIT JVM8080]
sit-c2
end
subgraph sit-c2-jvm-8090[SIT JVM8090]
sit-a2
end
end
sit-c1-jvm-8080 --> sit-configdb
sit-c1-jvm-8090 --> sit-configdb
sit-c2-jvm-8080 --> sit-configdb
sit-c2-jvm-8090 --> sit-configdb
sit-c1-jvm-8090 --> sit-c1-jvm-8080
sit-c2-jvm-8090 --> sit-c2-jvm-8080
end
subgraph UAT
uat-c1[UAT Config Service]
uat-a1[UAT Admin Service]
uat-c2[UAT Config Service]
uat-a2[UAT Admin Service]
uat-configdb[(UAT ConfigDB)]
subgraph UAT Linux Server 2.1
subgraph uat-c1-jvm-8080[UAT JVM8080]
uat-c1
end
subgraph uat-c1-jvm-8090[UAT JVM8090]
uat-a1
end
end
subgraph UAT Linux Server 2.2
subgraph uat-c2-jvm-8080[UAT JVM8080]
uat-c2
end
subgraph uat-c2-jvm-8090[UAT JVM8090]
uat-a2
end
end
uat-c1-jvm-8080 --> uat-configdb
uat-c1-jvm-8090 --> uat-configdb
uat-c2-jvm-8080 --> uat-configdb
uat-c2-jvm-8090 --> uat-configdb
uat-c1-jvm-8090 --> uat-c1-jvm-8080
uat-c2-jvm-8090 --> uat-c2-jvm-8080
end
jvm8070 --> sit-c1-jvm-8090
jvm8070 --> sit-c2-jvm-8090
jvm8070 --> uat-c1-jvm-8090
jvm8070 --> uat-c2-jvm-8090
On top of the above, to add an environment such as BETA environment, you need to add 2 and more Linux servers + 1 ConfigDB
Portal adds the information of the new environment, pointing to apollo.meta of BETA environment
In the actual production environment, many companies isolate their test environment, so the production environment is a single environment, with only one PRO environment
When there is only 1 server room, refer to 3.2 Highly available, single environment
If there are 2 server rooms, usually there is network isolation between the server rooms. If it is a co-located server room, idc1 and idc2, you can use the following deployment method
flowchart LR
idc1-p[idc1 Portal]
idc2-p[idc2 Portal]
portaldb[(PortalDB)]
idc1-p --> portaldb
idc2-p --> portaldb
configdb[(ConfigDB)]
idc1-c1-jvm-8080 --> configdb
idc1-c1-jvm-8090 --> configdb
idc1-c2-jvm-8080 --> configdb
idc1-c2-jvm-8090 --> configdb
idc2-c1-jvm-8080 --> configdb
idc2-c1-jvm-8090 --> configdb
idc2-c2-jvm-8080 --> configdb
idc2-c2-jvm-8090 --> configdb
subgraph idc1
subgraph idc1 Portal Linux Server
subgraph idc1-JVM8070
idc1-p
end
end
idc1-c1[idc1 Config Service]
idc1-a1[idc1 Admin Service]
idc1-c2[idc1 Config Service]
idc1-a2[idc1 Admin Service]
subgraph idc1 Linux Server 2.1
subgraph idc1-c1-jvm-8080[idc1 JVM8080]
idc1-c1
end
subgraph idc1-c1-jvm-8090[idc1 JVM8090]
idc1-a1
end
end
subgraph idc1 Linux Server 2.2
subgraph idc1-c2-jvm-8080[idc1 JVM8080]
idc1-c2
end
subgraph idc1-c2-jvm-8090[idc1 JVM8090]
idc1-a2
end
end
idc1-c1-jvm-8090 --> idc1-c1-jvm-8080
idc1-c2-jvm-8090 --> idc1-c2-jvm-8080
end
subgraph idc2
subgraph idc2 Portal Linux Server
subgraph idc2-JVM8070
idc2-p
end
end
idc2-c1[idc2 Config Service]
idc2-a1[idc2 Admin Service]
idc2-c2[idc2 Config Service]
idc2-a2[idc2 Admin Service]
subgraph idc2 Linux Server 2.1
subgraph idc2-c1-jvm-8080[idc2 JVM8080]
idc2-c1
end
subgraph idc2-c1-jvm-8090[idc2 JVM8090]
idc2-a1
end
end
subgraph idc2 Linux Server 2.2
subgraph idc2-c2-jvm-8080[idc2 JVM8080]
idc2-c2
end
subgraph idc2-c2-jvm-8090[idc2 JVM8090]
idc2-a2
end
end
idc2-c1-jvm-8090 --> idc2-c1-jvm-8080
idc2-c2-jvm-8090 --> idc2-c2-jvm-8080
end
idc1-JVM8070 --> idc1-c1-jvm-8090
idc1-JVM8070 --> idc1-c2-jvm-8090
idc2-JVM8070 --> idc2-c1-jvm-8090
idc2-JVM8070 --> idc2-c2-jvm-8090
Each server room has its own set of Portal, Config Service, Admin Service
For ConfigDB, under the same city and dual server rooms, the ConfigDB connected is the same, there is no 2 different ConfigDB, for PortalDB is also the same, need to connect the same
ConfigDB and PortalDB are not put into idc1 or idc2 in the diagram, you need to choose the suitable MySQL architecture and deployment method by yourself.
In ctrip, We deployment strategy is as follows.
Sample deployment diagram contributed by @lyliyongblue (we recommend right-clicking a new window to open a larger version).