v1 透過排序鍵繼續發布 (已淘汰)
透過集合功能整理內容
你可以依據偏好儲存及分類內容。
除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。
[[["容易理解","easyToUnderstand","thumb-up"],["確實解決了我的問題","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["難以理解","hardToUnderstand","thumb-down"],["資訊或程式碼範例有誤","incorrectInformationOrSampleCode","thumb-down"],["缺少我需要的資訊/範例","missingTheInformationSamplesINeed","thumb-down"],["翻譯問題","translationIssue","thumb-down"],["其他","otherDown","thumb-down"]],[],[],[],null,["# v1 Resume publishing with ordering keys (DEPRECATED)\n\n(DEPRECATED) Resume publishing with ordering keys\n\nCode sample\n-----------\n\n### Go\n\n\nBefore trying this sample, follow the Go setup instructions in the\n[Pub/Sub quickstart using\nclient libraries](/pubsub/docs/quickstart-client-libraries).\n\n\nFor more information, see the\n[Pub/Sub Go API\nreference documentation](https://godoc.org/cloud.google.com/go/pubsub).\n\n\nTo authenticate to Pub/Sub, set up Application Default Credentials.\nFor more information, see\n\n[Set up authentication for a local development environment](/docs/authentication/set-up-adc-local-dev-environment).\n\n import (\n \t\"context\"\n \t\"fmt\"\n \t\"io\"\n\n \t\"cloud.google.com/go/pubsub\"\n \t\"google.golang.org/api/option\"\n )\n\n func resumePublishWithOrderingKey(w io.Writer, projectID, topicID string) {\n \t// projectID := \"my-project-id\"\n \t// topicID := \"my-topic\"\n \tctx := context.Background()\n\n \t// Pub/Sub's ordered delivery guarantee only applies when publishes for an ordering key are in the same region\n \t// For list of locational endpoints for Pub/Sub, see https://cloud.google.com/pubsub/docs/reference/service_apis_overview#list_of_locational_endpoints\n \tclient, err := pubsub.https://cloud.google.com/go/docs/reference/cloud.google.com/go/pubsub/latest/index.html#cloud_google_com_go_pubsub_Client_NewClient(ctx, projectID,\n \t\toption.WithEndpoint(\"us-east1-pubsub.googleapis.com:443\"))\n \tif err != nil {\n \t\tfmt.Fprintf(w, \"pubsub.NewClient: %v\", err)\n \t\treturn\n \t}\n \tdefer client.Close()\n\n \tt := client.Topic(topicID)\n \tt.EnableMessageOrdering = true\n \tkey := \"some-ordering-key\"\n\n \tres := t.Publish(ctx, &pubsub.Message{\n \t\tData: []byte(\"some-message\"),\n \t\tOrderingKey: key,\n \t})\n \t_, err = res.Get(ctx)\n \tif err != nil {\n \t\t// Error handling code can be added here.\n \t\tfmt.Printf(\"Failed to publish: %s\\n\", err)\n\n \t\t// Resume publish on an ordering key that has had unrecoverable errors.\n \t\t// After such an error publishes with this ordering key will fail\n \t\t// until this method is called.\n \t\tt.https://cloud.google.com/go/docs/reference/cloud.google.com/go/pubsub/latest/index.html#cloud_google_com_go_pubsub_Topic_ResumePublish(key)\n \t}\n\n \tfmt.Fprint(w, \"Published a message with ordering key successfully\\n\")\n }\n\n### Ruby\n\n\nBefore trying this sample, follow the Ruby setup instructions in the\n[Pub/Sub quickstart using\nclient libraries](/pubsub/docs/quickstart-client-libraries).\n\n\nFor more information, see the\n[Pub/Sub Ruby API\nreference documentation](https://googleapis.dev/ruby/google-cloud-pubsub/latest/Google/Cloud/PubSub.html).\n\n\nTo authenticate to Pub/Sub, set up Application Default Credentials.\nFor more information, see\n\n[Set up authentication for a local development environment](/docs/authentication/set-up-adc-local-dev-environment).\n\n # topic_id = \"your-topic-id\"\n\n pubsub = Google::Cloud::https://cloud.google.com/ruby/docs/reference/google-cloud-pubsub/latest/Google-Cloud.html.new\n\n # Start sending messages in one request once the size of all queued messages\n # reaches 1 MB or the number of queued messages reaches 20\n topic = pubsub.topic topic_id, async: {\n max_bytes: 1_000_000,\n max_messages: 20\n }\n topic.enable_message_ordering!\n 10.times do |i|\n topic.publish_async \"This is message ##{i}.\",\n ordering_key: \"ordering-key\" do |result|\n if result.succeeded?\n puts \"Message ##{i} successfully published.\"\n else\n puts \"Message ##{i} failed to publish\"\n # Allow publishing to continue on \"ordering-key\" after processing the\n # failure.\n topic.resume_publish \"ordering-key\"\n end\n end\n end\n\n # Stop the async_publisher to send all queued messages immediately.\n topic.async_publisher.stop!\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=pubsub)."]]