Archiv für die Kategorie: 'Allgemein'

Heute surfen wir im Allgemeinen alle mit dem Webprotokoll HTTP 1.1 bzw. HTTPS via SSL Zertifikat.

In den nächsten Jahren soll ein neuer Standard HTTP/2.0 eingeführt werden. HTTP/2.0 basiert auf Googles Protokoll SPDY. Mittlerweile liegt ein inoffizieller Standard für HTTP/2.0 vor, der ausdrücklich zur Implementierung freigegeben wurde. Dieser neue Standard wurde bereits bei der IETF als HTTP 2.0 eingereicht. Für die großen Big Data Webcontent Vorreiter Google, Facebook, Amazon und Ebay ist dieses Protokoll seit ca. einem halben Jahr Standard.

Die Entwickler von SPDY haben sich die Header eines HTTP-Requests näher angeschaut. In der Regel stehen in diesen Headern Informationen, die bei jedem Request übertragen werden, sich aber nicht ändern. Beispielsweise der User Agent, der die Informationen über den Browser, OS etc. enthält, ändert sich in der Regel nicht innerhalb einer Session.

Eine Komprimierung der HTTP-Header bringt nach Angaben in einem Standard HTTP-Request eine Reduzierung um 52% !!!

Vorteile von SPDY:

  • Verbindung immer verschlüsselt
  • Stream Multiplexing
  • Server-Push Funktion
  • Flusskontrolle für Request/Push
  • Kopfzeilen Kompression
  • Reduktion der Kopfzeilen
SPDY Self Test:
Auf der Website https://www.ist-spdy-aktiviert.de  können Sie SPDY durch einen Selbsttest ausprobieren.

Funktionsweise:

Nach der Reduzierung durch Header-Komprimierung ist es den Entwicklern ein Anliegen den TCP-Slowstart zu ändern um mit weniger Paketen den erforderlichen Content downloaden zu können. Das TCP-Flag „initcwnd“ bestimmt dabei die Anzahl der Pakete die bis zum nächsten ACK übertragen werden dürfen. Die Zahl verdoppelt sich nach jeder erfolgreichen Übertragung, bei der es kein Paketverlust gab. Um diesen Slowstart zu umgehen, werden im Moment von den Clients bis zu sechs Verbindungen gleichzeitig aufgebaut. SPDY hingegen macht nur eine Verbindung auf und nutzt multiplexe Streams für den Ressourcen-Download.

Implementierung:

SPDY kann bereits heute produktiv genutzt werden. Viele wissen dies jedoch noch nicht. Um den Integrationsaufwand so einfach wie möglich zu Gestalten, gibt es ein Modul, welches direkt im Apache Kern eingebunden werden kann. Auch für den Ngix Webserver ist bereits ein Implementierungsmodul vorhanden. Die Browser Firefox, Chrome und Internet Explorer 11 unterstützen bereits SPDY. Für den einfachen User ändert sich nichts. Ob eine Webseite SPDY kompatible ist lässt sich durch ein Spezial Tool feststellen, welche den Downstream analysiert. Falls ein Browser kein SPDY unterstützt so wird das Übertragungsprotokoll HTTP bzw. HTTPs verwendet.

Fazit: Leider kennen noch nicht viele Web Developer die Möglichkeiten von SPDY. Sie könnten dadurch ihren Content viel schneller an den User pushen. SPDY bringt einen extremen Performanceschub und sollte heute auf allen größeren Projektpages implementiert werden.

Weitere Informationen und hilfreiche References:
http://dev.chromium.org/spdy/spdy-whitepaper
http://sprachkonstrukt.de/files/2012/08/http2-presentation.pdf 
http://www.eecis.udel.edu/~amer/PEL/poc/pdf/SPDY-Fan.pdf
https://code.google.com/p/mod-spdy/

http://www.cubrid.org/blog/dev-platform/what-is-spdy-deployment-recommendations/  

Heute hatte ich mal wieder Zeit einen neuen Blog Beitrag zu schreiben. Ich möchte euch mehr über die NoSQL (Not Only SQL) Welt zeigen. Habt ihr euch schon mal gefragt, wie Facebook ihre Big Data speichert ? Wie Amazon ihre Produkte und Einkäufe handelt ? Wie die Google Suche durch mehrere tausend Terrabyte Daten joined – Und im Millisekunden Bereich Ergebnisse liefert ? Mit einer standard relationalen Datenbank ist dies schon lange nicht mehr möglich. Das NoSQL Prinzip ist im Grunde simpel. Diese Datenspeicher benötigen keine festgelegten Tabellenschemata und versuchen, Joins zu vermeiden. Noch dazu skalieren Sie dabei horizontal.

Meine favourite NoSQL Database ist Apache Cassandra. Heute läuft diese Datenbank in mehreren verteilten Facebook Data Centers verteilt in einem Cluster mit über 50000 tausend Servern und ist performant. Der große Vorteil von Apache Cassandra ist

  • Eignung für schnelle verteilte und horizontale Skalierung
  • keine Single Point of Failures
  • Automatische Replikation zwischen Data Centers
  • schemafrei oder nur schwache Schemarestriktionen
  • Key-Value Stores
  • Open Source
  • einfache Datenreplikation zur Unterstützung der verteilten Architektur
  • direkte REST API – JSON, XML auf Keyspaces (Datenbanken), Column Familys (Tables)

Apache Cassandra hat unterm Strich gegenüber einer relationalen Datenbank like MySQL oder Oracle einen Geschwindigkeitszuwachs von etwa Faktor 1.000 (überprüft auf meinem Server durch 1TB free GEO location data auf einem Intel(R) Xeon(R) CPU E5-2620 0 @ 2.00GHz, 4 Cores und 16 Gigbyte RAM) !

