使用Nginx搭建phpMyAdmin

Nginx有什么用?

Nginx可读作EngineX是由俄罗斯程序员Igor Sysoev开发的高性能的web服务器。
它采用了与Apache完全不同的模型,能够处理接收更多的请求。
由于Nginx优秀的性能,Nginx几乎可以和Apache并驾齐驱。
对Apache来说,Nginx可谓是后起之秀。
可以说Apache代表了经典,Nginx则代表了新锐。
那Nginx具体有什么功能呢?

基本功能:
  • 静态资源的web服务器,能缓存打开的文件描述符。
  • http, smtp, pop3协议的反向代理服务器,缓存、负载均衡。
  • 支持FastCGI
  • 模块化,过滤器zip,SSI及图像大小调整
  • 支持SSL。

需要注意的是:
a.如果单纯只安装一个Nginx的软件包,服务器只会响应静态请求。
所以Nginx在配合php-fpm的时候就可以解析php网页的动态请求。
Apache的时候,php一般作为一个插件安装使用。
而php-fpm则是一个独立的进程,一般监听在9000端口。
b.Nginx不仅作为web服务器具有高性能,而且作为反向代理服务器也是十分优秀的。
c.与Apache的动态加载模块不同,nginx虽然支持第三方模块,但是也需要编译。

扩展功能:
  • 基于名称和IP的虚拟主机
  • 支持长连接
  • 支持平滑升级
  • 定制访问日志 ,支持使用日志缓冲区提高日志存储性能
  • 支持url重写
  • 支持路径别名
  • 支持基于IP及用户的访问控制
  • 支持速率限制,支持并发数限制
    虽然看上去她好像跟Apache服务器没什么区别,下面我们将从几个方面与Apache进行对比。

Nginx与Apache的不同之处

明明已经有Apache了,Nginx有什么特别的好处吗?
  • Nginx和Apache的最大不同之处,在于其网络IO模型。
    上一次我们在讲解LAMP的时候有说过,Apache最大支持1024最大请求。
    这个是由Apache的网络IO模型Select()决定的。
    Nginx使用异步IO模型Epoll(),则没有Apache最大并发1024个请求这种限制。
    其实Select()最大并发1024也不少了,想想一天有86400秒,假如一秒并发1024个。
    不过这要建立在硬件性能满足最大请求的硬件基础上。因为不合穿的鞋怎么会让一个跑步运动员跑得快呢?

  • 配置文件相比较于Apache,更加简单易懂。
    而Apache在这方面,如反向代理的配置都相对麻烦。
    并且Nginx有很详尽的官方文档
    例如Apache将动态请求通过fastcgi转发给php-fpm,或者ajp协议转发给tomcat,在配置上都没有Nginx直观。

  • 作为反向代理服务器的时候,有健康状态检测。
    能够监测后端的主机,如果有下线的话则不会到代理到下线的主机上。
    自带健康状态监测功能,如果是lvs则需要手动编写脚本来监测后端主机的状态。

  • Nginx更加轻量
    响应请求的时候,Nginx占用的内存更加的少。

虽然Nginx还有很多很吸引人的地方,但是我觉得这三点是我感受最深的。
往后的文章里,在讲反向代理的时候我们也会使用到Nginx。
如果以后时间比较充足的话,我还会配置一次Apache反向代理到tomcat。
到时候大家可以自行比较一下两者在实现同样功能上到底有什么不同。

使用Nginx搭建phpMyAdmin

phpMyAdmin是一个图形化管理MySQL数据库的一个工具。
他可以配置在web服务器上,用于统计数据库信息,备份数据库,实现增删改查等功能。
phpMyAdmin十分好用,而且直观。

主机名 主机地址
node1 192.168.2.201

本次使用的系统为CentOS7.1,数据库:MariaDB-5.5.50, web服务器:nginx-1.10.2,phpMyAdmin-4.6.5.2
注意:系统关闭了selinux,以及iptables。

