我正在按教程运行 http://ampcamp.berkeley.edu/big-data-mini-course/graph-analytics-with-graphx.html
在某些时候我们使用mapReduceTriplets操作。这将返回预期结果
// Find the oldest follower for each user
val oldestFollower: VertexRDD[(String, Int)] = userGraph.mapReduceTriplets[(String, Int)](
// For each edge send a message to the destination vertex with the attribute of the source vertex
edge => Iterator((edge.dstId, (edge.srcAttr.name, edge.srcAttr.age))),
// To combine messages take the message for the older follower
(a, b) => if (a._2 > b._2) a else b
)
但是IntelliJ指出我不推荐使用mapReduceTriplets(从1.2.0开始),应该用aggregateMessages替换
// Find the oldest follower for each user
val oldestFollower: VertexRDD[(String, Int)] = userGraph.aggregateMessages()[(String, Int)](
// For each edge send a message to the destination vertex with the attribute of the source vertex
edge => Iterator((edge.dstId, (edge.srcAttr.name, edge.srcAttr.age))),
// To combine messages take the message for the older follower
(a, b) => if (a._2 > b._2) a else b
)
所以我运行完全相同的代码,但后来我没有任何输出。这是预期的结果还是由于aggregateMessages的变化我应该改变什么?
答案 0 :(得分:2)
可能你需要这样的东西:
val oldestFollower: VertexRDD[(String, Int)] = userGraph.aggregateMessages[(String, Int)]
(
// For each edge send a message to the destination vertex with the attribute of the source vertex
sendMsg = { triplet => triplet.sendToDst(triplet.srcAttr.name, triplet.srcAttr.age) },
// To combine messages take the message for the older follower
mergeMsg = {(a, b) => if (a._2 > b._2) a else b}
)
您可以在Grapx proggraming guide页面找到aggregateMessages
功能签名和有用示例。希望这会有所帮助。