MessageA message is a unit of communication that conveys information from a sender to a receiver. It can be transmitted through various forms, such as spoken or written words, signals, or electronic data, and can range from simple instructions to complex information. [1][2] The consumption of the message relies on how the recipient interprets the message, there are times where the recipient contradicts the intention of the message which results in a boomerang effect. [3] Message fatigue is another outcome recipients can obtain if a message is conveyed too much by the source. [4] One example of a message is a press release, which may vary from a brief report or statement released by a public agency to commercial publicity material. [5] Another example of a message is how they are portrayed to a consumer via an advertisement. History
Roles in human communicationIn communication between humans, messages can be verbal or nonverbal:
The phrase "send a message" or "sending a message" is also used for actions taken by a party to convey that party's attitude towards a certain thing. For example, a government that executes people who commit acts of treason is sending a message that treason will not be tolerated.[6] Conversely, a party that appears through its actions to endorse something that it opposes can be said to be "sending the wrong message",[6] while one which appears to simultaneously endorse contradictory things can be said to be sending "mixed messages".[7] In computer scienceEvents vs. MessagesIn distributed systems, events represent a fact or state change (e.g., OrderPlaced) and are typically broadcast asynchronously to multiple consumers, promoting loose coupling and scalability. While events generally don’t expect an immediate response, acknowledgment mechanisms are often implemented at the infrastructure level (e.g., Kafka commit offsets, SNS delivery statuses) rather than being an inherent part of the event pattern itself. [8][9] In contrast, messages serve a broader role, encompassing commands (e.g., ProcessPayment), events (e.g., PaymentProcessed), and documents (e.g., DataPayload). Both events and messages can support various delivery guarantees, including at-least-once, at-most-once, and exactly-once, depending on the technology stack and implementation. However, exactly-once delivery is often achieved through idempotency mechanisms rather than true, infrastructure-level exactly-once semantics. [8][9] Delivery patterns for both events and messages include publish/subscribe (one-to-many) and point-to-point (one-to-one). While request/reply is technically possible, it is more commonly associated with messaging patterns rather than pure event-driven systems. Events excel at state propagation and decoupled notifications, while messages are better suited for command execution, workflow orchestration, and explicit coordination. [8][9] Modern architectures commonly combine both approaches, leveraging events for distributed state change notifications and messages for targeted command execution and structured workflows based on specific timing, ordering, and delivery requirements. [8][9] See also
References
External links |