MySQL vs. Cassandra

Was sollen Unternehmen machen, welche einen enormen Datenzuwachs redundant stand halten müssen ? Was sollen Unternehmen machen, welche direkt mehrere Gigabyte/Terrabyte/Petabyte Daten durch analytische Algorithmen und Funktionen analysieren wollen?

Mir würden zu diesem Use Case 3 intelligent Wege einfallen:

  • Direktes Data + Type Mapping mit MariaDB (MySQL Nachfolger – down kompatibel) zum Cassandra Cluster
    Die Keyspaces (=Datenbanken in einem NoSQL System) können als Tabelle (View) in SQL gemappt werden und man kann in Real-Time zwischen den Daten joinen und SQL Funktionen anwenden. Verwendung Cassandra als Storage Engine.
  • Direkte Analyse der Daten durch Apache Hadoop, Hive mit direktem Zugriff auf das Cassandra Cluster
  • Kopierung der Daten in eine relationale Datenbank MySQL, Oracle (nicht wirklich sinnvoll!)

Die schnellste Möglichekeit Cronjobs auszuführen, welche zu einer bestimmten Uhrzeit angetriggert werden sollen ist Crontab. Boardmittel von Linux Debian.

Einfach per Terminal auf Server einloggen und per “crontab -e” die Cronjobs eingeben. –> Fertig.!

 

Da ich sowieso schon mal mehr wissen wollte, wie IPv6 funktioniert habe ich mir eine kleine Präsentation gebastelt. Vielleicht kann ich diese ja nochmal irgendwo gebrauchen. Ganz unten gibt es die kompletten Slides als PDF zum Download.

[Ganze IPv6 Präsentation & weitere Folien als PDF Download]

 

 

Hier die ersten paar Slides eines neuen Projektes von mir namens WonderMessage.com

Kurzbeschreibung:

  • „Anonyme Kommunikation auf gleicher Interessensbasis
  • „User I schreibt eine „Flaschenpost“ Nachricht per Smartphone/Browser
  • „Standortbezogen (GEO-Location)
  • „Auto-/Auswahl/Erstellung einer geeigneten Content bezogenen Kategorie
  • „Zuweisung Maximale Reichweite z.B. 50 km
  • „User II:
  • kann eine „Flaschenpost“ Nachricht standortbezogen lesen, beantworten oder schreiben
  • „Komplette Darstellung auf einer Landkarte
[PDF Download - WonderMessage-Project Slides]

Die Neue Suchmaschine ab Mitte 2014 heißt Facebook Search (Social Graph Engine). Es kann nach sozialen Kontakten, Orten, Plätze, Gemeinschaften usw. gesucht werden. Außerdem wird Facebook das Ziel einer “Social Buy Strategy”  folgen. Mittlerweile zählt das soziale Netzwerk bereits über eine Milliarde Nutzer weltweit und kann damit eine enorme Reichweite vorweisen. Mit einer transaktionalen Suche könnte Facebook dabei in Konkurrenz zu allen E-Commerce Websites treten. Facebook besitzt mehrere Milliarden potentielle online Kunden. Somit wird Facebook bald einer der größten Konkurrenten zu Ebay und Amazon. Facebook wird im Q1 2013 Partnerschaften mit mehreren Distributoren suchen. Facebook baut aktuell seine Partnerschaft mit Microsoft aus. Deswegen ist Facebook auch von der Google Maps Integration zu einer Bing Maps Integration umgeswitcht. Im so genannten Social Graph wird es möglich sein nach allen Informationen zu suchen, welche wir als User des Social Networks zusammengetragen haben. Dies kann, muss aber kein Vorteil für uns sein.

Schon ein folgender Satz in Facebook Search…

Personen, die gerne Fahrrad fahren und in Germany, Bayern wohnen

…liefert mehrere Millionen Suchergebnisse (Social Connections).

Erste Entwickler Bilder des sozialen Netzwerkes Solife.me sind nun verfügbar.
Solife.me bietet eine völlig neue Art der Kommunikation. (Weitere Informationen dürfen aktuell noch nicht veröffentlicht werden).

Solife’s Vision

Solife.ME – Communication easier and smarter!

  • Visual Communication
  • Help Functions for Real Life
  • Real Time Media Sharing

read more on Solife.me

Wer schnell per Console alias Terminal seine öffentliche IP-Adresse erfahren möchte kann ab jetzt einfach eingeben:

chris-mac$ curl ifconfig.me

Und es wird die Public Internet IP zurückgegeben.

Here we go on

2013

A NEW SOCIAL NETWORK !

Heute habe ich das neue Windows 8 Professional getestet. Ich habe mir die Mühe gemacht, und alles per Screenshot mitgeschnitten, so könnt ihr auch sehen wie das neuste vom Neusten so designed ist. Sehr schön ist das UserInterface auch genannt Metro, das aber für einen Desktop-PC User eher ungeeignet ist, da man bekanntlich keine Touch Gesten mit der Maus ausführen kann. Wie immer verpasst Microsoft dem Windows ein neues frisches Aussehen. Leider musste ich feststellen, dass der Start Button auf dem Desktop verschwunden ist. Wenn man in die Systemeinstellungen wechseln möchte, wird die Touch Oberfläche gestartet, was für Maus User eher von Nachteil ist. Alles in allem hat Microsoft einen richtigen Schritt in die Zukunft gemacht. Respekt.

(weiterlesen …)