Apache Log Analyzer is a Python script that analyzes Apache access log files and provides insights into API response times and hit counts for different routes. It extracts relevant information from the log file and calculates response times and hit counts for each API route within a specified time range. It helps you gain insights into your web server's performance and identify potential issues.
- Choose the log file from your local storage using a user-friendly interface.
- Customize the time range for API analysis based on specific dates or predefined options (Yesterday's All Logs, Custom, Yesterday 5AM to 12AM).
- Set your desired threshold for API response times (in milliseconds) using a constant variable.
- Extract and analyze timestamps, API routes, and response times from the log file.
- Calculate API hit counts and identify routes with higher response times.
- Save the analysis results in a separate output file.
- Python 3.x
-
Ensure you have Python 3 and Tkinter installed on your Linux machine. If Tkinter is not installed, you can install it using the package manager specific to your distribution. For example, on Ubuntu, use the command:
sudo apt-get install python3-tk
- Clone the repository:
git clone https://github.com/DhananjayThomble/Apache-Log-Analyzer.git
cd Apache-Log-Analyzer
- Install the required dependencies:
pip install -r requirements.txt
- Run the script:
python api_log_analysis.py
- Select the Apache access log file you want to analyze using the file dialog.
- Choose the time range for the analysis based on your preference or select a predefined option.
- View the analysis results in the
api_names_with_response_times.txt
file.
You can customize the following settings in the script:
RESPONSE_TIME_THRESHOLD
: Set your desired threshold for API response times (in milliseconds).TIME_ZONE_OFFSET
: Set your desired timezone offset.TIME_FORMAT
: Set your desired time format for timestamp extraction.
Contributions are welcome! If you have any suggestions, bug reports, or feature requests, please feel free to open an issue or submit a pull request.
This project is licensed under the MIT License.