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...

Stream your media to your DLNA device e.g. tv with miniDLNA on a linux machine

Recently we bought a Sony Bravia LED TV with the possibility to receive streams. It can read DLNA, which is not much, so dont fall for the certificate. DLNA means it can read MPEG-I/II and some other normal stuff. Luckily the Sony Bravia can read mkv and x256 and some other codecs. And this is something the sells people and adverbs dont tell you, so be warned not to trust the DLNA-Certificate too much, the device has to decode the media in the end. Anyway i set up miniDLNA on my laptop and now I am able to stream my media to the television. Although the process did not go that well. The problem was miniDLNA was breaking down all the time. And checking it by reading the logs etc revealed permission issues. I had to start miniDLNA as the user my files belonged to. BUT I did not use the user setting in the minidlna.conf instead I just started the daemon as the user. I could have done this with a startup script, but there were some issues with the network being set up at the sam...