由于这次我们需要安装phpMyAdmin的高版本,需要php5.5+的版本。
所以我们需要先配置一个remi的yum源,而这个源在清华大学有镜像。
Remi's RPM repository

而phpMyAdmin我们则可以访问他的官网
phpMyAdmin官方网站

(1)配置remi镜像

  [root@bc ~]# wget https://mirrors.tuna.tsinghua.edu.cn/remi/enterprise/remi-release-7.rpm
  [root@bc ~]# yum install remi-release-7.rpm

在官网中选择合适的镜像安装,因为我们这里使用的是CentOS7,所以选择的是7的包。

(2)安装需要的组件

  [root@bc ~]# yum install nginx mariadb mariadb-server php-mysql  php56-php-fpm php56-php-mbstring php56-php-mysqlnd

这里需要注意的是,这次我们选择了php56-php-fpm,也就是php5.6版本的php-fpm。
系统默认提供的php-fpm是5.4版本的。

(3)下载phpMyAdmin,并解压放置在Nginx的web根目录下

  [root@bc ~]# wget https://files.phpmyadmin.net/phpMyAdmin/4.6.5.2/phpMyAdmin-4.6.5.2-all-languages.tar.gz
  [root@bc ~]# tar xf phpMyAdmin-4.6.5.2-all-languages.tar.gz 
  [root@bc ~]# cp -Ra /root/phpMyAdmin-4.6.5.2-all-languages /usr/share/nginx/html/pma/
  [root@bc ~]# chown nginx.nginx -R /usr/share/nginx/html/pma

(4)启动mariadb并初始化安全设置

[root@bc ~]# systemctl start mariadb.service
[root@bc ~]# mysql_secure_installation 

这里主要是设置密码,以及清除一些测试库等。
输出结果挺长的就不截取了。
待会儿在phpMyAdmin的页面上登陆的账号密码其实就是这里设置的。

(5)修改nginx设置

[root@bc ~]# vim /etc/nginx/nginx.conf
    server {
        listen       80 default_server;
        server_name  node1.bc.com;
        root         /usr/share/nginx/html/pma;
        index        index.php index.html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
        }

        location ~ \.php$ {
            root           html/pma/;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/html/pma/$fastcgi_script_name;
            include        fastcgi_params;
        }
    }

(6)修改phpMyAdmin的配置

[root@bc ~]# cp /usr/share/nginx/html/pma/config.sample.inc.php /usr/share/nginx/html/pma/config.inc.php 
[root@bc ~]# vim !$
  $cfg['blowfish_secret'] = '0OYNHGWmgBWP/GtG3hLVwYlCeH0ZBs4hew'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */

修改一行就可以了,这个主要是加密的字串,可以随便打一段进去,但是不要把我的这行复制进去。
需要注意的是,这个字符串需要在单引号里面,有一次眼神不好漏了一边单引号,结果报错了好久都没有找出问题。

**(7)重启nginx以及启动php-fpm **

[root@bc ~]# systemctl restart nginx.service 
[root@bc ~]# systemctl start php56-php-fpm.service

如果启动nginx不成功,可以使用nginx -t来测试配置文件是否有语法错误。

(8)在浏览器上键入主机的ip地址就可以访问phpMyadmin。

phpMyAdmin.jpg

这里输入的是刚才初始化数据库的时候,自己设置的账号密码。
注意:安装phpMyAdmin的时候,因为要安装mbstring和mysqli组件。
假如没有安装,这里就会报错。
不过这些在remi的源中有提供,默认的源也有提供,不过要安装对应版本。
这里安装的是php56-php-fpm,所以安装mbstring的包名就是php56-php-mbstring
安装组件之后,php-fpm需要重启一下才能使组件生效。

(9)键入MySQL的账号密码就可以正常使用了!

phpMyAdmin使用成功.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容