Skip to content

Commit

Permalink
Add 3.0 doc header.
Browse files Browse the repository at this point in the history
  • Loading branch information
KomachiSion committed Dec 3, 2024
1 parent 7187f0e commit e1c8118
Show file tree
Hide file tree
Showing 156 changed files with 34,869 additions and 1 deletion.
9 changes: 9 additions & 0 deletions src/components/common/Header/DocsMenu.astro
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,15 @@ export const docsItems = [
link: "/en/docs/next/overview/",
}
},
{
label: "3.0",
target: "_self",
link: "/docs/v3.0/what-is-nacos/",
translations: {
en: "3.0",
link: "/en/docs/v3.0/what-is-nacos/",
}
},
{
label: "2.3",
target: "_self",
Expand Down
2 changes: 1 addition & 1 deletion src/components/starlight/Head.astro
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ let canonical = Astro.site
if (canonical && Astro.url.pathname.includes("/docs/")) {
// 对于多版本文档来说,canonical需要改为latest的链接
const versionList = ["v1", "v2", "next", "v2.3"];
const versionList = ["v1", "v2", "next", "v2.3", "v3.0"];
const pathname = Astro.url.pathname;
try {
const version = pathname.split("/docs/")[1].split("/")[0];
Expand Down
224 changes: 224 additions & 0 deletions src/content/docs/v3.0/_sidebar.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,224 @@
[
{
"label": "概览",
"link": "docs/overview/",
"translations": {
"en": "Overview"
}
},
{
"label": "快速开始",
"translations": {
"en": "Quick Start"
},
"collapsed": false,
"items": [
{
"label": "Nacos",
"link": "docs/quickstart/quick-start/",
"translations": {
"en": "Nacos"
}
},
{
"label": "Nacos Docker",
"link": "docs/quickstart/quick-start-docker/",
"translations": {
"en": "Nacos Docker"
}
},
{
"label": "Nacos Kubernetes",
"link": "docs/quickstart/quick-start-kubernetes/",
"translations": {
"en": "Nacos Kubernetes"
}
}
]
},
{
"label": "用户手册",
"translations": {
"en": "User Manual"
},
"items": [
{
"label": "概览",
"autogenerate": { "directory": "manual/user/overview" }
},
{
"label": "JAVA SDK",
"autogenerate": { "directory": "manual/user/java-sdk" }
},
{
"label": "Golang SDK",
"autogenerate": { "directory": "manual/user/go-sdk" }
},
{
"label": "Python SDK",
"autogenerate": { "directory": "manual/user/python-sdk" }
},
{
"label": "Open API 手册",
"translations": {
"en": "Open API Manual"
},
"link": "docs/manual/user/open-api"
},
{
"label": "配置鉴权",
"translations": {
"en": "Authorization"
},
"link": "docs/manual/user/auth"
},
{
"label": "参数校验",
"translations": {
"en": "Parameters Check"
},
"link": "docs/manual/user/parameters-check"
},
{
"label": "寻址说明",
"translations": {
"en": "Addressing"
},
"link": "docs/manual/user/addressing"
}
]
},
{
"label": "运维手册",
"translations": {
"en": "Admin Manual"
},
"items": [
{
"label": "部署手册",
"translations": {
"en": "Deploy Manual"
},
"autogenerate": { "directory": "manual/admin/deployment" }
},
{
"label": "系统参数",
"translations": {
"en": "Nacos Configuration"
},
"link": "docs/manual/admin/system-configurations"
},
{
"label": "运维API",
"translations": {
"en": "Management API"
},
"link": "docs/manual/admin/admin-api"
},
{
"label": "鉴权手册",
"translations": {
"en": "Authorization Manual"
},
"link": "docs/manual/admin/auth"
},
{
"label": "升级手册",
"translations": {
"en": "Upgrading Manual"
},
"link": "docs/manual/admin/upgrading"
},
{
"label": "监控手册",
"translations": {
"en": "Monitor Manual"
},
"link": "docs/manual/admin/monitor"
}
,
{
"label": "控制台手册",
"translations": {
"en": "Console Manual"
},
"link": "docs/manual/admin/console"
}
]
},
{
"label": "插件",
"translations": {
"en": "Plugin"
},
"autogenerate": { "directory": "plugin" }
},
{
"label": "测试手册",
"translations": {
"en": "Test Manual"
},
"autogenerate": { "directory": "manual/test" }
},
{
"label": "生态融合",
"translations": {
"en": "Ecology"
},
"autogenerate": { "directory": "ecology" }
},
{
"label": "开源共建",
"translations": {
"en": "Contributor Guide"
},
"autogenerate": { "directory": "contribution" }
},
{
"label": "社区",
"translations": {
"en": "Community"
},
"autogenerate": { "directory": "community" }
},
{
"label": "将归档",
"translations": {
"en": "Archiving"
},
"collapsed": true,
"items": [
{
"label": "什么是 Nacos",
"translations": {
"en": "What is Nacos"
},
"link": "docs/what-is-nacos"
},
{
"label": "升级",
"translations": {
"en": "Upgrading"
},
"collapsed": true,
"autogenerate": { "directory": "upgrading" }
},
{
"label": "用户指南",
"translations": {
"en": "User Guide"
},
"collapsed": true,
"autogenerate": { "directory": "guide/user" }
},
{
"label": "运维指南",
"translations": {
"en": "Admin Guide"
},
"collapsed": true,
"autogenerate": { "directory": "guide/admin" }
}
]
}
]
135 changes: 135 additions & 0 deletions src/content/docs/v3.0/en/architecture.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
---
title: Nacos architecture
keywords: [Nacos,architecture]
description: Nacos architecture
---

# Nacos architecture

> Document optimizing...
## Basic Architecture and Concepts

![nacos_arch.jpg](https://cdn.nlark.com/yuque/0/2019/jpeg/338441/1561217892717-1418fb9b-7faa-4324-87b9-f1740329f564.jpeg)

### Service

A software function or a set of software functions (such as the retrieval of specified information or the execution of a set of operations) with the purpose that different clients can be reused for different purposes (for example, through a cross-process network call). Nacos supports almost all types of services:
[Kubernetes Service](https://kubernetes.io/docs/concepts/services-networking/service/)

[gRPC](https://grpc.io/docs/guides/concepts.html#service-definition)
[ | Dubbo RPC Service](https://dubbo.apache.org/#/?lang=en-us)

[Spring Cloud RESTful Service](https://spring.io/projects/spring-cloud)

### Service Registry

The database of services, instances and metadata. Service instances are registered with the service registry on startup and deregistered on shutdown. Clients of the service and/or routers query the service registry to find the available instances of a service. A service registry might invoke a service instances health check API to verify that it is able to handle requests.

### Service Metadata

Data describing services such as service endpoints, service labels, service version, service instance weights, routing rules, security policies.

### Service Provider

A process or application which provides reusable and callable services.

### Service Consumer

A process or application which initiates a call to a service.

### Configuration

During system development, developers usually extract some parameters or variables that need to be changed from the code and manage them in a separate configuration file. This enables the static system artifacts or deliverables (such as WAR and JAR packages) to fit with the physical operating environment in a better way. Configuration management is generally a part of system deployment, which is executed by the administrator or operation and maintenance personnel. Configuration modification is an effective method to adjust the behavior of a running system.

### Configuration Management

In the data center, all configuration-related activities such as editing, storage, distribution, change management, history version management, and change audit are collectively referred to as configuration management.

### Naming Service

Mapping the "names" of all the objects and entities in the distributed system to the associated metadata, for example, ```ServiceName``` -> ```Endpoints\Version etc...```, ```Distributed Lock Name``` -> ```Lock Owner/Status Info```, ```DNS Domain Name``` -> ```IP List```. Service discovery and DNS are the two major scenarios of naming service.

### Configuration Service

Providing dynamic configuration, service metadata and configuration management for other services or application.

### [More concepts...](./concepts.md)

## Introduction to logical architecture and its components

![nacos-logic.jpg](https://cdn.nlark.com/yuque/0/2019/png/338441/1561217775318-6e408805-18bb-4242-b4e9-83c5b929b469.png)

- Service Management: Implement services CRUD, domain name CRUD, service health check, service weight management, etc.
- Configuration Management: Implement configuration CRUD, version management, grayscale management, monitoring management, push trajectory, aggregate data, etc.
- Metadata Management: Provides metadata CURD and marking capabilities
- Plug-in mechanism: implements three modules to share the ability to implement the extended point SPI mechanism
- Event mechanism: implement asynchronous event notification, sdk data change asynchronous notification and other logic
- Log module: Manage log classification, log level, log portability (especially to avoid conflicts), log format, exception code + help documentation
- Callback mechanism: sdk informs the data and calls back user processing through a unified mode. Interface and data structures need to be scalable
- Addressing mode: solve various addressing modes such as ip, domain name, nameserver, broadcast, etc., need to be expandable
- Push channel: solve the push performance problem between server and storage, server, server and sdk
- Capacity management: manage each tenant, the capacity under the group, prevent the storage from being blasted, affecting service availability
- Traffic management: control the request frequency, the number of long links, the size of the message, and request flow control according to multiple dimensions such as tenant and group.
- Caching mechanism: disaster recovery directory, local cache, server cache mechanism. Disaster recovery catalogue requires tools
- Startup mode: Start different programs + UI according to stand-alone mode, configuration mode, service mode, dns mode, or all mode
- Consistency Protocol: Resolve different data, different consistency requirements, different consistency mechanisms
- Storage module: solve data persistence, non-persistent storage, solve data fragmentation problem
- Nameserver: Resolve the routing problem from namespace to clusterid, solve the mapping problem between user environment and nacos physical environment
- CMDB: Solve the metadata storage, docking problems with the three-party cmdb system, solving applications, people, resource relationships
- Metrics: Exposes standard metrics data for easy access to three-way monitoring systems
- Trace: Exposure standard trace, easy to open with SLA system, log whitening, push trajectory, etc., and can be connected with metering and billing system
- Access management: equivalent to Ali cloud service, assign identity, capacity, authority process
- User Management: Resolve issues such as user management, login, sso, etc.
- Rights Management: Resolve issues such as identity, access control, role management, etc.
- Audit system: extended interface facilitates access to different company audit systems
- Notification system: Core data changes, or operations, facilitated through the SMS system, notify the corresponding person data changes
- OpenAPI: exposes the standard Rest style HTTP interface, easy to use, and easy for multi-language integration
- Console: easy to use console, do service management, configuration management, etc.
- SDK: Multilingual sdk
- Agent: dns-f similar mode, or integration with mesh and other programs
- CLI: Lightweight management of the product on the command line, as easy as git

## Domain Model

### Data Model

The Nacos data model Key is uniquely determined by the triplet. The Namespace defaults to an empty string, the public namespace (public), and the group defaults to DEFAULT_GROUP.

![nacos_data_model](https://cdn.nlark.com/yuque/0/2019/jpeg/338441/1561217857314-95ab332c-acfb-40b2-957a-aae26c2b5d71.jpeg)

### Service Entity Relationship Model

![nacos_naming_data_model](https://cdn.nlark.com/yuque/0/2019/jpeg/338441/1561217924697-ba504a35-129f-4fc6-b0df-1130b995375a.jpeg)

### Config Entity Relationship Model

Around the configuration, there are mainly two associated entities, one is the configuration change history, and the other is the service tag (used for marking classification, convenient for indexing), which is associated by ID.

![nacos_config_er](https://cdn.nlark.com/yuque/0/2019/jpeg/338441/1561217958896-4465757f-f588-4797-9c90-a76e604fabb4.jpeg)


## Class view

### Nacos-SDK Class view

// TODO Service part to be continued

![nacos_sdk_class_relation](https://cdn.nlark.com/yuque/0/2022/png/25574784/1650771676187-d95a9e45-8656-4d1a-8b5b-ed63a23a816b.png)


## Artifacts, Deployment, and Start Mode

![undefined](https://cdn.yuque.com/lark/0/2018/png/15914/1531730742844-e8325932-258b-49b2-9473-8d1199efe20d.png)

### Two Artifacts

Nacos supports both standard Docker images (v0.2.0) and nacos-.zip(tar.gz). You can choose the appropriate build to deploy the Nacos service according to your needs.

### Two Start Modes

Nacos supports two start modes. you can merging the Service Registry and the Config Center in one process or deploying them in separately cluster.

### Free Public Cloud Service on Alibaba Cloud

In addition to deploying and launching Nacos services by users themselves, Nacos also supports public cloud. Nacos public cloud service will be free in Alibaba Cloud's commercial service (such as [MSE](https://cn.aliyun.com/product/aliware/mse?spm=nacos-website.topbar.0.0.0), [EDAS](https://www.aliyun.com/product/edas)). We also welcome other public cloud providers to offer Nacos public cloud services.
Loading

0 comments on commit e1c8118

Please sign in to comment.