Separation of mechanism and policy: Difference between revisions
m Date maintenance tags and general fixes |
→See also: Removed link to deleted article. |
||
(55 intermediate revisions by 43 users not shown) | |||
Line 1: | Line 1: | ||
⚫ | The '''separation of mechanism and policy'''<ref>[[Butler W. Lampson]] and Howard E. Sturgis. ''[http://research.microsoft.com/Lampson/15-ReflectionsOnOS/Acrobat.pdf Reflections on an Operating System Design]'' [http://portal.acm.org/citation.cfm?id=360051.360074] Communications of the ACM 19(5):251-265 (May 1976)</ref> is a [[software design|design]] principle in [[computer science]]. It states that mechanisms (those parts of a system implementation that control the [[authorization]] of operations and the [[resource allocation|allocation of resources]]) should not dictate (or overly restrict) the policies according to which decisions are made about which operations to authorize, and which resources to allocate. |
||
{{Cleanup|date=June 2008}} |
|||
⚫ | The '''separation of mechanism and policy'''<ref>Butler W. Lampson and Howard E. Sturgis. ''[http://research.microsoft.com/Lampson/15-ReflectionsOnOS/Acrobat.pdf Reflections on an Operating System Design]'' [http://portal.acm.org/citation.cfm?id=360051.360074] Communications of the ACM 19(5):251-265 (May 1976)</ref> is a design principle in [[computer science]]. It states that mechanisms (those parts of a system implementation that control the authorization of operations and the allocation of resources should not dictate (or overly restrict) the policies according to which decisions are made about which operations to authorize, and which resources to allocate. |
||
While most commonly discussed in the context of security mechanisms (authentication and authorization), separation of mechanism and policy is applicable to a range of resource allocation |
|||
problems (e.g. CPU scheduling, memory allocation, |
problems (e.g. [[Scheduling (computing)|CPU scheduling]], [[memory allocation]], [[quality of service]]) as well as the design of [[Abstraction_(computer_science)|software abstractions]].{{cn|date=April 2021}} |
||
question of good object abstraction. |
|||
⚫ | [[Per Brinch Hansen]] introduced the concept of separation of policy and mechanism in operating systems in the [[RC 4000 multiprogramming system]].<ref>{{Cite web|title = Per Brinch Hansen • IEEE Computer Society|url = http://www.computer.org/web/awards/pioneer-per-hansen|website = www.computer.org|access-date = 2016-02-05}}</ref> Artsy and Livny, in a 1987 paper, discussed an approach for an operating system design having an "extreme separation of mechanism and policy".<ref>Miller, M. S., & Drexler, K. E. (1988). [https://web.archive.org/web/20080518033556/http://www.agorics.com/Library/agoricpapers/aos/aos.4.html "Markets and computation: Agoric open systems"]. In Huberman, B. A. (Ed.). (1988), pp. 133–176. ''The Ecology of Computation''. North-Holland.</ref><ref>Artsy, Yeshayahu ''et al.'', 1987.</ref> In a 2000 article, Chervenak et al. described the principles of ''mechanism neutrality'' and ''policy neutrality''.<ref>Chervenak 2000 p.2</ref> |
||
[[Per Brinch Hansen]] presented arguments in favor of separation of mechanism and policy.<ref name="Wulf74">Wulf 74 pp.337-345</ref><ref name="Hansen70">Brinch Hansen 70 pp.238-241</ref> |
|||
⚫ | |||
⚫ | Artsy, in a 1987 paper, discussed an approach for an operating system design having an "extreme separation of mechanism and policy".<ref>Miller, M. S., & Drexler, K. E. (1988). |
||
⚫ | The separation of mechanism and policy is the fundamental approach of a [[microkernel]] that distinguishes it from a [[Monolithic kernel|monolithic]] one. In a microkernel, the majority of operating system services are provided by user-level server processes.<ref>[[Raphael Finkel]], [[Michael L. Scott]], Artsy Y. and Chang, H. ''[www.cs.rochester.edu/u/scott/papers/1989_IEEETSE_Charlotte.pdf Experience with Charlotte: simplicity and function in a distributed operating system]. IEEE Trans. Software Engng 15:676-685; 1989. Extended abstract presented at the IEEE Workshop on Design Principles for Experimental Distributed Systems, Purdue University; 1986.</ref> It is important for an [[operating system]] to have the flexibility of providing adequate mechanisms to support the broadest possible spectrum of real-world security policies.<ref>R. Spencer, S. Smalley, P. Loscocco, M. Hibler, D. Andersen, and J. Lepreau ''[http://www.cs.utah.edu/flux/papers/flask-usenixsec99-abs.html The Flask Security Architecture: System Support for Diverse Security Policies]'' In Proceedings of the Eighth USENIX Security Symposium, pages 123–139, Aug. 1999.</ref> |
||
In a 2000 article, Chervenak et al described the principles of ''mechanism neutrality'' and ''policy neutrality''.<ref>Chervenak 2000 p.2</ref> |
|||
It is almost impossible to envision all of the different ways in which a system might be used by different types of users over the life of the product. This means that any hard-coded policies are likely to be inadequate or inappropriate for some (or perhaps even most) potential users. |
|||
⚫ | |||
Decoupling the mechanism implementations from the policy specifications makes it possible for different applications to use the same mechanism implementations with different policies. This means that those mechanisms are likely to better meet the needs of a wider range of users, for a longer period of time. |
|||
⚫ | If it is possible to enable new policies without changing the implementing mechanisms, the costs and risks of such policy changes can be greatly reduced. In the first instance, this could be accomplished merely by segregating mechanisms and their policies into distinct modules: by replacing the module which dictates a policy (e.g. CPU scheduling policy) without changing the module which executes this policy (e.g. the scheduling mechanism), we can change the behaviour of the system. Further, in cases where a wide or variable range of policies are anticipated depending on applications' needs, it makes sense to create some non-code means for specifying policies, i.e. policies are not hardcoded into executable code but can be specified as an independent description. For instance, file protection policies (e.g. [[Filesystem permissions|Unix's ''user/group/other read/write/execute'']]) might be parametrized. Alternatively an implementing mechanism could be designed to include an interpreter for a new policy specification language. In both cases, the systems are usually accompanied by a deferred binding mechanism (e.g. [[late binding]] of configuration options via [[configuration file]]s, or runtime programmability via [[Application programming interface|API]]s) that permits policy specifications to be incorporated to the system or replaced by another after it has been delivered to the customer. |
||
⚫ | The separation of mechanism and policy is the fundamental approach of a [[microkernel]] that distinguishes it from a [[Monolithic kernel|monolithic]] one. In a microkernel the majority of operating system services are provided by user-level server processes.<ref>[[Raphael Finkel]], [[Michael L. Scott]], Artsy Y. and Chang, H. ''[www.cs.rochester.edu/u/scott/papers/1989_IEEETSE_Charlotte.pdf Experience with Charlotte: simplicity and function in a distributed operating system]. IEEE Trans. Software Engng 15:676-685; 1989. Extended abstract presented at the IEEE Workshop on Design Principles for Experimental Distributed Systems, Purdue University; 1986. |
||
⚫ | An everyday example of mechanism/policy separation is the use of [[Keycard lock|card keys]] to gain access to locked doors. The mechanisms (magnetic card readers, remote controlled locks, connections to a security server) do not impose any limitations on entrance policy (which people should be allowed to enter which doors, at which times). These decisions are made by a centralized security server, which (in turn) probably makes its decisions by consulting a database of room access rules. Specific authorization decisions can be changed by updating a room access database. If the rule schema of that database proved too limiting, the entire security server could be replaced while leaving the fundamental mechanisms (readers, locks, and connections) unchanged. |
||
It is almost impossible to envision all of the different ways in which a system might be used |
|||
by different types of users over the life of the product. This means that any hard-coded |
|||
policies are likely to be inadequate or inappropriate for some (or perhaps even most) users. |
|||
Decoupling the mechanism implementations from the policy specifications makes it |
|||
possible for different applications to use the same mechanism implementations |
|||
with different policies. This means that those mechanisms are likely to better |
|||
meet the needs of a wider range of users, for a longer period of time. |
|||
Contrast this with issuing physical keys: if you want to change who can open a door, you have to issue new keys and change the lock. This intertwines the unlocking mechanisms with the access policies. For a hotel, this is significantly less effective than using key cards. |
|||
If it is possible to enable new policies without changing the implementing mechanisms, |
|||
the costs and risks of such policy changes can be greatly reduced. This could be accomplished merely |
|||
⚫ | by segregating mechanisms and their policies into distinct modules, |
||
⚫ | |||
⚫ | An example of mechanism/policy separation is the use of card |
||
⚫ | |||
*[[Unix philosophy]] |
|||
*[[X Window System]] |
|||
==Notes== |
==Notes== |
||
Line 34: | Line 28: | ||
==References== |
==References== |
||
*{{cite |
*{{cite web |
||
| author = |
| author =Per Brinch Hansen |
||
| author-link =Per Brinch Hansen |
|||
| title = The evolution of operating systems |
| title = The evolution of operating systems |
||
| date = 2001 |
| date = 2001 |
||
| url = http://brinch-hansen.net/papers/2001b.pdf |
| url = http://brinch-hansen.net/papers/2001b.pdf |
||
| |
| access-date = 2006-10-24 |
||
⚫ | }} included in book: {{cite book |editor=Per Brinch Hansen |title=Classic operating systems: from batch processing to distributed systems |url=http://portal.acm.org/citation.cfm?id=360596&dl=ACM&coll=&CFID=15151515&CFTOKEN=6184618 |publisher=Springer-Verlag |location= New York |isbn=978-0-387-95113-3 |pages=1–36 |chapter=1 |chapter-url=http://brinch-hansen.net/papers/2001b.pdf |year=2001 |orig-year=2001}} (p. 18) |
||
| accessdate = 2006-10-24 |
|||
⚫ | * {{cite journal |last=Wulf |first=W. |author-link=William Wulf |author2=E. Cohen |author3=W. Corwin |author4=A. Jones |author5=R. Levin |author6=C. Pierson |author7=F. Pollack |date=June 1974 |title=HYDRA: the kernel of a multiprocessor operating system |journal=Communications of the ACM |volume=17 |issue=6 |pages=337–345 |doi=10.1145/355616.364017 |s2cid=8011765 |issn=0001-0782 |doi-access=free }} |
||
⚫ | }} included in book: {{cite book |editor=Per Brinch Hansen |title=Classic operating systems: from batch processing to distributed systems |
||
*{{cite journal |last= |
* {{cite journal |last=Hansen |first=Per Brinch |author-link=Per Brinch Hansen |date=April 1970 |title=The nucleus of a Multiprogramming System |journal=Communications of the ACM |volume=13 |issue=4 |pages=238–241 |url=http://portal.acm.org/citation.cfm?id=362278&dl=ACM&coll=GUIDE&CFID=11111111&CFTOKEN=2222222 |doi=10.1145/362258.362278 |issn=0001-0782 |citeseerx=10.1.1.105.4204 |s2cid=9414037 }} (pp. 238–241) |
||
* |
*{{cite book |last=Levin |first=R. |author2=E. Cohen |author3=W. Corwin |author4=F. Pollack |author5=W. Wulf |title=Proceedings of the fifth symposium on Operating systems principles - SOSP '75 |chapter=Policy/Mechanism separation in Hydra |year=1975 |volume=9 |issue=5 |pages=132–140 |chapter-url=http://portal.acm.org/citation.cfm?id=806531&dl=ACM&coll=&CFID=15151515&CFTOKEN=6184618 |doi=10.1145/800213.806531 |isbn=9781450378635 |s2cid=10524544 }} |
||
⚫ | *Chervenak et al. ''[http://hpc.csie.thu.edu.tw/meeting/g93/g932910_Yao-Chun%20Chi/ycc_2005-11-04_The%20Data%20Grid_Towards%20an%20Architecture%20for%20the%20Distributed%20Management%20and%20Analysis%20of%20Large%20Scientific%20Datasets.pdf The data grid]{{dead link|date=March 2018 |bot=InternetArchiveBot |fix-attempted=yes }}'' Journal of Network and Computer Applications, Volume 23, Issue 3, July 2000, Pages 187-200 |
||
*{{cite journal |last=Levin |first=R. |coauthors=E. Cohen, W. Corwin, F. Pollack, W. Wulf |year=1975 |title=Policy/mechanism separation in Hydra |journal=ACM Symposium on Operating Systems Principles / Proceedings of the fifth ACM symposium on Operating systems principles |pages=132–140 |url=http://portal.acm.org/citation.cfm?id=806531&dl=ACM&coll=&CFID=15151515&CFTOKEN=6184618 |doi=10.1145/800213.806531 }} |
|||
⚫ | *Chervenak et al ''[http://hpc.csie.thu.edu.tw/meeting/g93/g932910_Yao-Chun%20Chi/ycc_2005-11-04_The%20Data%20Grid_Towards%20an%20Architecture%20for%20the%20Distributed%20Management%20and%20Analysis%20of%20Large%20Scientific%20Datasets.pdf The data grid]'' Journal of Network and Computer Applications, Volume 23, Issue 3, July 2000, Pages 187-200 |
||
*Artsy, Yeshayahu, and [http://pages.cs.wisc.edu/~miron/ Livny, Miron], An Approach to the Design of Fully Open Computing Systems (University of Wisconsin / Madison, March 1987) Computer Sciences Technical Report #689. |
*Artsy, Yeshayahu, and [http://pages.cs.wisc.edu/~miron/ Livny, Miron], An Approach to the Design of Fully Open Computing Systems (University of Wisconsin / Madison, March 1987) Computer Sciences Technical Report #689. |
||
⚫ | * {{cite journal |last=Wulf |first=W. | |
||
⚫ | |||
⚫ | |||
==External links== |
==External links== |
||
*[ |
*[[Raphael Finkel]]'s "[https://web.archive.org/web/20170705054440/ftp://ftp.cs.uky.edu/cs/manuscripts/vade.mecum.2.pdf An operating system Vade Mecum]" |
||
*[http://www.cs.wisc.edu/condor/ Mechanism and policy for HTC] |
*[http://www.cs.wisc.edu/condor/ Mechanism and policy for HTC] |
||
[[Category:Dichotomies]] |
[[Category:Dichotomies]] |
||
[[Category:Operating system technology]] |
[[Category:Operating system technology]] |
||
[[Category:Programming principles]] |
Latest revision as of 03:07, 30 December 2024
The separation of mechanism and policy[1] is a design principle in computer science. It states that mechanisms (those parts of a system implementation that control the authorization of operations and the allocation of resources) should not dictate (or overly restrict) the policies according to which decisions are made about which operations to authorize, and which resources to allocate.
While most commonly discussed in the context of security mechanisms (authentication and authorization), separation of mechanism and policy is applicable to a range of resource allocation problems (e.g. CPU scheduling, memory allocation, quality of service) as well as the design of software abstractions.[citation needed]
Per Brinch Hansen introduced the concept of separation of policy and mechanism in operating systems in the RC 4000 multiprogramming system.[2] Artsy and Livny, in a 1987 paper, discussed an approach for an operating system design having an "extreme separation of mechanism and policy".[3][4] In a 2000 article, Chervenak et al. described the principles of mechanism neutrality and policy neutrality.[5]
Rationale and implications
[edit]The separation of mechanism and policy is the fundamental approach of a microkernel that distinguishes it from a monolithic one. In a microkernel, the majority of operating system services are provided by user-level server processes.[6] It is important for an operating system to have the flexibility of providing adequate mechanisms to support the broadest possible spectrum of real-world security policies.[7]
It is almost impossible to envision all of the different ways in which a system might be used by different types of users over the life of the product. This means that any hard-coded policies are likely to be inadequate or inappropriate for some (or perhaps even most) potential users. Decoupling the mechanism implementations from the policy specifications makes it possible for different applications to use the same mechanism implementations with different policies. This means that those mechanisms are likely to better meet the needs of a wider range of users, for a longer period of time.
If it is possible to enable new policies without changing the implementing mechanisms, the costs and risks of such policy changes can be greatly reduced. In the first instance, this could be accomplished merely by segregating mechanisms and their policies into distinct modules: by replacing the module which dictates a policy (e.g. CPU scheduling policy) without changing the module which executes this policy (e.g. the scheduling mechanism), we can change the behaviour of the system. Further, in cases where a wide or variable range of policies are anticipated depending on applications' needs, it makes sense to create some non-code means for specifying policies, i.e. policies are not hardcoded into executable code but can be specified as an independent description. For instance, file protection policies (e.g. Unix's user/group/other read/write/execute) might be parametrized. Alternatively an implementing mechanism could be designed to include an interpreter for a new policy specification language. In both cases, the systems are usually accompanied by a deferred binding mechanism (e.g. late binding of configuration options via configuration files, or runtime programmability via APIs) that permits policy specifications to be incorporated to the system or replaced by another after it has been delivered to the customer.
An everyday example of mechanism/policy separation is the use of card keys to gain access to locked doors. The mechanisms (magnetic card readers, remote controlled locks, connections to a security server) do not impose any limitations on entrance policy (which people should be allowed to enter which doors, at which times). These decisions are made by a centralized security server, which (in turn) probably makes its decisions by consulting a database of room access rules. Specific authorization decisions can be changed by updating a room access database. If the rule schema of that database proved too limiting, the entire security server could be replaced while leaving the fundamental mechanisms (readers, locks, and connections) unchanged.
Contrast this with issuing physical keys: if you want to change who can open a door, you have to issue new keys and change the lock. This intertwines the unlocking mechanisms with the access policies. For a hotel, this is significantly less effective than using key cards.
See also
[edit]Notes
[edit]- ^ Butler W. Lampson and Howard E. Sturgis. Reflections on an Operating System Design [1] Communications of the ACM 19(5):251-265 (May 1976)
- ^ "Per Brinch Hansen • IEEE Computer Society". www.computer.org. Retrieved 2016-02-05.
- ^ Miller, M. S., & Drexler, K. E. (1988). "Markets and computation: Agoric open systems". In Huberman, B. A. (Ed.). (1988), pp. 133–176. The Ecology of Computation. North-Holland.
- ^ Artsy, Yeshayahu et al., 1987.
- ^ Chervenak 2000 p.2
- ^ Raphael Finkel, Michael L. Scott, Artsy Y. and Chang, H. [www.cs.rochester.edu/u/scott/papers/1989_IEEETSE_Charlotte.pdf Experience with Charlotte: simplicity and function in a distributed operating system]. IEEE Trans. Software Engng 15:676-685; 1989. Extended abstract presented at the IEEE Workshop on Design Principles for Experimental Distributed Systems, Purdue University; 1986.
- ^ R. Spencer, S. Smalley, P. Loscocco, M. Hibler, D. Andersen, and J. Lepreau The Flask Security Architecture: System Support for Diverse Security Policies In Proceedings of the Eighth USENIX Security Symposium, pages 123–139, Aug. 1999.
References
[edit]- Per Brinch Hansen (2001). "The evolution of operating systems" (PDF). Retrieved 2006-10-24. included in book: Per Brinch Hansen, ed. (2001) [2001]. "1" (PDF). Classic operating systems: from batch processing to distributed systems. New York: Springer-Verlag. pp. 1–36. ISBN 978-0-387-95113-3. (p. 18)
- Wulf, W.; E. Cohen; W. Corwin; A. Jones; R. Levin; C. Pierson; F. Pollack (June 1974). "HYDRA: the kernel of a multiprocessor operating system". Communications of the ACM. 17 (6): 337–345. doi:10.1145/355616.364017. ISSN 0001-0782. S2CID 8011765.
- Hansen, Per Brinch (April 1970). "The nucleus of a Multiprogramming System". Communications of the ACM. 13 (4): 238–241. CiteSeerX 10.1.1.105.4204. doi:10.1145/362258.362278. ISSN 0001-0782. S2CID 9414037. (pp. 238–241)
- Levin, R.; E. Cohen; W. Corwin; F. Pollack; W. Wulf (1975). "Policy/Mechanism separation in Hydra". Proceedings of the fifth symposium on Operating systems principles - SOSP '75. Vol. 9. pp. 132–140. doi:10.1145/800213.806531. ISBN 9781450378635. S2CID 10524544.
- Chervenak et al. The data grid[permanent dead link ] Journal of Network and Computer Applications, Volume 23, Issue 3, July 2000, Pages 187-200
- Artsy, Yeshayahu, and Livny, Miron, An Approach to the Design of Fully Open Computing Systems (University of Wisconsin / Madison, March 1987) Computer Sciences Technical Report #689.