Apabila membina sistem teragih, baris gilir mesej seperti Amazon SQS memainkan peranan penting dalam mengendalikan beban kerja tak segerak. Dalam siaran ini, saya akan berkongsi pengalaman saya melaksanakan pengguna SQS yang mantap dalam Go yang mengendalikan acara pendaftaran pengguna untuk Keycloak. Penyelesaiannya menggunakan corak serentak kipas keluar/masuk untuk memproses mesej dengan cekap tanpa sumber sistem yang melampau.
Saya menghadapi masalah yang menarik: memproses sekitar 50,000 acara SQS setiap hari untuk mendaftarkan pengguna dalam Keycloak. Pendekatan naif mungkin menghasilkan goroutine baharu untuk setiap mesej, tetapi ini boleh menyebabkan kehabisan sumber dengan cepat. Kami memerlukan pendekatan yang lebih terkawal untuk keselarasan.
Corak kipas-keluar/kipas-masuk sesuai untuk bekas penggunaan ini kerana ia:
Pertama, mari kita lihat struktur asas pengguna kami:
type Consumer struct { Client *sqs.Client QueueName string }
Pelaksanaan terdiri daripada tiga komponen utama:
Begini cara kami memulakan pengguna:
func StartPool[requestBody any]( serviceFunc func(c context.Context, dto *requestBody) error, consumer *Consumer) { ctx := context.Background() params := &sqs.ReceiveMessageInput{ MaxNumberOfMessages: 10, QueueUrl: aws.String(consumer.QueueName), WaitTimeSeconds: 20, VisibilityTimeout: 30, MessageAttributeNames: []string{ string(types.QueueAttributeNameAll), }, } msgCh := make(chan types.Message) var wg sync.WaitGroup // Start worker pool first startPool(ctx, msgCh, &wg, consumer, serviceFunc) // Then start receiving messages // ... rest of the implementation }
Mari kita periksa parameter konfigurasi SQS yang penting:
Kolam pekerja ialah tempat corak kipas keluar:
func startPool[requestBody any]( ctx context.Context, msgCh chan types.Message, wg *sync.WaitGroup, consumer *Consumer, serviceFunc func(c context.Context, dto *requestBody) error) { processingMessages := &sync.Map{} // Start 10 workers for i := 0; i < 10; i++ { go worker(ctx, msgCh, wg, consumer, processingMessages, serviceFunc) } }
Kami menggunakan penyegerakan.Peta untuk menghalang pemprosesan mesej pendua:
type Consumer struct { Client *sqs.Client QueueName string }
Corak kipas keluar/masuk memberikan penyelesaian yang elegan untuk memproses mesej SQS volum tinggi dalam Go. Dengan mengekalkan kumpulan pekerja tetap, kami mengelakkan perangkap penciptaan goroutine tanpa had sambil memastikan pemprosesan mesej yang cekap.
Ingat untuk sentiasa mempertimbangkan kes penggunaan khusus anda apabila melaksanakan corak sedemikian. Nilai konfigurasi yang ditunjukkan di sini (kiraan pekerja, nilai tamat masa, dll.) hendaklah dilaraskan berdasarkan keperluan dan kekangan sumber anda.
Kod sumber: [Pautan ke repositori anda jika tersedia]
Tag: #golang #aws #sqs #concurrency #distributed-systems
Atas ialah kandungan terperinci Membina Pengguna SQS Berskala dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!