Lua*

Разработка → Подсчет статистики загрузок в Google Analytics

fuCtor 11 марта 2014 в 08:19 8,2k

Продолжая тему использования связки Nginx + Lua решил поделиться небольшой инструкцией подсчета загрузки статических данных и учетом всего этого в Google Analytics.

Будем считать что связка nginx-lua уже настроена и у нас имеется имя счетчика. Если нет, то в сети есть множество инструкций, также есть готовые сборки ( openresty.org ).
Для учета нам понадобиться скрипт, который будет отправлять данные в GA. Писать свой не хотелось и на просторах Github-a был найден пример: github.com/wstucco/ssga.lua Данный скрипт имеет один метод track, который принимает обязательным параметром имя счетчика, так же могут быть переданы имя хоста и путь, которые нужно передать. После его срабатывания, на панели статистики в реальном времени увидим наш переданный путь.
Учитывать загрузки можно двумя способами:
  • учитывать по пути загружаемого файла;
  • учитывать через события.

Первый вариант удобен когда нет смысла разделения файлов по категориям/группам, либо когда это сделать возможности нет, но вести статистику хочется. Второй вариант подходит для случая, когда есть строгая структура файлов, к примеру: раздел-категория-тип.
Рассмотри оба.

Простой учет пути

Самый простой путь, не требующий никаких особых манипуляций и подготовки. Поэтому приведу лишь конечную часть конфига nginx.

resolver  8.8.8.8;
access_by_lua '    
     local ssga = require( "ssga" )
     ssga.track({ua = "UA-25XXXXXX-1")
';

Перезагружаем и любуемся побежавшими записями в GA.

Учет через события

Данный способ требует определиться с тем, как будем квалифицировать скачиваемые файлы. В терминах GA нам нужно выделить 3 сущности: категория, действие, метка. В своем случае для этого использовал имена папок, тогда конечный URL загружаемого файла имел вид: dl.domain.name/category/action/label/filename.ext
Так же необходимо было научить имеющийся скрипт передавать данную информацию в GA. После небольших модификаций была получена расширенная версия скрипта ( github.com/fuCtor/ssga.lua ).
В итоге имеем следующую конфигурацию:

server {
  listen 80;
  server_name dl.domain.name;

  root /var/www/public;
  error_page 502 /502.html;

  location / {

    add_header Cache-Control public;
    expires  max;

    resolver 8.8.8.8;

    access_by_lua '
        opt = {}
        index  = 0
        for value in string.gmatch(ngx.var.uri ,"%w+") do
         opt [index] = value
         index = index + 1
        end
        local ssga = require( "ssga" )
        ssga.event({ua = "UA-25XXXXXX-1", domain = "dl.domain.name", category = opt[0], action = opt[1], label = opt[2], value = 1})
    ';
    }
}

Сохраняем перезагружаем. Теперь можем вести статистику по загрузкам в удобной форме, делать различные срезы.

Производительность

Проверять будем как быстро отработает именно наш счетчик, поэтому выполним HEAD запросы, тело нас не интересует.

Concurrency Level:      30
Time taken for tests:   3.223 seconds
Complete requests:      1000
Failed requests:        0
Write errors:           0
Total transferred:      348000 bytes
HTML transferred:       0 bytes
Requests per second:    310.26 [#/sec] (mean)
Time per request:       96.694 [ms] (mean)
Time per request:       3.223 [ms] (mean, across all concurrent requests)
Transfer rate:          105.44 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.1      0       1
Processing:    94   95   0.6     95      99
Waiting:       94   95   0.6     95      99
Total:         94   95   0.6     95      99


Concurrency Level:      30
Time taken for tests:   0.048 seconds
Complete requests:      200
Failed requests:        0
Write errors:           0
Total transferred:      69600 bytes
HTML transferred:       0 bytes
Requests per second:    4166.58 [#/sec] (mean)
Time per request:       7.200 [ms] (mean)
Time per request:       0.240 [ms] (mean, across all concurrent requests)
Transfer rate:          1415.99 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.3      0       1
Processing:     6    6   0.8      6       9
Waiting:        6    6   0.8      6       9
Total:          6    7   0.9      6      10



Изображение в шапке взято отсюда.
Проголосовать:
+29
Сохранить: