phpMyAdmin & Nginx to Maintain Databases: VPS BIBLE




new password?
login
X

Get phpMyAdmin Working with Nginx

phpmyadmin with nginx image

How to install PMA with Nginx, to administer multiple MySQL dbs from anywhere. View table structure, browse data, run queries, backup and more.

Adding phpMyAdmin to the Nginx web server is very like adding a sub-site. Dead easy! The process takes 10 minutes, tops. This guide shows you how to add the client, configure a virtual host file with its symlink, and create a simple A record.

Setup Unmanaged VPS: The Ubuntu-Nginx Guide

Take your virtual private server from zero to hero

  .. from blank box to cute-as server ..  

with this easy-to-follow copy/paste guide.

22+ parts with video, here’s the index.

Create an A or AAAA Record

If we do this first, by the time everything else is done the new DNS record should have propagated and we’ll be ready to play.

Go to your web host’s DNS manager and create an A record, adding the following:-

Hostname IP TTL (Time to Live)
phpmyadmin.mydomain.com the IP you use for mydomain.com shortest option

After you save that, in the record itself, “phpmyadmin.mydomain.com” may appear as “phpmyadmin”. That’s fine.

Tidy tip: For a little added security, rather than phpmyadmin.mydomain.com, choose something like hackoff.mydomain.com.

You can exit your DNS manager. It’ll take a little while for the new setting to register. At my VPS Linode, it’s minutes not hours. Yours? Dunno, but probably no longer than an hour or two.

Install the phpMyAdmin Software

Logged into your remote command line interface, type:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

.. and when asked for confirmation, type ‘y’ and hit Return.

A blue screen pops up asking which web server to reconfigure. Press the spacebar to choose ‘Apache2′, then tab onto ‘OK’, pressing Enter.

But I’m using Nginx, not Apache?

Sure, valid point.

phpMyAdmin downloads Apache2 as a dependent file, if you don’t already have it installed. Truth is, I have no idea why and maybe someone out there can put me right. But hey, while it’ll take up a little space it won’t be wasting resources, ‘cos we won’t be using it.

When configuring PMA and it asks for a web server, all I know is that by choosing Apache2 and concluding the install, Apache will fail to start (because Nginx is using the port it wants) and you’ll never hear from Apache again. Sweet.

Besides, with my method, phpMyAdmin just works!

But, hey, if anyone can fill me in with some more detail about all this, that’d be grand, and I’ll improve this guide if possible.

So that’s PMA installed. Now to configure it.

Configure the phpMyAdmin Virtual Host (vhost) File

This configures PMA to work with Nginx. Let’s change directory, to where all our vhosts live:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

And open a new file, which we’ll call “phpmyadmin”:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

And paste this lot, swapping the three incidences of mydomain.com for your_domain.tld:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

NB If you’re using my anti-hack tip mentioned above, then change the line ..


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

.. to read something like ..


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

Create an Nginx Symlink for phpMyAdmin

Paste this into your terminal:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

And, finally, restart Nginx ..


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

.. Or, if you followed Edit bashrc for User-Friendly Linux, plus System Updates, just type:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

Go Mine Data

Connect to your database using:-


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

.. or, if you went the anti-hack route ..


Please sign up for automatic premium content access.

Just $15/year* will save you hours, maybe days!

Alternatively, the vpsBible forum is free and you are welcome.

Login and enjoy.

Setup Unmanaged VPS: The Ubuntu-Nginx Guide

Take your virtual private server from zero to hero

with this easy-to-follow copy/paste guide.

“My local PC runs Windows” Show me for Linux

22+ parts with video, here’s the index ..

Manage Unmanaged VPS: Ubuntu-Nginx Administration

Already set it up? We’d best maintain it then.

Toggle to the ..  Ubuntu-Nginx Admin Index

Manage Unmanaged VPS: Ubuntu-Nginx Administration

Maintain your virtual private server with ..

.. cheatsheets, tutorials, tips & guides.

Head back to the ..  Ubuntu-Nginx Installation Index

Nginx Admin: In the Works ..

This lot’s marked for addition already:-

  • Setup or Edit DNS using Bind
  • Network Tools Troubleshooting Guide
  • The Comprehensive Permissions Guide
  • Configuring Nginx Rewrites
  • Custom Website Error Page
  • Setting up Cron Jobs
  • Rsync for Incremental Remote-to-Local Backup
  • Cron & Rsync for Automatic Backup
  • Cron & mysqldump for Auto DB Backup
  • Safeguard Bandwidth with Hotlink Protection
  • Block Access with Nginx’ IP Deny



Got a Question? Want to Comment?

This site has no comments system. We've got a better system!

Please use the link at the top of the post and goto this topic's forum thread:-

  • to help build community
  • for a superior knowledge base
  • to keep info in one place, not diluted between forum & comments.

For those posts ported from Guvnr.com (pre-Feb/2010), archive comments remain.

Handy info from these comments is in the process of being ported to the forum and attributed to the original author.

If you think this idea sucks, let me know.

