Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: update blue green update document #1081

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

Rory-Z
Copy link
Member

@Rory-Z Rory-Z commented Oct 22, 2024

Summary by CodeRabbit

  • Documentation
    • Revised English and Chinese documents on blue-green deployment for EMQX, improving clarity and usability.
    • Enhanced background sections to detail limitations of traditional rolling updates.
    • Updated steps for creating new Pods and redirecting service traffic during upgrades.
    • Introduced state diagrams for clearer visual representation of the upgrade process.
    • Expanded configuration examples and monitoring sections to provide comprehensive user guidance.

@Rory-Z Rory-Z requested a review from a team as a code owner October 22, 2024 10:03
Copy link

codecov bot commented Oct 22, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 76.04%. Comparing base (75eb1ef) to head (d43a316).

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1081      +/-   ##
==========================================
- Coverage   76.27%   76.04%   -0.23%     
==========================================
  Files          69       69              
  Lines        6250     6250              
==========================================
- Hits         4767     4753      -14     
- Misses       1245     1255      +10     
- Partials      238      242       +4     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@Rory-Z Rory-Z force-pushed the docs/update-blue-grees branch from 55ba0e0 to 3bbf6ef Compare October 22, 2024 10:20
Copy link

coderabbitai bot commented Oct 22, 2024

Walkthrough

The pull request involves updates to the documentation for the blue-green deployment strategy of the EMQX cluster. Changes include enhanced clarity in the task objectives, background, and solution sections, with a focus on creating new Pods instead of clusters. The upgrade process has been reformatted for readability, and state diagrams have replaced previous diagrams to illustrate the upgrade steps. Configuration examples have been updated, and a new monitoring section has been added to provide tools for tracking connection metrics during the upgrade.

Changes

File Path Change Summary
docs/en_US/tasks/configure-emqx-blueGreenUpdate.md Revised for clarity on blue-green deployment, expanded background, restructured solution, added state diagram, updated deployment commands, and added monitoring section.
docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md Improved explanation of blue-green deployment, expanded background, restructured solution, added state diagram, updated configuration examples, and expanded monitoring section.

Sequence Diagram(s)

sequenceDiagram
    participant User
    participant EMQX Cluster
    participant New Pods
    participant Old Pods

    User->>EMQX Cluster: Initiate Upgrade
    EMQX Cluster->>New Pods: Create New Pods
    New Pods->>EMQX Cluster: Join Existing Cluster
    EMQX Cluster->>User: Redirect Traffic to New Pods
    User->>Old Pods: Gradually Remove Old Pods
    Old Pods->>EMQX Cluster: Evacuate Connections
    EMQX Cluster->>User: Upgrade Complete
Loading

🐇 "In the garden where upgrades bloom,
New Pods arise, dispelling gloom.
Old ones fade, as traffic flows,
With YAML guides, the process grows.
Monitoring metrics, clear as day,
Blue-green magic, hip-hip-hooray!" 🌼


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (5)
docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (2)

28-88: LGTM: Improved solution section with state diagram

The solution section now provides a clearer outline of the blue-green upgrade process. The addition of the state diagram significantly enhances the understanding of the upgrade steps.

Consider replacing hard tabs with spaces in the Mermaid diagram code for consistent formatting across different editors and platforms. For example:

-	state Step1 {
+  state Step1 {
🧰 Tools
🪛 Markdownlint

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)


85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)


Line range hint 224-285: LGTM: New monitoring section with helpful commands

The new section on monitoring the upgrade process is a valuable addition. It provides clear commands for checking the status of the EMQX cluster and node evacuation process, along with detailed explanations of the output fields.

Consider adding a brief explanation of how users can interpret the state field in the node evacuation status output. For example:

   `state`: 节点疏散阶段。
+  可能的值包括 "evacuating"(正在疏散), "waiting_takeover"(等待接管)等,表示当前疏散的进度。

This addition would help users better understand the evacuation process.

docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (3)

29-89: LGTM: Enhanced solution explanation with visual representation

The expanded solution section with step-by-step explanation and the addition of the mermaid diagram greatly improve the document's clarity. The visual representation of the upgrade process is particularly helpful for understanding the complex steps involved.

Consider applying these minor formatting improvements to the mermaid code block:

  1. Remove the extra blank lines (lines 39, 59, 67, 74, 81) within the mermaid diagram to maintain consistency.
  2. Align the indentation of the state definitions (e.g., lines 40-48, 56-86) to improve readability.
🧰 Tools
🪛 Markdownlint

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)


86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)


Line range hint 91-224: LGTM: Comprehensive configuration examples and explanations

The configuration update strategy section provides clear YAML examples for both apps.emqx.io/v2beta1 and apps.emqx.io/v1beta4 versions, along with helpful explanations of the parameters. The use of tabs to separate different versions improves readability.

