Conflict Between Availability and Security
publish date: 2026/06/11 07:14:52.674232 UTC
A system has both high availability and high security as its most important non-functional requirements. Explain why these requirements create an architectural conflict.
Correct Answer
Explanation
High availability demands redundant components distributed so that parts can fail or be replaced without stopping the system. High security demands a layered structure with critical assets deeply protected and high-level security validation at each layer boundary. Distributing and replicating components for availability increases the number of potential attack surfaces and makes it harder to enforce the strict access controls needed for security. A compromise architecture - perhaps using different patterns for different system parts - is necessary.
Reference
Software Engineering, Ian Sommerville, 10th edition
