The UNIX and Linux Forums  


Go Back   UNIX och Linux Forum > Upp Forum > High Level Programming
.
google unix.com



High Level Programming Post frågor om C, C + +, Java, SQL och andra programmeringsspråk här.

Mer UNIX och Linux Forum Ämnen Du kan hitta Helpful
Tråd Thread Starter Forum Svar Senaste Inlägg
semaforen raguramtgr UNIX for Dummies Frågor & Svar 7 06-15-2009 10:39
Semaforen Jaken Shell-programmering och Skript 2 04-04-2009 06:10
dmidecode, RAM-hastighet \u003d "Current Speed: Okänt" Santi Filsystem, diskar och Minne 0 02-16-2006 06:16
Semaforen vjsony UNIX for Dummies Frågor & Svar 3 04-07-2003 03:06
semaforen yls177 UNIX for Dummies Frågor & Svar 1 10-09-2002 12:18

Closed Thread
English Japanese Spanish French German Portuguese Italian Dutch Swedish Russian Norwegian Hungarian Hebrew Danish Bulgarian Greek Powered by Powered by Google
 
LinkBack Thread Tools Sök i denna tråd Omdöme: Thread Rating: 1 votes, 4.00 average. Visningslägen
  #1 (permalänk)  
Old 09-17-2008
migurus migurus is offline
Registered User
  
 

Join Date: Sep 2008
Ort: USA
Inlägg: 49
semaforen åtkomsttid

Jag undersöker några låsa systemet med hjälp av semaforer. Att utvärdera grundläggande systemet hastighet jag köra en slinga för att få några semaforen info och visa den:

samtidigt:; göra. / semshow; gjort> res.txt

Jag har kört på 3 lådor - två liknande moderna HP Xeon lådor, en kör SCO OpenServer 5, den andra är Fedora 2.6.9 och en gammal PIII rutan under modern Linux (har någon info).
Resultaten är mycket motverka intuitiv:
H / W | OS | avg antalet körningar ber sek
---- | --- | -------------------------
Xeon | SCO | 1700
Xeon | Fedora | 500
PIII | Linux (senaste distributioner, okända) | 900
Alla tre systemen var ganska inaktiv på provmätningen temne.

Jag skulle vilja fråga, vad skulle de faktorer som gör antika Unix överträffa moderna OSes också, hur kommer PIII fält överträffa moderna Xeon rutan under liknande OS. Alla ponters skulle uppskattas.

Den semshow program är mycket grundläggande, se lista nedan:

Kod:
 
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include  <sys/timeb.h>
#include <time.h>
#include "semlib.h"
#define MODE_CREATE     0
#define MODE_REMOVE     1
key_t   IPCKEY;
main(int argc, char *argv[])
{
  int   sid, i;
  pid_t last_rpid, last_wpid;
  char  dbuf[80];
  union semun           arg;
  unsigned short        vals[NSEMS];
  struct timeb tb;
  struct tm *tp;
        if((IPCKEY = get_ipc_key()) == -1)
        {
                errexit("Can Not Obtain IPC Key");
        }
        if((sid = semget(IPCKEY, NSEMS, 0)) == -1)
        {
                errexit("Can Not Get Semaphore ID");
        }
        memset(vals, 0, sizeof(vals));
        arg.array = &vals[0];
        if(semctl(sid, NSEMS, GETALL, arg) == -1)
        {
                errexit("Can Not Get Semaphore Values");
        }
        if((last_rpid = semctl(sid, RDLOCK, GETPID)) == -1)
        {
                errexit("Can Not Get Semaphore R-Pid");
        }
        if((last_wpid = semctl(sid, WRLOCK, GETPID)) == -1)
        {
                errexit("Can Not Get Semaphore W-Pid");
        }
        ftime(&tb);
        tp = localtime(&tb.time);
        strftime(dbuf, sizeof(dbuf) - 1, "%T", tp);
        printf("%12li.%03i %s  RD:[%i]  WR:[%i] %i/%i\n",
                tb.time, tb.millitm, dbuf, 
                vals[RDLOCK], vals[WRLOCK],
                last_rpid, last_wpid);
        exit(0);
}

semlib.h har dessa defs:

Kod:
 
#define NSEMS   2
#define RDLOCK  0
#define WRLOCK  1
union   semun   {
        int             val;
        struct semid_ds *buf;
        unsigned short  *array;
};

  #2 (permalänk)  
Old 09-18-2008
otheus's Avatar
otheus otheus is online now Forum Staff  
Moderator ala Mode
  
 

Join Date: februari 2007
Location: Innsbruck, Österrike
Inlägg: 1892
Här är ett svar: din tid är felaktig. Se människan på ftime () under Linux:

Citat:
Denna funktion är föråldrad. Använd den inte. Om tiden i sekunder räcker, tid (2) kan
skall användas, gettimeofday (2) ger mikrosekunder, clock_gettime (3) ger nanosekunder men
är ännu inte allmänt tillgängliga.

Enligt libc4 och libc5 den millitm området är meningsfullt. Men tidigt glibc2 är felaktig och
återvänder 0 där, glibc 2.1.1 är korrekt igen.
  #3 (permalänk)  
