質問編集履歴
2
質問に対する回答を追記
test
CHANGED
File without changes
|
test
CHANGED
@@ -34,7 +34,31 @@
|
|
34
34
|
|
35
35
|
```nodejs
|
36
36
|
|
37
|
-
findOneAndUpdate(
|
37
|
+
findOneAndUpdate(
|
38
|
+
|
39
|
+
{'available':true, 'finish':false},
|
40
|
+
|
41
|
+
{$set:{'available':false}},
|
42
|
+
|
43
|
+
{sort:{'postNum':-1}}
|
44
|
+
|
45
|
+
)
|
46
|
+
|
47
|
+
```
|
48
|
+
|
49
|
+
```document
|
50
|
+
|
51
|
+
_id:id
|
52
|
+
|
53
|
+
url:URL
|
54
|
+
|
55
|
+
available:true/false
|
56
|
+
|
57
|
+
finish:true/false
|
58
|
+
|
59
|
+
postNum:投稿数
|
60
|
+
|
61
|
+
timestamp:タイムスタンプ
|
38
62
|
|
39
63
|
```
|
40
64
|
|
@@ -63,3 +87,13 @@
|
|
63
87
|
### 追記
|
64
88
|
|
65
89
|
現在300のプログラムが常にmongoDBとの接続を持っており、必要なときにfindOneAndUpdate()などのメソッドを使ってアクセスするという形になっております。
|
90
|
+
|
91
|
+
#### 質問に対する返答
|
92
|
+
|
93
|
+
- mongoDBは1台のみの攻勢となっております。
|
94
|
+
|
95
|
+
- 上記の要素をもつドキュメントが8500件ほどあります。
|
96
|
+
|
97
|
+
- GCPのサーバー上ではmongoDB以外の動作は行っておりません。
|
98
|
+
|
99
|
+
- findOneAndUpdate()の部分をfindOne()とupdate()にわけて実行したところ、CPUが上限に行くことはありませんでした。しかし、この方法ですとupdate前に同じドキュメントをfindOne()で取得してしまうことがあったので、可能な限りfindOneAndUpdate()を使う方法で行きたいと考えています。
|
1
追記
test
CHANGED
File without changes
|
test
CHANGED
@@ -57,3 +57,9 @@
|
|
57
57
|
|:--|:--|:--|
|
58
58
|
|
59
59
|
|GCE|vCPU x 2|7.5GB|
|
60
|
+
|
61
|
+
|
62
|
+
|
63
|
+
### 追記
|
64
|
+
|
65
|
+
現在300のプログラムが常にmongoDBとの接続を持っており、必要なときにfindOneAndUpdate()などのメソッドを使ってアクセスするという形になっております。
|