Introduction to Linux System Administration and DevOps methodologies. The goal of this course is to provide the foundation of knowledge with the tools and technologies used in managing today’s highly scalable and agile systems.
MWF: 4-5:00pm, KEC 1001
By appointment only.
- Linux basics:
- Single system fundamentals
- OS installation
- User management
- DNS & DHCP
- Syslog, cron & software RAID
- Linux networking and debugging
- Email servers
- DevOps Methodologies:
- Contribution to the growing DevOps ecosystem
- Continuous Integration & Deployment
- Configuration Management
- Historical Context
- Modern Configuration Management basics
- Service Monitoring tools
- Performance Monitoring tools
- High Availability
- Load balancing strategies
- Setting up services to minimize downtime
- Virtualization & Containerization
- Public and Private cloud technologies
- Use cases between virtualization and containers
- Distributed Systems & Service Discovery
- Current and future approaches of distributed and scalable system architecture
- Introspection on the state of distributed systems
System Administration Handbook (4th Edition) by Evi Nemeth et al
CS 311, CS 344, or instructor approval
- Design a configuration for multiple machines to achieve a specific task.
- Demonstrate how to install an operating system, partition disk space, add and remove network services, connect to a network, and validate system performance.
- Demonstrate how to manipulate user accounts across multiple machines working in concert, including adding/deleting users, checking disk space usage, changing passwords, tracking resource utilization, and tracking login frequency.
- Demonstrate how to manipulate system processes, including listing processes, killing rogue processes, detecting high use processes, moving processing from foreground to background and changing process priority.
- Demonstrate how to start up, reboot, and shut down a collection of machines working in concert.
- Manipulate and change user permissions on files and directories for use with shared groups of collaborators.
- Demonstrate package management and maintenance across multiple systems.
- Create programs that automate system administration tasks.
- Participate effectively in a team environment.
There are no make-up quizzes or exams unless you arrange with me ahead of time with a valid reason.
In general: Students who do not attend lectures tend to do very poorly in this class (C or lower).
Late homework policy¶
Any homework that is turned in past the deadline will incur a -10% dock in grade per day including weekend days.
- 2 midterms (2 x 20 pts ) – 20% of grade
- 1 final (40 pts) – 20% of grade
- 3 Projects (3 x 15 pts) – 22.5% of grade
- 6 Assignments (5 x 15 pts) – 37.5% of grade
Projects are intended to be hands-on and require additional time to complete. Students are allowed to collaborate together on projects, however they will need to each turn in their projects individually with individual results. Students are limited to teams of up to three students.
Homework will be assigned during the term, however collaboration is not allowed.
Policies regarding academic honesty can be found here and compliance is expected for this course.
Students with Disabilities¶
Accommodations are collaborative efforts between students, faculty and Services for Students with Disabilities (SSD). Students with accommodations approved through SSD are responsible for contacting the faculty member in charge of the course prior to or during the first week of the term to discuss accommodations. Students who believe they are eligible for accommodations but who have not yet obtained approval through SSD should contact SSD immediately at 737-4098.