Я пишу приложение, которое быстро записывает в mongodb. Слишком быстро для mongodb и mgo для обработки. Мой вопрос в том, есть ли способ определить, что монго не может идти в ногу и начинать блокировать? Но я также не хочу блокировать излишне. Вот пример кода, который эмулирует проблему:Golang Mgo pacing
package main
import (
"labix.org/v2/mgo"
"time"
"fmt"
)
// in database name is a string and age is an int
type Dog struct{
Breed string "breed"
}
type Person struct{
Name string "name"
Pet Dog `bson:",inline"`
Ts time.Time
}
func insert(session *mgo.Session, bob Person){
err := session.DB("db_log").C("people").Insert(&bob)
if err != nil {
panic("Could not insert into database")
}
}
func main() {
session, _ := mgo.Dial("localhost:27017")
bob := Person{Name : "Robert", Pet : Dog{}}
i := 0
for {
time.Sleep(time.Duration(1) * time.Microsecond)
i++
go insert(session, bob)
}
}
Я часто получаю ошибки как:
panic: Could not insert into database
или
panic: write tcp 127.0.0.1:27017: i/o timeout
@EvanShaw, что вы рекомендуете вместо этого? – thwd
Трудно сделать рекомендацию, не зная ничего о рассматриваемом приложении, но PostgreSQL часто является хорошим выбором по умолчанию. –
Если это круто, чтобы писать мнения, я собираюсь предложить противоположное мнение @EvanShaw. Мы используем Mongo в производстве и любим его. Мы получаем отличную производительность. Не позволяйте ненавистникам возиться с вами. Мне еще предстоит услышать спор против Монго, на который нельзя ответить. Дэвид Миттон из Server Density написал [потрясающий контрапункт] (https://blog.serverdensity.com/does-everyone-hate-mongodb/) полтора года назад, который я рекомендую читать. – Tyson