Auf der Symfony2 Doku Seite zum HTTP Cache wird sehr gut und ausführlich beschrieben, wie man aus einer Applikation noch mehr Speed durch Caching heraus holt. Dieser Geschwindigkeitszuwachs kann durch den eingebauten gateway cache oder durch einen externen Server/Dienst wie Varnish, der als Reverse Proxy fungiert, erreicht werden. Die Funktionsweise des… Read more »
function googleMapsApi() { scope = null; this.loadGoogleMapsApi = function (callback) { if (typeof(google) !== ‚undefined‘ && typeof(google.maps) !== ‚undefined‘) { // trick to execute the callback as a function window[scope][callback](); return; } var script = document.createElement(„script“); script.type = „text/javascript“; script.src = „http://maps.google.com/maps/api/js?sensor=false&callback=“ + scope + „.“ + callback; document.body.appendChild(script); }… Read more »
Wenn jemand das Problem haben sollte, dass der Apache-Server sich nach einer Windows-Installation allen verfügbaren RAM nimmt und die Maschine fast zu stehen bekommt, hier zwei Tipps. 1. Es wird immer empfohlen in der Datei: Apache Software Foundation\Apache2.2\conf\extra\httpd-mpm.conf Dein Einrtag „Win32DisableAcceptEx“ zu aktivieren, bzw. hinzu zu fügen. ThreadsPerChild 150 MaxRequestsPerChild… Read more »
Eigentlich möchte man ja, dass die CSS und Javascript-Dateien nur einmal vom User herunter geladen werden und dann lange Zeit nicht mehr. Dieser Wunsch ist verständlich, da ja inzwischen Javascript/CSS-Frameworks wie jQuery viele Kilobyte belegen. Man kann natürlich die alte Datei löschen und eine neue Datei referenzieren. Dies ist aber… Read more »
Wenn man Textteile suchen und ersetzen möchte, dann geht das in SQL einfach mit der REPLACE-Funktion. Leider stößt die Funktion bei TEXT-Feldern an Ihre Grenzen und verweigert den Dienst. Um aber dennoch Textteile ersetzen zu können habe ich unter http://blogs.x2line.com/al/archive/2008/05/03/3417.aspx die Lösung gefunden (und noch verfeinert 🙂 ). Ich habe… Read more »
Wenn man doppelte Datensätze in einer Tabelle finden und eliminieren möchte, ist das manuell zwar möglich, es wird aber ab einer gewissen Anzahl von Datensätzen nicht mehr sinnvoll möglich sein. Zum Glück gibt es SQL und dabei speziell den HAVING-Operator. Dieser ermöglicht uns, eine Datenbankabfrage zu starten und danach das… Read more »
Wenn man im Nagios3 über die Oberfläche z.B. einen restart des Services oder einen Check-Befehl manuell aus führen muss, muss man in der Datei „/etc/nagios3/nagios.cfg“ die Variable „check_external_commands“ auf „1“ setzen. (“check_external_commands=1″) Leider funktioniert das aber nicht unter Ubuntu. Es kommt die Fehlermeldung: error: Could not stat() command file ‘/var/lib/nagios3/rw/nagios.cmd’!… Read more »
Um den Javascript/Jquery Quellcode nicht zu sehr wachsen zu lassen, möchte ich auf zwei alternative (und kürzere) Möglichkeiten bei jQuery hinweisen. Um einen AJAX POST abzusetzen muss man nicht unbedingt mit jQuery.ajax… arbeiten. Es reicht wenn man $.post(„/rabattSpeichern“, function(data){ alert(data); // Ausgabe des Antwortstrings }); verwendet. Was ich jetzt erst… Read more »
Wenn man in Datenbanken mit starker Normalisierung arbeitet, ist es mitunter mühselig die einzelnen Tabellen mit unterschiedlichen SQLs „upzudaten“. Aber es gibt auch die Möglichkeit UPDATE – SQLs mit JOIN zu verknüpfen. UPDATE adressen SET name = z.name, plz = z.plz, ort = z.ort FROM adressen As a INNER JOIN… Read more »
Wenn man bei der täglichen Datensicherung so überprüft, fällt einem ab und zu ein richtig großer Brocken auf. Bei Dateien ist das kein Problem, bei Datenbanken hingegen schon. Wenn die SQL-Datenbank plötzlich mehrere Gigabyte (GB) groß ist, fragt man sich, woher das kommt. Es gibt die Möglichkeit, auf jede Tabelle… Read more »