summaryrefslogtreecommitdiff
path: root/0199-move-sandbox-network_ready-from-metadata-to-state-fo.patch
blob: 9f962005da5fc615e4c90d07f8d63816ebb2ef9c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
From c61807c0f18022117fc02889b42d87ec19e9d1e9 Mon Sep 17 00:00:00 2001
From: zhongtao <zhongtao17@huawei.com>
Date: Sat, 22 Feb 2025 10:38:59 +1400
Subject: [PATCH 1/2] move sandbox network_ready from metadata to state for
 save optimization

Signed-off-by: zhongtao <zhongtao17@huawei.com>
---
 src/daemon/sandbox/sandbox.cc | 12 ++++++++++--
 1 file changed, 10 insertions(+), 2 deletions(-)

diff --git a/src/daemon/sandbox/sandbox.cc b/src/daemon/sandbox/sandbox.cc
index b97c0bc6..33d7f63f 100644
--- a/src/daemon/sandbox/sandbox.cc
+++ b/src/daemon/sandbox/sandbox.cc
@@ -431,7 +431,11 @@ auto Sandbox::UpdateStatsInfo(const StatsInfo &info) -> StatsInfo
 
 void Sandbox::SetNetworkReady(bool ready)
 {
+    Errors tmp_error;
     m_networkReady = ready;
+    if (!SaveState(tmp_error)) {
+        ERROR("Failed to save sandbox state, %s for %s", m_id.c_str(), tmp_error.GetMessage().c_str());
+    }
 }
 
 auto Sandbox::Save(Errors &error) -> bool
@@ -504,6 +508,8 @@ auto Sandbox::Load(Errors &error) -> bool
     return true;
 }
 
+// no need to save state after recovery
+// when restarting isulad, the status will be updated again and wait sandbox
 void Sandbox::OnSandboxReady()
 {
     WriteGuard<RWMutex> lock(m_stateMutex);
@@ -514,6 +520,8 @@ void Sandbox::OnSandboxReady()
     m_state.status = SANDBOX_STATUS_RUNNING;
 }
 
+// no need to save intermediate state
+// when restarting isulad, the status will be updated again and wait sandbox
 void Sandbox::OnSandboxPending()
 {
     WriteGuard<RWMutex> lock(m_stateMutex);
@@ -842,6 +850,7 @@ auto Sandbox::SaveState(Errors &error) -> bool
     state.pid = m_state.pid;
     state.status = m_state.status;
     state.updated_at = m_state.updatedAt;
+    state.network_ready = m_networkReady;
 
     stateJson = GenerateSandboxStateJson(&state);
     if (stateJson.length() == 0) {
@@ -953,6 +962,7 @@ auto Sandbox::LoadState(Errors &error) -> bool
     m_state.createdAt = state->get()->created_at;
     m_state.updatedAt = state->get()->updated_at;
     m_state.status = (SandboxStatus)state->get()->status;
+    m_networkReady = state->get()->network_ready;
 
     return true;
 }
@@ -1005,7 +1015,6 @@ auto Sandbox::LoadMetadata(Errors &error) -> bool
     m_runtimeInfo.sandboxer = std::string(metadata->get()->runtime_info->sandboxer);
     m_runtimeInfo.runtimeHandler = std::string(metadata->get()->runtime_info->runtime_handler);
     m_netMode = std::string(metadata->get()->net_mode);
-    m_networkReady = metadata->get()->network_ready;
     m_taskAddress = std::string(metadata->get()->task_address);
     m_netNsPath = std::string(metadata->get()->net_ns_path);
 
@@ -1125,7 +1134,6 @@ void Sandbox::FillSandboxMetadata(sandbox_metadata* metadata, Errors &error)
     metadata->runtime_info->runtime_handler = util_strdup_s(m_runtimeInfo.runtimeHandler.c_str());
 
     metadata->net_mode = util_strdup_s(m_netMode.c_str());
-    metadata->network_ready = m_networkReady;
     metadata->task_address = util_strdup_s(m_taskAddress.c_str());
     metadata->net_ns_path = util_strdup_s(m_netNsPath.c_str());
 
-- 
2.43.0