In the deployment command for the v2beta1 version (line 125), consider removing the colon after "as" to improve readability:

-Save the above content as: `emqx-update.yaml`, execute the following command to deploy EMQX, in this example, just deploy EMQX core node cluster without replicant node:
+Save the above content as `emqx-update.yaml`, execute the following command to deploy EMQX, in this example, just deploy EMQX core node cluster without replicant node:
🧰 Tools
🪛 LanguageTool

[uncategorized] ~123-~123: Loose punctuation mark.
Context: ...n (unit: count/second)。 sessEvictRate: MQTT Session evacuation rate, only supp...

(UNLIKELY_OPENING_PUNCTUATION)


[typographical] ~125-~125: Do not use a colon (:) before a series that is introduced by a preposition (‘as’). Remove the colon or add a noun or a noun phrase after the preposition.
Context: ... count/second)。 Save the above content as: emqx-update.yaml, execute the followi...

(RP_COLON)


Line range hint 225-290: LGTM: Well-documented upgrade process with clear examples

The upgrade process section provides comprehensive instructions for connecting to the EMQX cluster, triggering the upgrade, and monitoring its progress. The inclusion of JSON output examples is particularly helpful for understanding the status of nodes and the evacuation process.

In the code block for checking node evacuations status (lines 244-268), consider removing the extra blank line at the beginning to maintain consistency with other code blocks in the document:

-
-  $ kubectl get emqx emqx-ee -o json | jq ".status.nodeEvacuationsStatus"
+$ kubectl get emqx emqx-ee -o json | jq ".status.nodeEvacuationsStatus"
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between be90806 and 3bbf6ef.

📒 Files selected for processing (2)
  • docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (3 hunks)
  • docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (3 hunks)
🧰 Additional context used
🪛 Markdownlint
docs/en_US/tasks/configure-emqx-blueGreenUpdate.md

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)


86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)


85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)

🪛 LanguageTool
docs/en_US/tasks/configure-emqx-blueGreenUpdate.md

[typographical] ~125-~125: Do not use a colon (:) before a series that is introduced by a preposition (‘as’). Remove the colon or add a noun or a noun phrase after the preposition.
Context: ... count/second)。 Save the above content as: emqx-update.yaml, execute the followi...

(RP_COLON)

🔇 Additional comments (5)
docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (3)

Line range hint 1-27: LGTM: Improved introduction and background sections

The enhanced introduction and expanded background section provide a clearer context for the blue-green deployment strategy. The content is well-structured and informative, effectively highlighting the limitations of traditional rolling updates.

🧰 Tools
🪛 Markdownlint

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)


85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)


Line range hint 89-223: LGTM: Updated configuration examples

The configuration examples for both apps.emqx.io/v2beta1 EMQX and apps.emqx.io/v1beta4 EmqxEnterprise have been clearly updated. The examples now include parameters for managing connection and session eviction rates, which are crucial for the blue-green update strategy. The use of tabs for different EMQX versions improves readability and user experience.


Line range hint 286-301: LGTM: Informative Grafana monitoring section

The Grafana monitoring section effectively illustrates the benefits of the blue-green deployment strategy. The included graph and its explanation clearly demonstrate how the upgrade process maintains a stable connection count, highlighting the smooth transition and minimal impact on the service.

🧰 Tools
🪛 Markdownlint

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)


85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)

docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (2)

Line range hint 1-28: LGTM: Improved clarity in introduction and background

The updates to the task objective and background sections provide a clearer context for the blue-green deployment strategy. The explanation of the problems with traditional rolling updates is well-articulated and helps readers understand the need for this approach.

🧰 Tools
🪛 Markdownlint

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)


86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)


92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)


Line range hint 293-309: LGTM: Valuable addition of Grafana Monitoring section

The new Grafana Monitoring section is a valuable addition to the document. It provides visual insights into the upgrade process through a monitoring graph and clear explanations of the graph components. This section effectively demonstrates the smooth transition of connections during the blue-green deployment, reinforcing the benefits of this upgrade strategy.

🧰 Tools
🪛 Markdownlint

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)


86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)


92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)

@Rory-Z Rory-Z force-pushed the docs/update-blue-grees branch from 3bbf6ef to e41816a Compare October 22, 2024 10:25
@Rory-Z Rory-Z requested a review from zmstone October 22, 2024 13:58
Signed-off-by: Rory Z <16801068+Rory-Z@users.noreply.github.com>
@Rory-Z Rory-Z force-pushed the docs/update-blue-grees branch from e41816a to d43a316 Compare October 22, 2024 13:59
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (8)
docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (2)

28-88: LGTM with minor formatting suggestions

The solution section clearly outlines the steps for blue-green deployment, and the mermaid diagram provides an excellent visual representation of the process. However, there are some minor formatting issues in the mermaid diagram.

Consider applying the following changes to improve the formatting:

  1. Remove the hard tabs at the beginning of lines 38 and 85.
  2. Ensure consistent indentation throughout the mermaid diagram for better readability.

Example:

-	state Step1 {
+  state Step1 {
     [*] --> CreateNewPods
     CreateNewPods: Create new pods
     CreateNewPods -->  NewPodsJoinTheCluster
     NewPodsJoinTheCluster: New pods join the cluster
     NewPodsJoinTheCluster --> WaitNewPodsReady
     WaitNewPodsReady: Wait new pods ready
     WaitNewPodsReady --> LBServiceSelectNewPods
     LBServiceSelectNewPods: Redirect the Service to the new Pods and remove the old Pods from the Service
     LBServiceSelectNewPods --> [*]
   }
🧰 Tools
🪛 Markdownlint

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)


85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)


Line range hint 224-293: LGTM with minor formatting suggestions

The upgrade process section provides clear steps and example commands for upgrading the EMQX cluster. The inclusion of commands to check cluster status and node evacuation status is particularly helpful.

Consider applying the following changes to improve the formatting of the code blocks:

  1. Add language identifiers to the code blocks for better syntax highlighting. For example:
-  ```
+  ```bash
   kubectl get emqx emqx-ee -o json | jq '.status.coreNodesStatus'
   {
     "currentReplicas": 2,
     "currentRevision": "54fc496fb4",
     "readyReplicas": 4,
     "replicas": 2,
     "updateReplicas": 2,
     "updateRevision": "5d87d4c6bd"
   }

2. Ensure consistent indentation for the JSON output in the code blocks.

</blockquote></details>
<details>
<summary>docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (6)</summary><blockquote>

Line range hint `1-11`: **LGTM! Clear introduction and task objective.**

The updated introduction and task objective provide a clear context for the document. The added tip about supported versions is helpful for users.


Consider adding a brief explanation of what blue-green deployment is for readers who might be unfamiliar with the concept.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)

</blockquote></details>

</details>

---

Line range hint `23-89`: **Great improvement in the solution section.**

The updated solution section provides a clear and detailed explanation of the blue-green deployment process. The breakdown of steps and the addition of the state diagram significantly enhance the reader's understanding of the upgrade process.


Consider adding a brief legend or explanation for the state diagram to help readers unfamiliar with mermaid syntax better understand the flow.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)

</blockquote></details>

</details>

---

Line range hint `91-225`: **Comprehensive configuration update strategy section.**

The inclusion of specific YAML configurations for both `apps.emqx.io/v2beta1` and `apps.emqx.io/v1beta4` versions, along with detailed parameter explanations, greatly enhances the usability of this document. The updated deployment and status-checking commands are also helpful.


Consider adding a brief note about the differences between the two versions (`v2beta1` and `v1beta4`) to help users choose the appropriate configuration for their needs.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 LanguageTool</summary><blockquote>

[uncategorized] ~123-~123: Loose punctuation mark.
Context: ...n (unit: count/second)。  `sessEvictRate`: MQTT Session evacuation rate, only supp...

(UNLIKELY_OPENING_PUNCTUATION)

---

[typographical] ~125-~125: Do not use a colon (:) before a series that is introduced by a preposition (‘as’). Remove the colon or add a noun or a noun phrase after the preposition.
Context: ... count/second)。  Save the above content as: `emqx-update.yaml`, execute the followi...

(RP_COLON)

</blockquote></details>

</details>

---

Line range hint `225-301`: **Clear and detailed upgrade process instructions.**

The step-by-step instructions for upgrading the EMQX cluster, including commands for triggering the upgrade, checking node status, and monitoring the evacuation process, are very helpful. The added explanation of node evacuation status parameters enhances understanding of the process.


Consider adding a troubleshooting subsection or common issues that users might encounter during the upgrade process, along with their solutions.

---

Line range hint `304-322`: **Excellent addition of the Grafana Monitoring section.**

The inclusion of a monitoring section with a graph illustrating connection metrics during the upgrade process is a valuable addition. It provides users with a visual representation of the upgrade's impact on connections and helps demonstrate the effectiveness of the blue-green deployment strategy.


Consider adding information on how users can set up similar monitoring for their own deployments, including any necessary Grafana dashboard configurations or Prometheus metrics to collect.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)

</blockquote></details>

</details>

---

`125-125`: **Minor typographical correction needed.**

Remove the colon after "as" in the following sentence:
"Save the above content as: `emqx-update.yaml`, execute the following command to deploy EMQX"

