(Webzeugs) Geschwindigkeit C++ (CGI) vs. PHP
-
Original erstellt von crass:
ICh weiß zwar jetzt nicht was wieviel schneller ist, aber bei einer solchen Anwendung kommt es doch nicht so sehr auf Geschwindigkeit an.. was bringts dir wenn der Server die Sache in 0.01 Sekunden berechnet hat anstatt in 0.1, dann aber die Internet-Verbindung 10 Sekunden braucht um die Sachen runterzuladen? Nimm das was dir besser gefällt.Entlastung des Servers ? Weniger Kosten ? Mehr Benutzerzugriffe möglich ? Höhere Skalierbarkeit ?
Ein Arbeitskollege hat's mit CGI gemacht und es war sauschnell, PHP ist (so meine ich) auch wie PERL eine Intepreter Sprache, die noch zusätzliche Performance fressen würde... also haste da schonmal ne Spaßbremse
[ Dieser Beitrag wurde am 23.05.2003 um 16:50 Uhr von Winn editiert. ]
-
Du kannst das nicht vergleichen! PHP läuft im Apache und kann so z.B. Datenbankverbindungen offen halten, C++-CGI-Apps. müssen sie jeweils neu herstellen...
Wenn überhaupt muss du C++FastCGI verwenden oder die App. als Apache-Modul entwerfen. Je nach komplexität erreichst du bei FastCGI ab Faktor 2. Zur Modul-Variante habe ich keinen Vergleich! Evtl. solltest du dir mal Moto angucken: Interpretiert entwickeln und dann zum Apache-Modul kompilieren. Habe ich keine erfahrungen mit, klingt aber gut!
-
kommt alles drauf an:
ist es eine seite die sehr lange laufzeit haben wird - dann rentiert sich C++ uU schon.
wird die meiste zeit auf die DB gewartet, ist C++ nicht sehr sinnvoll.Mit C++ steigen die entwicklungskosten + zeit drastisch an - bei PHP ist beides gering.
Gute libs fuer C++ sind uA
CGIXX
und
CGICCwenn mit einem template system gearbeitet werden soll, bietet sich bei PHP smarty an - fuer C++ kenne ich nur http://www.vbmcgi.org/ - das ist allerdings ne eigene CGI Library
du musst genauer sagen was die anforderungen sind - sonst kann man die frage schwer beantworten...
-
Um mir gleich mal den Wind aus den Segeln zu nehmen ;): Mein erster Post mag sich professionell angehört haben, ist aber nicht so gemeint :). Es handelt sich um kein kommerzielles Projekt, sondern um eins, das meine Freizeit etwas ausfüllen soll (zwischen Schule und Zivi liegt viel Zeit...). Mein Ziel ist ein Browserspiel zu programmieren (naja, ich versuch es wenigstens :)). Deshalb ist ein praktischer Einsatz auch nicht unbedingt meine Absicht. Da ich aber nichts von vornherein ausschließen wollte, möchte ich Geschwindigkeits-Aspekte gerne berücksichtigen (will heißen, Kosten und Zeit sind mir egal, da ich mich nicht bezahlen muß). Bleiben also 3 Möglichkeiten:
- C++ mit FastCGI
- C++ als Apache-Modul
- PHP
Wo liegen außer der zu investierenden Zeit Vor- und Nachteile?
Gruß
Fliegenpilz
P.S.: Trotzdem schon mal vielen Dank für die schnellen Antworten
-
wenn man unter dem apache mod_php bzw. mod_perl (ist schneller als php) beutzt, kommt man auf sehr gute resultate und sehr gute performance.
würde ich einer c/c++ applikation vorziehen. (perl, nicht php!)
-
Ich schreibe gerade selbst einen Chat in CGI-C++.
Die Datenbankabfragen sind etwas schneller.(Nicht der rede Wert)
Du musst dir erst alle Klassen selbst schreiben. Parser für einige Dinge, etc.
Die Verarbeitung ist aber Sauschnell.
Ich verwende die VBMCGI. Habe mir aber eine Session,MYSQL,Datenholder,File, und noch vieles mehr dazu geschrieben. Der Vorteil ist, daß man diese auch in anderen Programmen verwenden kann und sie nicht nur für das Web schreibt. Weiters kann man closed-Source schreiben. Geht mit PHP zwar auch aber die Programme kosten.
Man kann fast sofort WEBANWENDUNGEN schreiben wenn man C++ kann und muss nicht erst PHP lernen.
Jeder Entwickler hat sowieso sein eigenen Klassen bereit und die lassen sich verwenden.
Bei PHP muss immer das Script geparsed werden was Zeit kostet. Allerdings barucht der Aufruf des cgi-programmes auch Zeit die man sich bei PHP wieder spart.
Der Vorteil von Perl und PHP ist, daß er bereits viele Funktionen gibt.
-
Das wichtigste an Allem: Der Hoster muss das Hochladen/ausführen von eigenen CGI-Modulen schon unterstützen sonst hilft alles nix!
-junix
-
Original erstellt von junix:
**Das wichtigste an Allem: Der Hoster muss das Hochladen/ausführen von eigenen CGI-Modulen schon unterstützen sonst hilft alles nix!
**jo. und ich kenne noch keinen, der so nett ist.
-
Irgendwas sagt mir, das hat nix mit nettigkeit zu tun, volkard (o;
-junix
-
Original erstellt von Fliegenpilz:
Meine Frage ist nun, welche Lösung um wie viel schneller als die andere ist (ungefähr).wenn du eh von apache ausgehst, dann wohl php. wenn ich recht vertande habe, hat der php sauber integriert (in seinem prozess selber) und braucht nicht dauernd umzuschalten. mit dem zend optimizer sollte php auch nicht lahm sein. wird das programm größer, ist nach c++ umzusteigen. aber auch kaum wegen des speeds. mehr als faktor 2 traue ich c++ unter apache unter keiner ernsthaften anwendung zu. sondern, weil c++ destruktoren hat. su kannst aus der innigsten mitte deiner verschachtelten funktionen throw WRONG_PASSWORD machen, und nix der geschützt daten komt an, sondern nur dein fehlertext, aber der richig. mit php5 bald kannste vermutlich auch wieder php nehmen, das hat destruktoren (hoffenlich nicht pseudo-destruktoren wie jave).
top speed wirste erreichen, wenn du in c++ nen eigenen http-server baust und dem erlaubst, ohne taskwechsel die seiten aufzubauen und zu verschicken (mal davon ausgehend, daß zum lesen der seiten, weil im cache, kein passives warten nutwendig ist). müßtest auch den eingang zustandslos machen. oh, das ist gemein zu programmieren. mein tip: nimm doch nen langweiligen thread pro aufgerufener seite und dann kannste auch gleich apache nehmen und dann kannste auch php nehmen. php fühlt sich echt wohl im apache. (perl ürigens auch).
-
Original erstellt von junix:
**Irgendwas sagt mir, das hat nix mit nettigkeit zu tun, volkard (o;
**äh. jo. ausreichend geld tut es auch.
-
könnte man nicht viele Probleme der C++ CGIs dadurch lösen, dass man ein Backend schreibt, dass sich um die verschiedenen Resourcen (MySQL Anbindung etc.) kümmert, so dass die eigentliche CGI die aufgerufen wird nur an das Backend die Parameter übergibt. Dann wär auch IPC zB. deutlich leichter.
ab nach Webzeugs