QStat

(Różnice między wersjami)
Skocz do: nawigacji, wyszukiwania
(Kompilacja)
(Kompilacja)
Linia 67: Linia 67:
 
  make
 
  make
 
W tym momencie kompilują się źródła.
 
W tym momencie kompilują się źródła.
*Ostatni element to wpisanie z prawami superusera komendy
+
*Ostatni element to wpisanie z prawami superusera/root'a komendy:
 
  make install
 
  make install
  
Jesli nie mamy praw superusera/root'a, to mozemypo ''configure'' dopisac ''--prefix=/sciezka/do/jakiegos/katalogu'', na przykład
+
Jesli nie mamy praw superusera/root'a, to mozemy po ''configure'' dopisac ''--prefix=/sciezka/do/jakiegos/katalogu'', na przykład
 
  ./configure --prefix=/var/www/html/mrtg/serwer/bin/
 
  ./configure --prefix=/var/www/html/mrtg/serwer/bin/
  
 
potem make i na końcu make install - wtedy zainstaluje się nie globanie a do wybranego katalogu.
 
potem make i na końcu make install - wtedy zainstaluje się nie globanie a do wybranego katalogu.
  
 +
 +
==Testowanie==
 +
Uruchamiając program z konsoli bez parametrów powinniśmy uzyskać skrócona informacje jak go używać, na przykład
 +
<pre>
 +
[kaszpir@bagno]$ qstat
 +
Usage: qstat [options ...]
 +
        [-default server-type] [-cfg file] [-f file] [host[:port]] ...
 +
Where host is an IP address or host name
 +
-a2s            query Half-Life 2 new server
 +
-ams            query America's Army v2.x server
 +
-bfs            query BFRIS server
 +
-codm          query Call of Duty Master server
 +
-cods          query Call of Duty server
 +
-crs            query Command and Conquer: Renegade server
 +
-d3g            query Descent3 Gamespy Protocol server
 +
-d3m            query Descent3 Master (PXO) server
 +
-d3p            query Descent3 PXO protocol server
 +
-d3s            query Descent3 server
 +
-dm3m          query Doom 3 Master server
 +
-dm3s          query Doom 3 server
 +
-efm            query Star Trek: Elite Force server
 +
-efs            query Star Trek: Elite Force server
 +
-eye            query All Seeing Eye Protocol server
 +
-fcs            query FarCry server
 +
-gps            query Gamespy Protocol server
 +
-grs            query Ghost Recon server
 +
-gs2            query Gamespy V2 Protocol server
 +
-gs3            query Gamespy V3 Protocol server
 +
-gs4            query Gamespy V4 Protocol server
 +
-gsm            query Gamespy Master server
 +
-h2s            query Hexen II server
 +
-hl2s          query Half-Life 2 server
 +
-hla2s          query Half-Life server
 +
-hla2sm        query Steam Master server
 +
-hlm            query Half-Life Master server
 +
-hlqs          query Half-Life server
 +
-hls            query Half-Life server
 +
-hrs            query Heretic II server
 +
-hws            query HexenWorld server
 +
-jk3m          query Jedi Knight: Jedi Academy server
 +
-jk3s          query Jedi Knight: Jedi Academy server
 +
-kps            query Kingpin server
 +
-maqs          query Medal of Honor: Allied Assault (Q) server
 +
-mas            query Medal of Honor: Allied Assault server
 +
-mhs            query Medal of Honor: Allied Assault server
 +
-netp          query NetPanzer server
 +
-netpm          query NetPanzer Master server
 +
-nexuizm                query Nexuiz Master server
 +
-nexuizs                query Nexuiz server
 +
-preym          query Prey Master server
 +
-preys          query PREY server
 +
-prs            query Pariah server
 +
-q2m            query Quake II Master server
 +
-q2s            query Quake II server
 +
-q3m            query Quake III Master server
 +
-q3s            query Quake III: Arena server
 +
-q4m            query Quake 4 Master server
 +
-q4s            query Quake 4 server
 +
-qs            query Quake server
 +
-qwm            query QuakeWorld Master server
 +
-qws            query QuakeWorld server
 +
-rss            query Ravenshield server
 +
-rwm            query Return to Castle Wolfenstein Master server
 +
-rws            query Return to Castle Wolfenstein server
 +
-sas            query Savage server
 +
-sfs            query Soldier of Fortune server
 +
-sgs            query Shogo: Mobile Armor Division server
 +
-sms            query Serious Sam server
 +
