1

Google App Engine の Golang で Reddit API を作成しようとしています。私のコード:

package RedditAPI

import(
    "appengine"
    "encoding/json"
    "io/ioutil"
    "net/http"
    "appengine/urlfetch"
    "time"
    "net/url"
)

func GetTopSubmissions(c appengine.Context){
    one, two:=Call(c, "http://www.reddit.com/r/Bitcoin/top.json", "POST", nil);
    c.Infof("%v, %v", one, two);
}


func Call(c appengine.Context, address string, requestType string, values url.Values)(map[string]interface{}, error){
    req, err:=http.NewRequest("GET", address, nil)
    if err!=nil{
        c.Infof("Request: %v", err)
        return nil, err
    }

    req.Header.Add("User-Agent", "This is a very creative name for a Reddit bot v1.0 by /u/username")
    c.Infof("%v", req.Header.Get("User-Agent"))
    c.Infof("%v", req)
    c.Infof("%v", req.UserAgent())

    duration, err:= time.ParseDuration("60s")
    tr := &urlfetch.Transport{Context: c, Deadline: duration}

    resp, err:=tr.RoundTrip(req)
    if err != nil {
        c.Infof("Post: %v", err)
        return nil, err
    }
    defer resp.Body.Close()
    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        c.Infof("ReadAll: %v", err)
        return nil, err
    }
    result := make(map[string]interface{})
    err = json.Unmarshal(body, &result)
    if err != nil {
        c.Infof("Unmarshal: %v", err)
        c.Infof("%s", body)
        return nil, err
    }
    return result, nil
}

戻り値

2013/05/23 03:00:34 Unsolicited response received on idle HTTP channel starting with "H"; err=<nil>
2013/05/23 03:01:42 INFO: &{GET http://www.reddit.com/r/Bitcoin/top.json HTTP/1.1 1 1 map[User-Agent:[This is a very creative name for a Reddit bot v1.0 by /u/username]] <nil> 0 [] false www.reddit.com map[] <nil> map[]   <nil>}
2013/05/23 03:01:42 INFO: This is a very creative name for a Reddit bot v1.0 by /u/username
2013/05/23 03:01:42 INFO: map[error:429], <nil>
INFO     2013-05-23 03:01:42,720 server.py:584] default: "GET / HTTP/1.1" 200 81

このエラーの原因は何ですか?

4

1 に答える 1

1

HTTP エラー 429 は「リクエストが多すぎます」: https://www.rfc-editor.org/rfc/rfc6585#section-4

https://github.com/reddit/reddit/wiki/APIで、Reddit は次のように述べています。あなたからのリクエストは 2 秒ごとに 1 つではありません。」彼らはまた、「30 秒に 1 回以上同じページにアクセスしないでください」とも言っています。

ユーザーがアプリにヒットするたびに同じリソースをリクエストする場合は、GAE の memcache サポートを使用できます。大量のリソースをリクエストしている場合、Reddit wiki ページに「[r]equests for multiple resources at a time」と記載されているため、リクエストをバッチ処理するための機能があるかもしれません (API に精通していないため、わかりません)。cronjob を実行している場合は、実行頻度を減らすことができます。

いずれにせよ、残りの謎は、Go の質問というよりは Reddit API の質問です。リポジトリ matthewbauer ( https://github.com/jzelinskie/reddit ) にコメントするか、Reddit API ドキュメントにさらに多くの情報がある場合があります。

于 2013-11-03T22:37:27.867 に答える