質問編集履歴

2

質問に対する回答を追記

2019/02/03 00:54

投稿

robert
robert

スコア20

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

追記

2019/02/03 00:54

投稿

robert
robert

スコア20

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()などのメソッドを使ってアクセスするという形になっております。