-sns            query Sin server
 +
-sof2m          query SOF2 Master server
 +
-sof2m1.0              query SOF2 Master (1.0) server
 +
-sof2s          query Soldier of Fortune 2 server
 +
-stm            query Steam Master server
 +
-stma2s        query Steam Master for A2S server
 +
-stmhl2        query Steam Master for HL2 server
 +
-t2m            query Tribes 2 Master server
 +
-t2s            query Tribes 2 server
 +
-tbm            query Tribes Master server
 +
-tbs            query Tribes server
 +
-tm            query TrackMania server
 +
-tremulous              query Tremulous server
 +
-tremulousm            query Tremulous Master server
 +
-ts2            query Teamspeak 2 server
 +
-uns            query Unreal server
 +
-ut2004m                query UT2004 Master server
 +
-ut2004s                query UT2004 server
 +
-ut2s          query Unreal Tournament 2003 server
 +
-warsowm                query Warsow Master server
 +
-warsows                query Warsow server
 +
-woetm          query Enemy Territory Master server
 +
-woets          query Enemy Territory server
 +
-default        set default server type: a2s ams bfs codm cods crs d3g d3m d3p d3s dm3m dm3s efm efs eye fcs gps grs gs2 gs3 gs4 gsm h2s hl2s hla2s hla2sm hlm hlqs hls hrs hws jk3m jk3s kps maqs mas mhs netp netpm nexuizm nexuizs preym preys prs q2m q2s q3m q3s q4m q4s qs qwm qws rss rwm rws sas sfs sgs sms sns sof2m sof2m1.0 sof2s stm stma2s stmhl2 t2m t2s tbm tbs tm tremulous tremulousm ts2 uns ut2004m ut2004s ut2s warsowm warsows woetm woets
 +
-nocfg          Ignore qstat configuration loaded from any default location. Must be the first option on the command-line.
 +
-cfg            read the extended types from given file not the default one
 +
-f              read hosts from file
 +
-R              fetch and display server rules
 +
-P              fetch and display player info
 +
-sort          sort servers and/or players
 +
-u              only display servers that are up
 +
-nf            do not display full servers
 +
-ne            do not display empty servers
 +
-nh            do not display header line.
 +
-cn            display color names instead of numbers
 +
-ncn            display color numbers instead of names
 +
-hc            display colors in #rrggbb format
 +
-tc            display time in clock format (DhDDmDDs)
 +
-tsw            display time in stop-watch format (DD:DD:DD)
 +
-ts            display time in seconds
 +
-pa            display player address
 +
-hpn            display player names in hex
 +
-hsn            display server names in hex
 +
-nh            do not display header
 +
-old            old style display
 +
-progress      display progress meter (text only)
 +
-retry          number of retries, default is 3
 +
-interval      interval between retries, default is 0.50 seconds
 +
-mi            interval between master server retries, default is 2.00 seconds
 +
-timeout        total time in seconds before giving up
 +
-maxsim        set maximum simultaneous queries
 +
-sendinterval          set time in ms between sending packets, default 5
 +
-errors        display errors
 +
-allowserverdups                allow adding multiple servers with same ip:port (needed for ts2)
 +
-of            output file
 +
-af            Like -of, but append to the file
 +
-raw <delim>    output in raw format using <delim> as delimiter
 +
-mdelim <delim> For rules with multi values use <delim> as delimiter
 +
-xml            output status data as an XML document
 +
-Th,-Ts,-Tpt    output templates: header, server and player
 +
-Tr,-Tt        output templates: rule, and trailer
 +
-srcport <range>        Send packets from these network ports
 +
-srcip <IP>    Send packets using this IP address
 +
-H              resolve host names
 +
-Hcache        host name cache file
 +
-carets        Display carets in Quake 3 player names
 +
-d              Enable debug options. Specify multiple times to increase debug level.
 +
-dump          write received raw packets to dumpNNN files which must not exist before
 +
-pkt <file>    use file as server reply instead of quering the server. Works only with TF_SINGLE_QUERY servers
 +
-htmlmode      Convert <, >, and & to the equivalent HTML entities
 +
-htmlnames      Colorize Quake 3 and Tribes 2 player names using html font tags
 +
-nohtmlnames    Do not colorize Quake 3 and Tribes 2 player names even if $HTML is used in an output template.
 +
-showgameport  Always display the game port in QStat output.
 +
-noportoffset  Dont use builtin status port offsets ( assume query port was specified ).
 +
-raw-arg        When used with -raw, always display the server address as it appeared in a file or on the command-line.
 +
-utf8          Use the UTF-8 character encoding for XML output.
 +
 +
Sort keys:
 +
  servers: p=by-ping, g=by-game, i=by-IP-address, h=by-hostname, n=by-#-players, l=by-list-order
 +
  players: P=by-ping, F=by-frags, T=by-team, N=by-name
 +
 +
qstat version 2.10
 +
[kaszpir@bagno]$
 +
</pre>
 +
 +
jak widać, dla na przykład serwera gry Half-Life Steam mozna przetestować serwer ponizszą komendą:
 +
qstat -a2s 156.17.41.139:27015
 +
Na przykład:
 +
[kaszpir@bagno]$ qstat -a2s 156.17.41.139:27015
 +
ADDRESS          PLAYERS      MAP  RESPONSE TIME    NAME
 +
156.17.41.139:27015    0/16 dod_flash    25 / 0  dod    [PL] Festung-Breslau.pl [DoD 1.3]
 +
[kaszpir@bagno]$
 +
 +
Oczywiście róbcie testy na działającym serwerze :D
 +
=Dodatki=
 +
Nie chce mi się pisać o template, jakie mozna wykorzystywac w qstatcie - np można zwracac wyniki jako HTML czy XML, albo do bazy danych.
  
 
[[kategoria:oprogramowanie]]
 
[[kategoria:oprogramowanie]]
 
[[kategoria:statystyki]]
 
[[kategoria:statystyki]]

Wersja z 14:40, 6 wrz 2006

Spis treści

Opis

Qstat to napisany w języku C/C++ programik do sprawdzania statusu serwerów gier - poprzez wywołanie bezpośrednie, albo do serwerów master.

Jest to program odpalany w konsoli.


Ten artykuł jest niepełny i wymaga uzupełnienia. Jeżeli jesteś w stanie - postaraj się go uzupełnić.. Pamiętaj, że nawet najmniejsza zmiana jest cenna i pomocna :)


Linki

Wersja

Ogólnie jest miszmasz na ich stronie:)

  • CVS jest zawsze najnowsze - czytaj niżej jak pobrać.
  • 2.10 jest do pobrania z SourceForge.net
  • 2.8 to najnowsza oficjalna, na stronie Qstat.org

Instalacja

Windows

Po ściągnięciu zipa i rozpakowaniu mamy wszystko gotowe - warto zajrzec do plików readme ze słownikiem :)

Linux

Po linuxem trzeba QStat skompilować ze źródeł - więc wymagany jest kompilator C/C++ na przykład gcc.

Mozna skompilować źródła po ściągnięciu i rozpakowaniu pakietu .tar.gz albo z CVS - ja polecam to drugie jesli możecie.

CVS

CVS zawiera najnowsza wersje programu - źródła oraz histrię zmian. Większość dystrybucji posiada juz zainstalowanego klienta CVS, ew niektóre wymagaja doinstalowania (np gentoo) - ale nie mam zamiaru pisac jak się istaluje tutaj paiety serwera - poszukajcie informacji na necie, albo poroście admina.

Zdanie jest proste, w konsli linkusa wpisujecie:

 cvs -d:pserver:anonymous@qstat.cvs.sourceforge.net:/cvsroot/qstat login

Po czym wciskacie enter jesli wyskakuje pytanie o hasło. Nastepnie wstukujecie dalej

 cvs -z3 -d:pserver:anonymous@qstat.cvs.sourceforge.net:/cvsroot/qstat co -P qstat2

Pojawi się status aktualizacji plików z serwera, może to troszkę potrwać. Po tej operacji w katalogu qstat2 mamy źródła QStat.

[kaszpir@bagnocvs]$  cvs -d:pserver:anonymous@qstat.cvs.sourceforge.net:/cvsroot/qstat login
Logging in to :pserver:anonymous@qstat.cvs.sourceforge.net:2401/cvsroot/qstat
CVS password:
[kaszpir@bagnocvs]$  cvs -z3 -d:pserver:anonymous@qstat.cvs.sourceforge.net:/cvsroot/qstat co -P qstat2
cvs checkout: Updating qstat2
U qstat2/.cvsignore
U qstat2/CHANGES.txt
U qstat2/COMPILE.txt
...
...
...
cvs checkout: Updating qstat2/template
U qstat2/template/tribes2tp.html
U qstat2/template/tribes2ts.html
U qstat2/template/tribes2tt.html
U qstat2/template/unrealTh.html
U qstat2/template/unrealTp.html
[kaszpir@bagno cvs]$

