Direkt zum Hauptbereich

nginx mit CakePHP 2.1.2

Und nun werde ich Euch zeigen, wie ich CakePHP 2.1.2 mit nginx versöhnte:

Jedoch muss ich dafür nichts wiederholfen, also guckt erstmal hier,
bei mir jedoch ohne spawn-cgi:
http://kevin.vanzonneveld.net/techblog/article/cakephp_and_nginx/

Ich werde nun den Code durchgehen und erklären, was ich gelernt habe bzw. was Ihr vielleicht machen müsstet:


root    /var/www/example.com/app/webroot;  
index    index.php index.html index.htm;
   

Obig wird der absolute Pfad zum Wurzelverzeichnis von nginx gelegt.
Dieses ist bei CakePHP in cakephp/app/webroot.

Ich nutze hierfür immer nano in der Shell:
nano /etc/nginx/conf.d/default.conf

Mein Pfad unter Fedora sieht nun so aus:
 root        /usr/share/nginx/html/cakephp/app/webroot;

Der Rest ist geblieben, und ich wählte bewusst den default-Ordner von nginx, weil ich mir die Option offen halte möchte, Apache wieder laufen zu lassen.
Es macht nicht viel Sinn, weil ich so physikalisch zwei Ordner mit cakephp habe, aber diese Daten sind klein und ich trenne die beiden Server lieber, um für spätere Stolpersteine und Vergleiche vorzusorgen.
Die wesentlichen Daten sind ja sowieso in einer Datenbank gespeichert, worauf von beiden zugegriffen werden kann.

CakePHP kann aber nun eben auch über die URL angesprochen werden,
so beschreibt Ammelbruger et al ein Beispiel mit folgender ULR:
http://localhost/cakejobs/jobs

Hier ist webroot=cakejobs aber der Ordner jobs existiert nicht, wird aber normalerweise von htaccess umgeleitet.

Dies muss man nun nginx auch beibringen, also dass jede nicht vorhandene ULR als Argument an CakePHP weitergereicht wird:


   # Not found this on disk?   
   # Feed to CakePHP for further processing!  

   if (!-e $request_filename) {  
     rewrite ^/(.+)$ /index.php?url=$1 last;  
     break;  
                              }  

Die nächste Veränderung zur Standardkonfiguration ist im nächsten Block zu sehen, der für das fastcgi sorgt:


location ~ \.php$ {
        # fastcgi_pass   unix:/tmp/php-fastcgi.sock;
        fastcgi_pass   127.0.0.1:9000;


Dort ist nämlich kein root mehr, sondern einfach die URL samt Port, wo der PHP-FastCGI-Parser lauert.

Ich hatte eine Weile gebraucht, um jene Seite zu finden;
und nach einigen Versuchen kopierte ich einfach deren Zeilen und ersetzte meine default.conf damit bis es dann klappte.

Wähle ich nun localhost an, springt mir CakePHP entgegen,
dass dann nur noch eingerichtet werden muss.

Ciao

Kommentare

Beliebte Posts aus diesem Blog

rails + carrierwavve + plupload = multiple file upload

Right now I am very happy! I finished my work on creating a file upload method in rails for more than one file, altogether handled by rails sessions and as objects. First I had to learn a bit more about how rails works and I achieved that by reading a lot: books, screencasts and blogs. In this blog post I like to share what I accomplished, but without the hussle of putting code blocks in here, so watch out for bold formatted text as that is the code. My goal was to have one site with just the pure option of uploading files. All file handling would be done behind the scenes by myself logging onto my server. That said you are not going to see any fancy CRUD here. Lets start then! And dont forget to versioning your app BEFORE you try something new! [e.g. git] > rails g scaffold Photo title:string Now add carrierwave to you Gemfile and run > bundle install >rails g uploader Photo Alltogether you have model, controller, views and an uploader folder with the Ph...

debian 6 vserver - a new installation due to centOS update problem - my steps

My centOS vserver broke down after a "yum update" and even the centOS community forum could not give an answer within 24h. In my books that is poor for the almighty and stable centOS. Bare in mind that I am just a normal user of linux, no professional and definitely no expert when it comes to server, but I can read, try and share my findings: debian 6 installation steps via ssh secure your server: adduser foobar for security purposes  change /etc/sshd/sshd_conf to PermitRootLogin no now you can login as foobar and change to root via su - visudo for sudo command permissions and put this at the bottom: foobar   ALL=(ALL) ALL change hostname change hostname in /etc/hostname and in /etc/hosts reboot login via rsa key rather than password locally do ssh-keygen ssh-copy-id -i foobar@hostname... ssh now works without passwords but with keys (for easy deployment) install ruby and rails via rvm login as root always good to have: sudo apt-get install...

Virtuelles Wasser?!

In den letzten Tagen habe ich immer mal wieder etwas mit Rails programmiert und werde mich ebenso heute dem neuen Auftrag "multiple file upload" kümmern. Und weil vieles "Versuch-Irrtum" ist, gucke ich auf dem zweiten Monitor immer Reportagen. Letztens kam mir "Der große Haushaltscheck" unter die Finger: ARD Mediathek "Der große Haushaltscheck" In der Sendung vom 11.3.2013 ging es um unser Trinkwasser. Jedem sollte klar sein, dass Plastikflaschen nicht die erste Wahl sind, weil man nicht darauf vertrauen kann, dass der Hersteller wirklich "gutes" Plastik nahm (BPA, Phtalate, Benzol, Xylol usw.), aber das interessante waren die genannten Zahlen in puncto virtuellem Wasser bzw. Wassersparen. Wasser sparen an und für sich ist ja gut, nur heisst das nicht, dass wir weniger die Klospühlung benutzen sollten, sondern dass wir uns Gedanken machen über das "virtuelle Wasser". Unsere Kanalisation ist eine Schwemm-Kanalisatio...