| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- /*
- * ***** BEGIN LICENSE BLOCK *****
- * Version: MIT
- *
- * Portions created by Alan Antonuk are Copyright (c) 2012-2013
- * Alan Antonuk. All Rights Reserved.
- *
- * Portions created by VMware are Copyright (c) 2007-2012 VMware, Inc.
- * All Rights Reserved.
- *
- * Portions created by Tony Garnock-Jones are Copyright (c) 2009-2010
- * VMware, Inc. and Tony Garnock-Jones. All Rights Reserved.
- *
- * Permission is hereby granted, free of charge, to any person
- * obtaining a copy of this software and associated documentation
- * files (the "Software"), to deal in the Software without
- * restriction, including without limitation the rights to use, copy,
- * modify, merge, publish, distribute, sublicense, and/or sell copies
- * of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be
- * included in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
- * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
- * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- * ***** END LICENSE BLOCK *****
- */
- #include <stdint.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- #include <amqp.h>
- #include <amqp_tcp_socket.h>
- #include "utils.h"
- #define SUMMARY_EVERY_US 1000000
- static void send_batch(amqp_connection_state_t conn, char const *queue_name,
- int rate_limit, int message_count) {
- uint64_t start_time = now_microseconds();
- int i;
- int sent = 0;
- int previous_sent = 0;
- uint64_t previous_report_time = start_time;
- uint64_t next_summary_time = start_time + SUMMARY_EVERY_US;
- char message[256];
- amqp_bytes_t message_bytes;
- for (i = 0; i < (int)sizeof(message); i++) {
- message[i] = i & 0xff;
- }
- message_bytes.len = sizeof(message);
- message_bytes.bytes = message;
- for (i = 0; i < message_count; i++) {
- uint64_t now = now_microseconds();
- die_on_error(amqp_basic_publish(conn, 1, amqp_cstring_bytes("amq.direct"),
- amqp_cstring_bytes(queue_name), 0, 0, NULL,
- message_bytes),
- "Publishing");
- sent++;
- if (now > next_summary_time) {
- int countOverInterval = sent - previous_sent;
- double intervalRate =
- countOverInterval / ((now - previous_report_time) / 1000000.0);
- printf("%d ms: Sent %d - %d since last report (%d Hz)\n",
- (int)(now - start_time) / 1000, sent, countOverInterval,
- (int)intervalRate);
- previous_sent = sent;
- previous_report_time = now;
- next_summary_time += SUMMARY_EVERY_US;
- }
- while (((i * 1000000.0) / (now - start_time)) > rate_limit) {
- microsleep(2000);
- now = now_microseconds();
- }
- }
- {
- uint64_t stop_time = now_microseconds();
- int total_delta = (int)(stop_time - start_time);
- printf("PRODUCER - Message count: %d\n", message_count);
- printf("Total time, milliseconds: %d\n", total_delta / 1000);
- printf("Overall messages-per-second: %g\n",
- (message_count / (total_delta / 1000000.0)));
- }
- }
- int main(int argc, char const *const *argv) {
- char const *hostname;
- int port, status;
- int rate_limit;
- int message_count;
- amqp_socket_t *socket = NULL;
- amqp_connection_state_t conn;
- if (argc < 5) {
- fprintf(stderr,
- "Usage: amqp_producer host port rate_limit message_count\n");
- return 1;
- }
- hostname = argv[1];
- port = atoi(argv[2]);
- rate_limit = atoi(argv[3]);
- message_count = atoi(argv[4]);
- conn = amqp_new_connection();
- socket = amqp_tcp_socket_new(conn);
- if (!socket) {
- die("creating TCP socket");
- }
- status = amqp_socket_open(socket, hostname, port);
- if (status) {
- die("opening TCP socket");
- }
- die_on_amqp_error(amqp_login(conn, "/", 0, 131072, 0, AMQP_SASL_METHOD_PLAIN,
- "guest", "guest"),
- "Logging in");
- amqp_channel_open(conn, 1);
- die_on_amqp_error(amqp_get_rpc_reply(conn), "Opening channel");
- send_batch(conn, "test queue", rate_limit, message_count);
- die_on_amqp_error(amqp_channel_close(conn, 1, AMQP_REPLY_SUCCESS),
- "Closing channel");
- die_on_amqp_error(amqp_connection_close(conn, AMQP_REPLY_SUCCESS),
- "Closing connection");
- die_on_error(amqp_destroy_connection(conn), "Ending connection");
- return 0;
- }
|