Kompilacja

  • No dobra, may źródła w katalogu, wchdzomy do niego, w środku jest kilkanaście plików i katalogów.
  • Jeśli widzimy tam plik autogen.sh to wpisujemy
./autogen.sh

Powstana skrypty kofnigrujące.

  • W konsoli wpisujemy:
./configure

Pojawi się skrypt wykrywający konfiguracje systemu i konfigurujący pakiet źróde do kompilacji.

  • Potem wpisujemy
make

W tym momencie kompilują się źródła.

  • Ostatni element to wpisanie z prawami superusera/root'a komendy:
make install

Jesli nie mamy praw superusera/root'a, to mozemy po configure dopisac --prefix=/sciezka/do/jakiegos/katalogu, na przykład

./configure --prefix=/var/www/html/mrtg/serwer/bin/

potem make i na końcu make install - wtedy zainstaluje się nie globanie a do wybranego katalogu.


Testowanie

Uruchamiając program z konsoli bez parametrów powinniśmy uzyskać skrócona informacje jak go używać, na przykład

[kaszpir@bagno]$ qstat
Usage: qstat [options ...]
        [-default server-type] [-cfg file] [-f file] [host[:port]] ...
Where host is an IP address or host name
-a2s            query Half-Life 2 new server
-ams            query America's Army v2.x server
-bfs            query BFRIS server
-codm           query Call of Duty Master server
-cods           query Call of Duty server
-crs            query Command and Conquer: Renegade server
-d3g            query Descent3 Gamespy Protocol server
-d3m            query Descent3 Master (PXO) server
-d3p            query Descent3 PXO protocol server
-d3s            query Descent3 server
-dm3m           query Doom 3 Master server
-dm3s           query Doom 3 server
-efm            query Star Trek: Elite Force server
-efs            query Star Trek: Elite Force server
-eye            query All Seeing Eye Protocol server
-fcs            query FarCry server
-gps            query Gamespy Protocol server
-grs            query Ghost Recon server
-gs2            query Gamespy V2 Protocol server
-gs3            query Gamespy V3 Protocol server
-gs4            query Gamespy V4 Protocol server
-gsm            query Gamespy Master server
-h2s            query Hexen II server
-hl2s           query Half-Life 2 server
-hla2s          query Half-Life server
-hla2sm         query Steam Master server
-hlm            query Half-Life Master server
-hlqs           query Half-Life server
-hls            query Half-Life server
-hrs            query Heretic II server
-hws            query HexenWorld server
-jk3m           query Jedi Knight: Jedi Academy server
-jk3s           query Jedi Knight: Jedi Academy server
-kps            query Kingpin server
-maqs           query Medal of Honor: Allied Assault (Q) server
-mas            query Medal of Honor: Allied Assault server
-mhs            query Medal of Honor: Allied Assault server
-netp           query NetPanzer server
-netpm          query NetPanzer Master server
-nexuizm                query Nexuiz Master server
-nexuizs                query Nexuiz server
-preym          query Prey Master server
-preys          query PREY server
-prs            query Pariah server
-q2m            query Quake II Master server
-q2s            query Quake II server
-q3m            query Quake III Master server
-q3s            query Quake III: Arena server
-q4m            query Quake 4 Master server
-q4s            query Quake 4 server
-qs             query Quake server
-qwm            query QuakeWorld Master server
-qws            query QuakeWorld server
-rss            query Ravenshield server
-rwm            query Return to Castle Wolfenstein Master server
-rws            query Return to Castle Wolfenstein server
-sas            query Savage server
-sfs            query Soldier of Fortune server
-sgs            query Shogo: Mobile Armor Division server
-sms            query Serious Sam server
-sns            query Sin server
-sof2m          query SOF2 Master server
-sof2m1.0               query SOF2 Master (1.0) server
-sof2s          query Soldier of Fortune 2 server
-stm            query Steam Master server
-stma2s         query Steam Master for A2S server
-stmhl2         query Steam Master for HL2 server
-t2m            query Tribes 2 Master server
-t2s            query Tribes 2 server
-tbm            query Tribes Master server
-tbs            query Tribes server
-tm             query TrackMania server
-tremulous              query Tremulous server
-tremulousm             query Tremulous Master server
-ts2            query Teamspeak 2 server
-uns            query Unreal server
-ut2004m                query UT2004 Master server
-ut2004s                query UT2004 server
-ut2s           query Unreal Tournament 2003 server
-warsowm                query Warsow Master server
-warsows                query Warsow server
-woetm          query Enemy Territory Master server
-woets          query Enemy Territory server
-default        set default server type: a2s ams bfs codm cods crs d3g d3m d3p d3s dm3m dm3s efm efs eye fcs gps grs gs2 gs3 gs4 gsm h2s hl2s hla2s hla2sm hlm hlqs hls hrs hws jk3m jk3s kps maqs mas mhs netp netpm nexuizm nexuizs preym preys prs q2m q2s q3m q3s q4m q4s qs qwm qws rss rwm rws sas sfs sgs sms sns sof2m sof2m1.0 sof2s stm stma2s stmhl2 t2m t2s tbm tbs tm tremulous tremulousm ts2 uns ut2004m ut2004s ut2s warsowm warsows woetm woets
-nocfg          Ignore qstat configuration loaded from any default location. Must be the first option on the command-line.
-cfg            read the extended types from given file not the default one
-f              read hosts from file
-R              fetch and display server rules
-P              fetch and display player info
-sort           sort servers and/or players
-u              only display servers that are up
-nf             do not display full servers
-ne             do not display empty servers
-nh             do not display header line.
-cn             display color names instead of numbers
-ncn            display color numbers instead of names
-hc             display colors in #rrggbb format
-tc             display time in clock format (DhDDmDDs)
-tsw            display time in stop-watch format (DD:DD:DD)
-ts             display time in seconds
-pa             display player address
-hpn            display player names in hex
-hsn            display server names in hex
-nh             do not display header
-old            old style display
-progress       display progress meter (text only)
-retry          number of retries, default is 3
-interval       interval between retries, default is 0.50 seconds
-mi             interval between master server retries, default is 2.00 seconds
-timeout        total time in seconds before giving up
-maxsim         set maximum simultaneous queries
-sendinterval           set time in ms between sending packets, default 5
-errors         display errors
-allowserverdups                allow adding multiple servers with same ip:port (needed for ts2)
-of             output file
-af             Like -of, but append to the file
-raw <delim>    output in raw format using <delim> as delimiter
-mdelim <delim> For rules with multi values use <delim> as delimiter
-xml            output status data as an XML document
-Th,-Ts,-Tpt    output templates: header, server and player
-Tr,-Tt         output templates: rule, and trailer
-srcport <range>        Send packets from these network ports
-srcip <IP>     Send packets using this IP address
-H              resolve host names
-Hcache         host name cache file
-carets         Display carets in Quake 3 player names
-d              Enable debug options. Specify multiple times to increase debug level.
-dump           write received raw packets to dumpNNN files which must not exist before
-pkt <file>     use file as server reply instead of quering the server. Works only with TF_SINGLE_QUERY servers
-htmlmode       Convert <, >, and & to the equivalent HTML entities
-htmlnames      Colorize Quake 3 and Tribes 2 player names using html font tags
-nohtmlnames    Do not colorize Quake 3 and Tribes 2 player names even if $HTML is used in an output template.
-showgameport   Always display the game port in QStat output.
-noportoffset   Dont use builtin status port offsets ( assume query port was specified ).
-raw-arg        When used with -raw, always display the server address as it appeared in a file or on the command-line.
-utf8           Use the UTF-8 character encoding for XML output.

Sort keys:
  servers: p=by-ping, g=by-game, i=by-IP-address, h=by-hostname, n=by-#-players, l=by-list-order
  players: P=by-ping, F=by-frags, T=by-team, N=by-name

qstat version 2.10
[kaszpir@bagno]$

jak widać, dla na przykład serwera gry Half-Life Steam mozna przetestować serwer ponizszą komendą:

qstat -a2s 156.17.41.139:27015

Na przykład: [kaszpir@bagno]$ qstat -a2s 156.17.41.139:27015 ADDRESS PLAYERS MAP RESPONSE TIME NAME 156.17.41.139:27015 0/16 dod_flash 25 / 0 dod [PL] Festung-Breslau.pl [DoD 1.3] [kaszpir@bagno]$

Oczywiście róbcie testy na działającym serwerze :D

Dodatki

Nie chce mi się pisać o template, jakie mozna wykorzystywac w qstatcie - np można zwracac wyniki jako HTML czy XML, albo do bazy danych.

Osobiste
Przestrzenie nazw
Warianty
Działania
HLDS.pl - Menu:
Inne
IRC
Inne sekcje:
Znajomi:
Narzędzia