本文整理匯總了Golang中github.com/trivago/gollum/core.Message.Drop方法的典型用法代碼示例。如果您正苦於以下問題:Golang Message.Drop方法的具體用法?Golang Message.Drop怎麽用?Golang Message.Drop使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/trivago/gollum/core.Message
的用法示例。
在下文中一共展示了Message.Drop方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: storeSortedSet
func (prod *Redis) storeSortedSet(msg core.Message) {
value, _ := prod.format.Format(msg)
var scoreValue []byte
if prod.fieldFromParsed {
scoreMsg := msg
scoreMsg.Data = value
scoreValue, _ = prod.fieldFormat.Format(scoreMsg)
} else {
scoreValue, _ = prod.fieldFormat.Format(msg)
}
score, err := strconv.ParseFloat(string(scoreValue), 64)
if err != nil {
Log.Error.Print("Redis: ", err)
return // ### return, no valid score ###
}
result := prod.client.ZAdd(prod.key, redis.Z{
Score: score,
Member: string(value),
})
if result.Err() != nil {
Log.Error.Print("Redis: ", result.Err())
msg.Drop(prod.GetTimeout())
}
}
示例2: storeString
func (prod *Redis) storeString(msg core.Message) {
value, _ := prod.ProducerBase.Format(msg)
result := prod.client.Set(prod.key, string(value))
if result.Err() != nil {
Log.Error.Print("Redis: ", result.Err())
msg.Drop(prod.GetTimeout())
}
}
示例3: writeMessage
func (prod *File) writeMessage(msg core.Message) {
msg.Data, msg.StreamID = prod.ProducerBase.Format(msg)
state, err := prod.getFileState(msg.StreamID, false)
if err != nil {
Log.Error.Print("File log error:", err)
msg.Drop(time.Duration(0))
return // ### return, dropped ###
}
if !state.batch.Append(msg) {
state.writeBatch()
state.batch.Append(msg)
}
}
示例4: storeHash
func (prod *Redis) storeHash(msg core.Message) {
value, _ := prod.format.Format(msg)
var field []byte
if prod.fieldFromParsed {
fieldMsg := msg
fieldMsg.Data = value
field, _ = prod.fieldFormat.Format(fieldMsg)
} else {
field, _ = prod.fieldFormat.Format(msg)
}
result := prod.client.HSet(prod.key, string(field), string(value))
if result.Err() != nil {
Log.Error.Print("Redis: ", result.Err())
msg.Drop(prod.GetTimeout())
}
}