Suggested correction:
"Save the above content as `emqx-update.yaml`, execute the following command to deploy EMQX"

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 LanguageTool</summary><blockquote>

[typographical] ~125-~125: Do not use a colon (:) before a series that is introduced by a preposition (‘as’). Remove the colon or add a noun or a noun phrase after the preposition.
Context: ... count/second)。  Save the above content as: `emqx-update.yaml`, execute the followi...

(RP_COLON)

</blockquote></details>

</details>

</blockquote></details>

</blockquote></details>

<details>
<summary>📜 Review details</summary>

**Configuration used: CodeRabbit UI**
**Review profile: CHILL**

<details>
<summary>📥 Commits</summary>

Files that changed from the base of the PR and between 3bbf6ef9cffa8258b26b7cca0692024c1f246093 and d43a3165f350859088e7c175a6ae2a73c60f1356.

</details>

<details>
<summary>📒 Files selected for processing (2)</summary>

* docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (3 hunks)
* docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (3 hunks)

</details>

<details>
<summary>🧰 Additional context used</summary>



<details>
<summary>🪛 Markdownlint</summary><blockquote>

<details>
<summary>docs/en_US/tasks/configure-emqx-blueGreenUpdate.md</summary><blockquote>

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

</blockquote></details>
<details>
<summary>docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md</summary><blockquote>

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)

</blockquote></details>

</blockquote></details>
<details>
<summary>🪛 LanguageTool</summary><blockquote>

<details>
<summary>docs/en_US/tasks/configure-emqx-blueGreenUpdate.md</summary><blockquote>

[typographical] ~125-~125: Do not use a colon (:) before a series that is introduced by a preposition (‘as’). Remove the colon or add a noun or a noun phrase after the preposition.
Context: ... count/second)。  Save the above content as: `emqx-update.yaml`, execute the followi...

(RP_COLON)

</blockquote></details>

</blockquote></details>

</details>

<details>
<summary>🔇 Additional comments (4)</summary><blockquote>

<details>
<summary>docs/zh_CN/tasks/configure-emqx-blueGreenUpdate.md (3)</summary><blockquote>

Line range hint `1-27`: **LGTM: Clear introduction and background**

The introduction and background sections provide a clear context for the blue-green deployment strategy, explaining its purpose and the limitations of traditional rolling updates. This sets a good foundation for the rest of the document.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)

</blockquote></details>

</details>

---

Line range hint `89-223`: **LGTM: Comprehensive configuration examples**

The configuration examples for both `apps.emqx.io/v2beta1 EMQX` and `apps.emqx.io/v1beta4 EmqxEnterprise` are well-structured and provide clear explanations of the configuration parameters. This section offers valuable guidance for users implementing blue-green deployments.

---

Line range hint `294-310`: **LGTM: Informative Grafana monitoring section**

The Grafana monitoring section provides a valuable visualization of the connection metrics during the upgrade process. The explanation of the graph and its implications effectively demonstrates the benefits of the blue-green deployment strategy, highlighting the minimal impact on total connections during the upgrade.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

38-38: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

85-85: Column: 1
Hard tabs

(MD010, no-hard-tabs)

</blockquote></details>

</details>

</blockquote></details>
<details>
<summary>docs/en_US/tasks/configure-emqx-blueGreenUpdate.md (1)</summary><blockquote>

Line range hint `13-21`: **Excellent background information.**

The expanded background section effectively highlights the limitations of traditional rolling updates, providing a clear rationale for using blue-green deployment. This context helps users understand the importance of the solution presented in this document.

<details>
<summary>🧰 Tools</summary>

<details>
<summary>🪛 Markdownlint</summary><blockquote>

39-39: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

86-86: Column: 1
Hard tabs

(MD010, no-hard-tabs)

---

92-92: Punctuation: '.'
Trailing punctuation in heading

(MD026, no-trailing-punctuation)

</blockquote></details>

</details>

</blockquote></details>

</blockquote></details>

</details>

<!-- This is an auto-generated comment by CodeRabbit for review status -->

Copy link
Member

@zmstone zmstone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

elegantly -> gracefully

Copy link
Member

@zmstone zmstone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should we suggest another architecture which do not serve MQTT traffic on core nodes ?

@Rory-Z
Copy link
Member Author

Rory-Z commented Oct 25, 2024

should we suggest another architecture which do not serve MQTT traffic on core nodes ?

In this document, just deployment only core nodes cluster, should I change cluster to core + repl cluster ?

@zmstone
Copy link
Member

zmstone commented Oct 25, 2024

should I change cluster to core + repl clus

but I can see replicant node in the flow

HasReplNode --> SelectOldestReplPod: Has EMQX replicant node pod

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants