Autor wpisu: batman, dodany: 07.12.2011 20:16, tagi: php
W dniu wczorajszym PHP Fog poinformował o zniesieniu sześciomiesięcznego limitu na bezpłatne aplikacje, po którym należało usunąć aplikację lub zmigrować do aplikacji płatnej. Blogosfera się ucieszyła, pojawiły się pozytywne reakcje na ten ruch i wydawać by się mogło, że szum wokół PHP Fog ucichnie tak szybko jak się podniósł, gdy nagle pojawiła się kolejna informacja o zmianach i to nie małych.
Od dzisiaj aplikacje tworzone w chmurze PHP Fog zyskały mechanizm dodatków (Add-Ons). Na starcie są to tylko (a może aż) dwa dodatki MongoDB oraz NewRelic. Pierwszy z nich to znana i lubiana baza NoSQL, drugi – monitoring aplikacji. Oba dodatki obsługiwane są przez zewnętrzne firmy i to w nich rezydują panele administracyjne oraz w nich uiszcza się dodatkowe opłaty.
W przypadku MongoDB obsługą bazy zajmuje się serwis MongoLab.com, do którego zostaniemy przekierowani po dodaniu rozszerzenia. Niestety dokumentacja PHP Fog jest wyjątkowo oszczędna w informacje i o cenach dowiadujemy się dopiero po aktywowaniu rozszerzenia. Na szczęście baza do 240 MB jest bezpłatna. Problemem jest jak się okazuje usunięcie bazy, które odnotowywane jest tylko w MongoLab.com. PHP Fog nie jest świadome tego faktu i wyświetla link do zarządzania nieistniejącą bazą, po kliknięciu w który otrzymujemy komunikat o braku bazy. Warto wiedzieć, iż PHP Fog oraz MongoLab to niezależne usługi, które oddzielnie zarządzają swoimi chmurami. Według zapewnień z dokumentacji zarówno baza jak i aplikacja znajdują się w tym samym datacenter, co ma zmniejszyć opóźnienia.
NewRalic z kolei obsługiwany jest przez stronę NewRelic.com i jest dostępny tylko dla dedykowanych chmur. Niestety dokumentacja nie zawiera żadnych dodatkowych informacji na ten temat.
Mimo iż wyścig do chmury dopiero się rozpoczyna, PHP Fog mocno ruszył do przodu i konkurencyjne platformy, które powstaną w przyszłości, będą miały nie lada problem, by nadrobić zaległości, zwłaszcza że kolejni partnerzy już czekają ze swoimi produktami na wdrożenie.
Autor wpisu: batman, dodany: 07.12.2011 07:51, tagi: php
Jedna z pierwszych, jeśli nie pierwsza, chmura dedykowana dla PHP – PHP Fog, zaktualizowała swój cennik i usunęła limit sześciu miesięcy, po których darmowa aplikacja działająca w ramach współdzielonej chmury musiała zostać zamieniona w aplikację płatną lub usunięta. Co więcej, otrzymujemy możliwość utworzenia aż trzech darmowych aplikacji w ramach jednej chmury. To nie wszystkie nowości. PHP Fog wzbogacił się o nowe aplikacje oraz frameworki i w chwili obecnej obsługuje:
- WordPress
- Drupal 6 i 7
- Joomla
- SugarCRM
- MediaWiki
- PyroCMS
- Zend Framework
- CakePHP
- CodeIgniter
- Slim
- Elefant
- Shopify API
- Kohana
- Laravel
Jak widać lista jest całkiem imponująca i wiele jej nie brakuje.
Zakładając darmową aplikacją musimy jednak pamiętać o ograniczeniach jakie są na nas nakładane – współdzielona pamięć i procesor, 100MB pojemności dyskowej oraz 15 GB limitu transferu danych. Ponadto nie mamy możliwości podpięcia własnej domeny. Niestety nie udało mi się znaleźć dokładnych informacji na temat pamięci, procesora oraz bazy danych.
Do czego taka darmowa chmura może nam posłużyć? Przede wszystkim jako poligon doświadczalny dla naszych aplikacji oraz jako miejsce, z którego możemy pokazywać klientom kolejne etapy powstawania ich aplikacji. Oczywiście nic nie stoi na przeszkodzie aby uruchomić we współdzielonej chmurze nasz własny projekt i w razie konieczności zmigrować go do dedykowanej chmury.
Autor wpisu: Blame, dodany: 04.12.2011 14:43, tagi: php
Witajcie, dzisiaj zaprezentuję wam szalenie przydatny trik, który znajduje zastosowanie zawsze wtedy, kiedy skrypt ma do wykonania jakieś czasochłonne zajęcie a nie chcielibyśmy zbytnio wystawiać na próbę cierpliwość naszych użytkowników. Zatem do dzieła!
Wstęp
Wyobraźmy sobie sytuację, w której użytkownik wchodzi na naszą stronę aby pobrać jakieś dane. Skrypt szybciutko łączy się z bazą i przekazuje mu je najszybciej jak to możliwe. Założenia naszego systemu wymagają jednak, aby każde działanie użytkownika było logowane do bazy. Normalnie połączenie użytkownik->skrypt pozostałoby otwarte, co skutkowałoby tym, że musiałby on bezsensownie czekać na zakończenie działania programu. To jest tylko przykładowa sytuacja, ale są i takie, w których skrypt po wysłaniu odpowiedzi musi się jeszcze wykonywać nawet przez dobre parę sekund. Rozwiązanie, które wam zaprezentuje rozwiąże ten problem.
Sytuacja pierwsza – skrypt zwraca użytkownikowi dane
Skorzystamy tutaj z możliwości PHP do buforowania danych wyjścia. Kluczem do zaoszczędzenia cennego czasu jest tutaj wysyłanie odpowiednich nagłówków, które powiedzą przeglądarce, czy i w którym momencie ma zamknąć połączenie/zakończyć ładowanie strony. Na początek kod:
<?php // otwieramy bufor ob_start(); // tutaj przetwarzamy i wyświetlamy wszystkie dane // pobieramy wielkość bufora $wielkoscOdpowiedzi = ob_get_length(); // wysyłamy nagłówki mówiące przeglądarce o zamknięciu połączenia header("Content-Length: $wielkoscOdpowiedzi"); header('Connection: close'); header('Content-Encoding: none'); // wysyłamy dane z bufora ob_end_flush(); ob_flush(); flush(); // zamykamy obecną sesję if (session_id()) session_write_close(); //proces który leci sobie dalej w tle sleep(10); ?>
Teraz małe objaśnienie. Na początku otwieramy bufor, wszystkie dane jakie potem wyślemy w nim lądują, następnym krokiem jest pobranie rozmiaru bufora, aby potem przekazać przeglądarce po ilu bajtach może skończyć ładowanie strony. Potem wysyłamy wszystkie nagłówki, w tym momencie należy pamiętać, że w tym przykładzie kompresja gzip musi być wyłączona. Jest to spowodowane faktem, że normalnie kompresja następuje po wykonaniu skryptu, co skutkuje różnicą pomiędzy wielkością przesyłanych danych a zadeklarowanym rozmiarem w nagłówku Content-Length. Kolejnym krokiem jest wysłanie całej zawartości bufora oraz zamknięcie sesji dla danego pliku tak aby nie nastąpiła interferencja, kiedy użytkownik będzie przeglądał dalej stronę podczas gdy skrypt nie zakończy jeszcze swojego działania. I teraz najlepsze, cała praca skryptu wykonywana po tych działaniach będzie miała miejsce tak jakby „w tle” i nie będzie już odczuwalna dla użytkownika. Warto dodać ignore_user_abort(true);
na początku skryptu, co uczyni go niewrażliwym na zatrzymanie poprzez kliknięcie przycisku STOP w przeglądarce.
Sytuacja druga – skrypt nie zwracający żadnych danych
Tutaj sytuacja wygląda prościej i nie wymaga „przemeblowywania” kodu. Jeśli skrypt nic nie wyświetla podczas wykonywania a chcemy uzyskać taki sam efekt jak najszybszego uruchomienia programu i zamknięcia połączenia wystarczy na początku skryptu dodać:
header("HTTP/1.0 204 No Content");
Spowoduje to natychmiastowe zakończenie połączenia przez przeglądarkę/cURL/fsockopen przy dalszym wykonywaniu skryptu. Bajecznie prosta metoda, której warto używać zawsze wtedy, kiedy nie przekazujemy nic do przeglądarki.
Podsumowanie
To będzie na tyle moich dzisiejszych wypocin Mam nadzieje, że te dwa sposoby pozwolą wam na tworzenie jeszcze bardziej rozbudowanych a mimo to jeszcze szybszych serwisów.
Pozdro!
Tagged: bufor, curl, fsockopen, PHPAutor wpisu: cojack, dodany: 26.11.2011 19:39, tagi: php
Ostatnio zacząłem pracę nad API Facebooka i moim zadaniem było rozpracowanie tego api, takie tam. Ale doszło w reszcie do acziwmentów na facebugu. Jeden wpis w google how to, i wio ogień, jedziemy. Poszło łatwo, dokumentacja fajna, przejrzysta, wszystko ładnie opisane: link no ale gdyby wszystko poszło bez problemu nie byłoby tego wpisu…
Facebug
Nie bez kozery w żargonie programistów ta nazwa nabiera coraz silniejszego znaczenia. Kto pracuje z API tego serwisu społecznościowego ten to rozumie. Facebook jest teraz w fazie wprowadzania nowego API o nazwie kodowej Graph (wow how f***g awesome it’s?!). Wracając do meritum sprawy, po wywołaniu rejestracyjnego linka z acziwmentem ni stąd ni zowąd dostawałem błąd: „(#3502) Object at achievement URL is not of type game.achievement”, o którym już pisałem wcześniej na forum php: link, niestety nikt chyba wcześniej nie miał problemu z tym (albo miał i się nie podzielił, who care?). Sytuacja doprowadzała mnie do frustracji, gdyż po użyciu debuggera: link nie zwracał mi żadnego błędu związanego z opengraph, a błąd mówił o czymś innym. Bądź tu mądry i pisz wiersze…
Rozwiązanie problemu
Otóż przypadkiem(?) parę razy udało mnie się zarejestrować te acziwmenty, zachodziłem w głowę jak ja to zrobiłem. Maluśka retrospekcja i olśniło mnie co takiego zrobiłem. Otóż proces jaki należy wykonać przed przystąpieniem do zarejestrowania acziwmentu jest taki:
Wchodzi na stronę debbugera: link
Wklepujemy link do naszego acziwmentu, klikamy debug (wow!), teraz na samym dole po poprawnej analizie naszego pliku powinna się znajdować sekcja: „Adresy URL” (tia mam po polskiemu) i jest sobie jakiś pierwszy link:
Graph API: http://graph.facebook.com/blablabla
klikamy na ten link, otworzy nam się stronka z wyplutym jsonem, i dawaj, po tym zabiegu możemy już wykonać poprawnie proces rejestracji acziwmentu bez żadnego problemu!
Słów kilka na zakończenie
3 dni się z tym ścierwem męczyłem…
Autor wpisu: bastard13, dodany: 25.11.2011 15:08, tagi: php, oop
ciągle o tym samym
W dzisiejszym wpisie kontynuuje wątek z poprzedniego wpisu, a więc nadal będzie o metodach:)Dzisiaj zbiór wszelkich różnych rzeczy dotyczących metod, czyli trochę informacji, a trochę dobrych praktyk, które warto przestrzegać, aby z kodem przyjemniej się pracowało:)Czytaj więcej »Autor wpisu: sokzzuka, dodany: 22.11.2011 15:42, tagi: javascript, php
From some time (2+ years) we can observe a huge explosion of different Javascript frameworks. These frameworks divide mainly into two categories
- UI widgets / DOM manipulation frameworks
- class based type system frameworks
In this post I would like to focus on the latter. Every time is see a new framework of this type popping on the news I tend to ask myself the same question – why ? Why one does write all does frameworks, why people so much need classes in Javascript ?
After some thinking I’ve got to a conclusion, that people need them mainly because they are used to the concept of the „class” and to a typical type system like this found in Java, PHP or „name your favorite mainstream programming language here”. This is understandable, as naturally human beings are resistive to change. Also, some people tend to „not get” what’s going on in the prototypical type system. We cannot also blame them here because it has some quirks and well, no one teaches it in schools ( ;P ).
One may ask himself – do we have an other choices to write clean, readable and understandable code other than using JS frameworks ? I think the answer for this question would be affirmative.
But before we come up for a solution. We must think for a second and summarize what we are trying to achieve. I think that are needs wrap in:
- new object instantiation
- information hiding
- code reuse
- modularization
The thing that some one will miss would be inheritance. Should it be on the list ? I don’t think so. The reason for the lack of inheritance is simple – inheritance has two purposes:
- vertical code reuse – the type lower in the hierarchy inherits behavior from the type higher in it
- signature checking – in statically typed class based languages, polymorphism is achieved through inheritance
we could achieve code reuse by other means in Javascript and as JS has no type checking we don’t need inheritance at all.
For our „no framework JS framework” we will use mainly such features of JS as first class functions and JSON. So behold, some common patterns for our daily JS programming:
//persons modulepersons = (function(){ //private Person object constructor var Person = function(firstName, lastName, birthDate){ var foo = "bar"; var name = function(){ return firstName + " " + lastName; } var age = function(){ var currentYear = (new Date()).getYear() var birthDayYear = birthDate.getYear() return currentYear - birthDayYear } var saySomething = function(){ return foo; } //the methods that will be public return { "name": name, "age": age, "saySomething": saySomething } } //private FitnessAddict object constructor var FitnessAddict = function(firstName, lastName, birthDate, weight, height){ var person = Person(firstName, lastName, birthDate); var bmi = function(){ return weight / (height*height); } var isWeightNormal = function(){ var currentBmi = bmi() if(currentBmi > 25){ return false } if(currentBmi < 18.5){ return false } return true } //we make isWeightNormal method public person.isWeightNormal = isWeightNormal; return person; } //we make the fitnessAddict object constructor public return { "fitnessAddict": FitnessAddict }})()view raw noFrameworkJsFramework.js This Gist brought to you by GitHub.
Usage of the example:
var fa = persons.fitnessAddict( "Bar", "Baz", new Date(1990,5,5), 80, 1.8) fa.isWeightNormal() // truefa.saySomething() // "bar"fa.name() // "Bar Baz"view raw noFrameworkJsFramework2.js This Gist brought to you by GitHub.
The first example proves, that we can achieve all of our goals through simple Javascript, without the need for frameworks. The additional benefit is that, because all is private by default, we improve the „cleanliness” of our API.