1 / 121

Windows vs. Linux Security Comparison: Principles & Practices

Explore the security architectures, vulnerabilities, and hardening techniques of Windows and Linux. Compare the two systems based on metrics and certifications for an in-depth analysis.

rosac
Download Presentation

Windows vs. Linux Security Comparison: Principles & Practices

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Computer Security: Principles and Practice Chapter 23 – Linux SecurityChapter 24 – Windows and Windows Vista SecurityWindows vs. Linux Security EECS 710 Professor: Hossein Saiedian Presented by Purvi Patel

  2. Agenda • Background • Windows Security Architecture • Linux Security Model • Evaluation: Windows vs. Linux Design • Windows Vulnerabilities • Linux Vulnerabilities • Means of Evaluating Metrics • Evaluation: Windows vs. Linux Vulnerabilities • CERT: Comparing Query Result for “Microsoft” and “Linux” Keywords • System Hardening • Windows Defenses • Linux System Hardening • OS-Level • Application-Level • OS Security Capabilities: Windows vs. Linux • Conclusion

  3. Background: Operating System Market Share (October 2010)

  4. Background: Windows • Advantages • User friendly • Enhancements can help millions of users • Defects found quickly because of widespread use • Disadvantages • Security defects can leave millions vulnerable • Non-technical user-base • Industry dominance leaves MS handcuffed - any move to expand capabilities seen as anticompetitive

  5. Background: Linux • Advantages • Stability • Free Software • Runs on old hardware • Security • Disadvantages • Learning curve • Equivalent programs • More technical ability needed • Not all hardware compatible

  6. Agenda • Background • Windows Security Architecture • Linux Security Model • Evaluation: Windows vs. Linux Design • Windows Vulnerabilities • Linux Vulnerabilities • Means of Evaluating Metrics • Evaluation: Windows vs. Linux Vulnerabilities • CERT: Comparing Query Result for “Microsoft” and “Linux” Keywords • System Hardening • Windows Defenses • Linux System Hardening • OS-Level • Application-Level • OS Security Capabilities: Windows vs. Linux • Conclusion

  7. Windows Security Architecture • Security Reference Monitor • Local Security Authority • Security Account Manager • Active Directory • Local vs. Domain Accounts • Access Control Lists • Integrity Control • User Account Controls

  8. Security Reference Monitor (SRM) • Kernel Mode Component that • Performs Access Checks • Generates Audit Log Entries • Manipulates User Privileges

  9. Local Security Authority (LSA) • Responsible for enforcing local security policy • Lsass.exe • User mode • Issues security tokens to accounts • Key component of the logon process

  10. Security Account Manager (SAM) • A database that stores user accounts and local users and groups security information • SamSrv.exe

  11. Active Directory • Directory Service • Server-based authentication • Centrally managed

  12. WinLogon & NetLogon • WinLogon – keyboard requests • NetLogon – network requests

  13. Local vs. Domain Accounts • Local Accounts for computers not hooked up to a network • Networked computers can be: • Workgroup joined • Domain joined

  14. Workgroup Joined • A collection of computers connected together • Only local accounts in SAM can be used • No infrastructure to support AD

  15. Domain Joined • Share access to networked printers, file servers, etc. • Centrally Managed • More secure • Scalable

  16. Windows Login Example • Administrator creates a user account (full name, username, password, group, privileges) • Windows creates an SID in the form of • S-1-5-21-AAA-BBB-CCC-RRR (page 723) • In windows, username can be in two formats • SAM format: support by all versions of Windows (legacy format) • Form: DOMAIN/username • User Principle Name (UPN) and looks more like RFC822 email address • Example: username@domain.company.com

  17. Windows Login Example • User logs in with keyboard • Information is sent to the AD (domain controller) • If successful token is generated and sent to user • Token contains • User’s SID • Group membership • Privileges

  18. Review Question • A user hits Ctrl+Alt+Del and logs into Windows with a keyboard… • What Windows process captures this login?

  19. Answer • The WinLogon process captures logins at the keyboard • WinLogon passes information to the domain controller (Active Directory) to perform logon • WinLogon would pass the information to the SAM (if local) which would give true/false authentication status • LSA would generate token if SAM verifies true username/password combination

  20. Windows Privileges • System-wide permissions assigned to user accounts • Some are considered “dangerous” • Act as part of the OS privilege • Debug programs privilege • Backup files and directories privilege • Some are considered “benign” • Bypass traverse checking privilege

  21. Access Control List (ACL) • Discretionary ACL • Grants or denies access to protected resources such as files, shared memory, etc. • System ACL • Used for auditing and to enforce mandatory integrity policy (Vista)

  22. Access Control Lists (ACL) (continued) • Objects needing protection are assigned an ACL that includes • SID of object owner • List of access control entries (ACEs) • Each ACE includes a SID and Access Mask • Access mask could include • Read, Write, Create, Delete, Modify, etc.

  23. Access Control Example • User opens text file

  24. Integrity Control • New to Vista: a low-level change to Windows that isolates different objects on a trust-based scale • Controlled by a new OS component called Windows Integrity Control (WIC) • Integrity levels trounce permissions • Example: malware no longer runs in the privilege level of the logged-on user, as it does in XP • It runs in the integrity level of the object that spawned it • Makes process isolation and other Vista security measures possible

  25. Six Integrity Levels Object and Principals are labeled • Untrusted • Low • Medium • High • System • Installer

  26. MAC: Vista Integrity Control • Having Integrity Control in Windows Vista • Limits operations changing an object’s state

  27. User Account Controls • A new feature in Windows Vista designed to help prevent unauthorized changes to your compute • UAC is similar to security features in UNIX-like operating systems • Perhaps the most reviled and misunderstood feature ever added to Windows

  28. User Account Controls (continued) • How it works: When your consent is required to complete a task, UAC will prompt you with a dialog box • Tasks that will trigger a UAC prompt include anything that will affect the integrity or security of the underlying system • This is a surprisingly long list of tasks • UAC works slightly differently with standard user and administrator-class accounts

  29. UAC Consent UI: Type 1 • Prompt: Windows needs your permission to continue • Why you see this: You attempt to change a potentially dangerous system setting, such as a running a Control Panel

  30. UAC Consent UI: Type 2 • Prompt: A program needs your permission to continue • Why you see this: An external application with a valid digital signature is attempting to run with admin privileges

  31. UAC Consent UI: Type 3 • Prompt: An unidentified program wants access to your computer • Why you see this: in external application without a valid digital signature is trying to run

  32. UAC: What’s really happening • Administrator accounts now logon with a mixed token • Half of this mixed token is a standard user token: this is what is typically used to determine your memberships and privileges • The other half, the administrator token, is invoked only when required: you can do so manually (run as) or automatically (certain tasks in Vista are tagged as requiring an admin token)

  33. Review Question • When a Modify (e.g. Write) operation occurs first check that the subjects integrity level dominates the objects integrity level • This is most like a property of which? • Bell-LaPadula model • Biba Model • Chinese Wall Model

  34. Answer: Biba Model • Simple Integrity Rule • A subject can modify an object only if the integrity level of the subject dominates the integrity level of the object • I(S)>=I(O)

  35. Agenda • Background • Windows Security Architecture • Linux Security Model • Evaluation: Windows vs. Linux Design • Windows Vulnerabilities • Linux Vulnerabilities • Means of Evaluating Metrics • Evaluation: Windows vs. Linux Vulnerabilities • CERT: Comparing Query Result for “Microsoft” and “Linux” Keywords • System Hardening • Windows Defenses • Linux System Hardening • OS-Level • Application-Level • OS Security Capabilities: Windows vs. Linux • Conclusion

  36. Linux Security Model • Overview of Linux Security Model • File System Security (DAC) • Users and Groups • File and Directory Permissions • Kernel Space vs. User Space

  37. Overview of Linux Security Model • Since Linux Torvalds created in 1991, it has been evolved into one of the world’s most popular and versatile operating system • Free, open-sourced and available in a wide variety of “distributions” • Traditional security model • People or processes with “root” privileges can do anything • Other accounts can do much less • Goal of hackers – to gain root privilege • Linux can be run robust and secure • Many system Admin fail to use the security features • Add-on tools like sudo and Tripwire available • Crux of the problem – Discretionary Access Control

  38. Linux Security Transactions

  39. File System Security • In Linux everything is a file • I/O to devices is via a “special” file • Example: /dev/cdrom points to /dev/hdb which is a special file • Have other special files like named pipes • A conduit between processes / programs • Since almost everything a file – security very important

  40. Users and Groups • Users and Groups are not files • Users • Someone or something capable of using files • Can be human or process • e.g. lpd (Linux Printer Daemon) runs as user lp • Groups • List of user accounts • User’s main group membership specified in /etc/passwd • User can be added to additional group by editing /etc/group • Command line -> useradd, usermod, and userdel

  41. Understanding: /etc/password • username: Used when user logs in. It should be between 1 and 32 characters in length • password: An x character indicates that encrypted password is stored in /etc/shadow file • user ID (UID): Each user must be assigned a user ID (UID). UID 0 (zero) is reserved for root and UIDs 1-99 are reserved for other predefined accounts • UID 100-999 are reserved by system for administrative and system accounts/groups • group ID (GID): The primary group ID (stored in /etc/group file) • user ID Info: The comment field • Allows you to add extra information about the users such as user's full name, phone # etc • This field used by finger command • home directory: The absolute path to the directory the user will be in when they log in • If this directory does not exists then users directory becomes / • command/shell: The absolute path of a command or shell (/bin/bash) • Typically, this is a shell. Please note that it does not have to be a shell.

  42. Understanding of /etc/group • group_name: Name of group • password: Generally password not used, hence it is empty/blank. It can store encrypted password. Useful to implement privileged groups • group ID (GID): Group ID must be assigned to every user • group List: List of user names of users who are members of the group. The user names must be separated by commas

  43. File Permissions • Files have two owners: a user & a group • Each with its own set of permissions • With a third set of permissions for other • Permissions are to read/write/execute in order user/group/other • rw-rw -r-- 1 maestro user 35414 Mar 25 01:38 baton.txt • Permission can be changed using chmod command

  44. Numeric File Permissions • Read (r) = 4 • Write (w) = 2 • Execute (x) = 1 • Example from textbook: drwxr-x--- 8 biff drummers 288 Mar 25 01:38 extreme_casseroles

  45. Directory Permissions • Permissions on folder slightly works different • read = list contents • write = create or delete files in directory • execute = use anything in or change working directory to this directory • Example from textbook: $ chmod g+rx extreme_casseroles $ ls -l extreme_casseroles drwxr-x--- 8 biff drummers 288 Mar 25 01:38 extreme_casseroles

  46. Difference between File and DirectoryPermissions

  47. Sticky Bit • Used to trigger process to “stick” in memory or lock file in memory • Usage now obsolete • Currently used on directories to suppress deletion of file that is owned by others • Other users cannot delete even if they have write permissions • Set group-write bit for directory • Example from textbook: • Chmod g+w ./extreme_casseroles • Set sticky bit using chmod command with +t flag • Example from textbook: • chmod +t extreme_casseroles • Directory listing includes t or T flag • Example from textbook: • drwxrwx--T 8 biff drummers 288 Mar 25 01:38 extreme_casseroles () • The permissions are not inherited by child directories

  48. SetUID and SetGID • SetUI bit: means program “run with same privileges as” owner • No matter who executes it • SetGID bit: means “run with same privileges as” a member of group that owns it • Again regardless of who executes it • Are very dangerous if set of any file owned by if root or other privileged account or group • Only used on executable files, not shell scripts • The command “sudo” is much better tool for delegating root’s authority • Note that the linux kernel ignores the setid and setgid bits on shell scripts; these bits only work on binary (compiled) executables

  49. SetGID and Directories • SetUID has no effects on directories • SetGID does and causes any file created in a directory to inherit the directory's group-owner • Useful if users belong to other groups and routinely create files to be shared with other members of those groups • Instead of manually changing its group

  50. Kernel Space and User Space • Kernel space: refers to memory used by the Linux kernel and its loadable modules (e.g device drivers) • User space: refers to memory used by all other processes • Since kernel enforces Linux DAC and security, its extremely critical to isolate kernel from user space • For this reason, kernel space never swapped to disk • Only root may load and unload kernel modules

More Related