Write a simple tool to analyze logs from the command line.
The goal of this project is to help you practice some basic shell scripting skills. You will write a simple tool to analyze logs from the command line.
Download the sample nginx access log file from here. The log file contains the following fields:
You are required to create a shell script that reads the log file and provides the following information:
Here is an example of what the output should look like:
Top 5 IP addresses with the most requests:
45.76.135.253 - 1000 requests
142.93.143.8 - 600 requests
178.128.94.113 - 50 requests
43.224.43.187 - 30 requests
178.128.94.113 - 20 requests
Top 5 most requested paths:
/api/v1/users - 1000 requests
/api/v1/products - 600 requests
/api/v1/orders - 50 requests
/api/v1/payments - 30 requests
/api/v1/reviews - 20 requests
Top 5 response status codes:
200 - 1000 requests
404 - 600 requests
500 - 50 requests
401 - 30 requests
304 - 20 requests
There are multiple ways to solve this challenge. Do some research on awk
, sort
, uniq
, head
, grep
, and sed
commands. Stretch goal is to come up with multiple solutions for the above problem. For example, instead of using awk
, you can use grep
and sed
to filter and count the requests.
Join the Community
roadmap.sh is the 7th most starred project on GitHub and is visited by hundreds of thousands of developers every month.
Roadmaps Best Practices Guides Videos FAQs YouTube
roadmap.sh by @kamrify @kamrify
Community created roadmaps, best practices, projects, articles, resources and journeys to help you choose your path and grow in your career.
Login to your account
You must be logged in to perform this action.