Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/skx/asql
A toy utility to process Apache log files via SQL.
https://github.com/skx/asql
acc apache perl sqlite sqlite3
Last synced: 3 months ago
JSON representation
A toy utility to process Apache log files via SQL.
- Host: GitHub
- URL: https://github.com/skx/asql
- Owner: skx
- Created: 2018-11-04T14:20:46.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2022-01-13T04:13:11.000Z (almost 3 years ago)
- Last Synced: 2024-10-02T10:12:26.654Z (3 months ago)
- Topics: acc, apache, perl, sqlite, sqlite3
- Language: Perl
- Homepage: https://steve.fi/Software/asql/
- Size: 167 KB
- Stars: 7
- Watchers: 4
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Homepage:
http://www.steve.org.uk/Software/asql/Git Repository:
http://github.com/skx/asql/asql
----ASQL is a simple tool to allow you to query Apache common logfiles
via SQL. (Only "Apache common" logfiles are currently supported.)When asql starts up it creates a temporary SQLite database to hold
the contents of the parsed logfile(s) you might load. This temporary
database may then be queried directly via SQL.Why might you want to do this? Well it does allow you to make certain
queries very easily.Aliases
-------Using the 'alias' command you may record and replay previous
queries by name, along with variable expansion.For example the following query will show the number of hits
against your server:SELECT COUNT(id) FROM logs;
You could save this query via this:
ALIAS hits SELECT COUNT(id) FROM logs;
Now at any future point entering 'hits' would run the query.
If you wish you can use variables in aliases such as:
ALIAS hitsagent SELECT * FROM logs where agent like '%$1%';
The text `$1` will be replaced by the first argument you supply to the alias when running it:
hitsagent mozilla
hitsagent SlurpYou can use variables from $1 to $9.
(Aliases persist between sessions via the file `~/.asql.aliases`.)
Example Queries
---------------The following examples give an idea of the kind of power an SQL query allows you:
Greediest downloaders:
SELECT source,SUM(size) AS Number FROM logs GROUP BY source ORDER BY Number DESC, source
A count of each distinct referers:
SELECT referer,COUNT(referer) AS number from logs WHERE referer NOT LIKE '%steve.org.uk%' GROUP BY referer ORDER BY number DESC,referer LIMIT 0,10
See which Debian packages were downloaded the most:
SELECT request,COUNT(request) AS Number FROM logs WHERE request LIKE '%.deb' GROUP BY request ORDER BY Number DESC, request;
See who has downloaded me:
select * FROM logs WHERE request='/etch/pool/main/a/asql/asql_0.6-1_all.deb';
Dependencies
------------For parsing IPv6 log entries the `Regexp::IPv6` module is required.
Steve
--