Thank you.

  • Use phpMyAdmin & Nginx to Maintain Databases - VPS CARE #5 - GUVNR | Green Web hosting July 14th, 2009 at 2:05 pm

    [...] original post here: Use phpMyAdmin & Nginx to Maintain Databases – VPS CARE #5 – GUVNR Top 5 Green Web Hosting Companies, Click [...]

  • Use phpMyAdmin & Nginx to Maintain Databases - VPS CARE #5 - GUVNR : evaluehost.com July 14th, 2009 at 2:18 pm

    [...] More here: Use phpMyAdmin & Nginx to Maintain Databases – VPS CARE #5 – GUVNR [...]

  • Use phpMyAdmin & Nginx to Maintain Databases - VPS CARE #5 - GUVNR : tntwebhostings.com July 14th, 2009 at 2:44 pm

    [...] See the article here: Use phpMyAdmin & Nginx to Maintain Databases – VPS CARE #5 – GUVNR [...]

  • Use phpMyAdmin & Nginx to Maintain Databases - VPS CARE #5 - GUVNR : hostingwebsitereviews.com July 14th, 2009 at 3:45 pm

    [...] Continued here: Use phpMyAdmin & Nginx to Maintain Databases – VPS CARE #5 – GUVNR [...]

  • Use phpMyAdmin & Nginx to Maintain Databases - VPS CARE #5 - GUVNR : websiteshostingreviews.com July 14th, 2009 at 4:08 pm

    [...] More here: Use phpMyAdmin & Nginx to Maintain Databases – VPS CARE #5 – GUVNR [...]

  • Mattew September 22nd, 2009 at 6:54 pm

    Hi Guvnr,
    thank you for this usful article. Everythig works, but I can’t get phpmyadmin work in SSL mode. Maybe you have any suggestions?

  • Mattew September 22nd, 2009 at 7:28 pm

    I did it! :)
    here is my config /usr/local/nginx/sites-available/phpmyadmin
    server {

    listen 443;
    server_name phpmyadmin.domain.com;
    access_log /home/public_html/domain.com/log/phpmyadmin.access.log;
    error_log /home/public_html/domain.com/log/phpmyadmin.error.log;
    ssl on;
    ssl_certificate /usr/local/nginx/conf/server.crt;
    ssl_certificate_key /usr/local/nginx/conf/server.key;

    location / {
    root /usr/share/phpmyadmin;
    index index.php;
    }

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ \.php$
    {
    fastcgi_param HTTPS on;
    fastcgi_pass 127.0.0.1:9000;
    fastcgi_index index.php;
    include /usr/local/nginx/conf/fastcgi_params;
    fastcgi_param SCRIPT_FILENAME /usr/share/phpmyadmin$fastcgi_script_name;
    }

    *Note that there must be generated certificates:
    Generate Certificates

    To generate dummy certficates you can do this steps:

    $ cd /usr/local/nginx/conf
    $ openssl genrsa -des3 -out server.key 1024
    $ openssl req -new -key server.key -out server.csr
    $ cp server.key server.key.org
    $ openssl rsa -in server.key.org -out server.key
    $ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

    More info – http://wiki.nginx.org/NginxHttpSslModule

  • the_guv September 23rd, 2009 at 10:20 am

    @Mattew .. big cheers m8 .. that is gonna be mighty handy for some folks out there. Good of you to come back and post that.

  • Joey September 27th, 2009 at 7:25 am

    do you know how to have phpmyadmin listen on 127.0.0.1:80 and then use ssh to access it. I heard that otherwise it is a security risk if somebody tries to brute force the password?

  • the_guv October 6th, 2009 at 6:49 am

    @Joey .. hmmn .. never tried it, but what a good idea. then again, doesn’t that defeat teh object of having it in the first place?! all it is is a GUI for what you’d do with ssh anyhow, er, no? one thing i do do is to strap PMA onto a pretty irrelevant, parked, site on the vps, rather than in an obvious place like http://www.hackmyPMAplease.guvnr.com. Change the name too .. you can call it whatever you like, alpha-numerically .. so effectively that gives you a second password. (problem is, for the life of me, i can’t remember what mine’s called ..)

  • Alborz December 9th, 2009 at 7:51 am

    I faced a problem, phpmyadmin gave me ‘blowfish_secret’ error.
    To solve this error:

    Go here:
    /var/lib/phpmyadmin/blowfish_secret.inc.php

    Copy the line:
    $cfg['blowfish_secret'] = ‘your hash here’;

    Paste that line at the end of:
    /etc/phpmyadmin/config.inc.php

  • Install/Upgrade WORDPRESS with SUBVERSION: VPS BIBLE - vpsBible February 10th, 2010 at 4:59 pm

    [...] If you’d prefer to relocate select data, there’s always phpMyAdmin. [...]

  • the_guv March 5th, 2010 at 6:13 am

    Tx to a cracking plugin to sync the bbPress forum to WP comments .. comments are open now.

    Post here and your comment is automatically posted in the relevant forum. Post there and vice-versa.

    Comments below here have been imported from Guvnr. Bit of a timeline gap so apologies for that.

    (Big cheers to Bobrik for wordpress-bbpress-syncronization.)

  • the_guv March 5th, 2010 at 6:15 am

    test!

  • the_guv March 5th, 2010 at 6:48 am

    test from bbPress