Old 09-18-2008
migurus migurus is offline
Registered User
  
 

Join Date: Sep 2008
Ort: USA
Inlägg: 49
Fedora fält har
/lib/tls/libc.so.6 -> libc-2.3.5.so
ja, jag utgår från den version 2.3.5.

Men det är vid sidan av poängen.

Den rena antal gånger systemet drev program inom andra skulle ange övergripande system makt, så att säga. Till min förvåning PIII under Linux lyckades köra nästan dubbelt så många cyklar withi ett andra än Xeon 3.2GHz under Linux. Sedan samma Xeon h / v under gamla SCO OSR köra dubbelt så snabbt som PIII rutan.
  #4 (permalänk)  
Old 09-18-2008
otheus's Avatar
otheus otheus is online now Forum Staff  
Moderator ala Mode
  
 

Join Date: februari 2007
Location: Innsbruck, Österrike
Inlägg: 1892
Men Problem # 1 är att man mäter det här på fel sätt. Du har för många beroenden på biblioteket samtal som är irrelevanta för det du försöker att mäta. Ta bort alla semaforen kod nytt test, och se vilka tider du får. Eller köra en 10.000x slinga runt semaforen. Sedan skala ner till närmaste andra så att mikrosekunder mistimings inte kommer in i bilden.

Problem # 2 är att semaforer kräver buss-tillgång och är relativt oberoende av Processor hastighet.
  #5 (permalänk)  
Old 09-18-2008
migurus migurus is offline
Registered User
  
 

Join Date: Sep 2008
Ort: USA
Inlägg: 49
Jag ersatte ftime med gettimeofday och kör, resultaten är desamma.

Sammanfattningsvis igen
samma h / v:
program enligt SCO går 3 gånger snabbare än under Linux,
samma OS:
körs 2 gånger snabbare om gamla PIII än på moderna Xeon

Alla skäl? några idéer?
  #6 (permalänk)  
Old 09-18-2008
otheus's Avatar
otheus otheus is online now Forum Staff  
Moderator ala Mode
  
 

Join Date: februari 2007
Location: Innsbruck, Österrike
Inlägg: 1892
Jag är ledsen, men du har fortfarande inte avskaffat alla "lös variabler. Men din semaforen kod i en loop av 1000 eller så och bänken igen.
  #7 (permalänk)  
Old 09-18-2008
migurus migurus is offline
Registered User
  
 

Join Date: Sep 2008
Ort: USA
Inlägg: 49
Jag förenklade mitt program till mycket grundläggande minimum, det blir IPC nyckel får semaforen id och läser värden av semaforer och då är det utgångar på rad (temne och semaforen värden). Det är allt den gör.

Då ska jag köra det på följande sätt:
$ Samtidigt:; göra tstshow; gjort> x.txt
och jag drabbades avbryta nyckel efter väntar en tid.

urval av de x.txt fil innehåll:
1221785538 [1,99]
1221785538 [1,99]
1221785538 [1,99]


Sen att se hur många gånger som kunde köra det jag gör:
$ Cut-c-12 x.txt | Uniq-c

urval av resultaten:
616 1221785538
615 1221785539
612 1221785540

Det tels mig systemet klarar av att driva detta enkelt bara ungefär 600 gånger per sekund.

Bara för att vara konsekvent skulle jag upprepa resultaten här:
PIII under Linux -- 900 ggr / sek
Xeon 3.2 Linux -- 600 ggr / sek
Xeon 3.2 SCO -- 1800 ggr / sek
Systems är inaktiv vid tiden för testet.
Hur skulle du förklara de resultat som jag har? Jag försöker att hitta en flaskhals på den moderna h / w som kör Linux.

Se min nya förenklade koden nedan:


Kod:
 
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <time.h>
#define NSEMS   2
main(int argc, char *argv[])
{
  int           sid;
  ushort        vals[NSEMS] = {0, 0};
        if((sid = semget(get_ipc_key(), NSEMS, 0)) == -1)
        {
                errexit("Can Not Get Semaphore ID");
        }
        if(semctl(sid, NSEMS, GETALL, vals) == -1)
        {
                errexit("Can Not Get Semaphore Values");
        }
        printf("%12li [%i,%i]\n", time(NULL), vals[0], vals[1]);
        exit(0);
}

Closed Thread

Komihåglista

Thread Tools Sök i denna tråd
Sök i denna tråd:

Avancerad sökning
Visningslägen Betygsätt denna tråd
Betygsätt denna tråd:

Utstationering Regler
Du får inte efter nya trådar
Du får inte efter svar
Du får inte skicka bilagor
Du får inte redigera dina inlägg

BB-kod är
Smilies är
[IMG] kod
HTML-koden är Av
Trackback är
Pingbacks är
Refbacks är




Alla tider är GMT -4. Klockan är nu 10:11.


Powered by: vBulletin, Copyright © 2000 - 2006, Jelsoft Enterprises Limited. Översättningar Powered by .
vBCredits v1.4 Copyright © 2007 - 2008, PixelFX Studios
UNIX och Linux Forum Innehållet upphovsrättsskyddat © 1993-2009. All Rights Reserved.Ad förvaltning RedTyger

Content Relevant webbadresser från vBSEO 3.2.0