centos下安装nginx和php磨难记
为了能有一个完善的体验过程,我自己安装了一遍centos和nginx、php,中间出了不少问题,记事留念。
第1步当然就是安装Vmware,这没啥好说的,一步步next就好了;
第2步是新建一个虚拟机,并加载ios镜像安装Centos6.3,这个也没啥好说的,网上很多图文教程,
注1:分区时,我增加了一个/home区,而且我没安装gui图形环境,按base server进行的安装;
注2:安装完成后,我选择的网络模式是NAT,在VmWare的菜单“编辑”里有一个“虚拟网络编辑器”,选择NAT模式,确定即可,然后再打开宿主Windows机的本地连接属性,打开“允许其他网络用户通过此计算机的Internet连接来连接”,这样虚拟机就可以上网了;
注3:开启共享后,出了一个问题,就是Windows里的Cisco VPN客户端连接不上了,取消共享,就可以连接,连接上后,再开启共享也无效,只能二选一进行工作。
第3步,配置一些环境:
1、调整Shell分辨率(这一步可要可不要,后面我都通过终端访问) 命令行下输入:vim /boot/grub/grub.conf ,
在kenel这行最后面添加 vga=ask 这样每次重启都会询问分辨率,如果添加 vga=0x369,表示把终端分辨率 固定为1280*800
2、修改IP,因为Windows打开共享后,Nat网关IP是192.168.137.1,所以我把Centos的IP设置为192.168.137.8:
编辑对应的网卡配置文件,本机为ifcfg-eth0: # vim /etc/sysconfig/network-scripts/ifcfg-eth0 内容如下 DEVICE=eth0 #描述网卡对应的设备别名 BOOTPROTO=static #设置获得ip方式,可能的选项为static,dhcp或bootp BROADCAST=192.168.137.255 #对应的子网广播地址 ONBOOT=yes IPADDR=192.168.137.8 #设置网卡静态ip地址 NETMASK=255.255.255.0 #网卡对应的网络掩码 GATEWAY=192.168.137.1 #网关IP DNS1=114.114.114.114 #DNS1的IP修改完IP后,记得使用命令重启Centos网络,以便使IP生效
service network restart
好了,前面的准备工作完成,要开始部署环境了
第1步、模拟生产系统,添加了一个work账户,命令行如下:
useradd work
passwd work 这里回车后,会让你输入work账户的新密码,输入2遍
然后再把work用户加入sudoer
chmod u+w /etc/sudoers 首先设置sudoers文件可写 vim /etc/sudoers 打开sudoers文件进行编辑,在"root ALL=(ALL) ALL"下面添加"kiwi ALL=(ALL) ALL". chmod u-w /etc/sudoers 撤消写权限
第2步、使用yum安装php 和 nginx php-fpm,命令行如下,按指示一步步确认:
yum install php
注:下一步,是设置源,否则无法yum安装nginx
rpm -ivh http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm
yum install nginx
第3步、配置nginx的运行用户和web参数
nginx的配置文件位置: /etc/nginx/nginx.conf 首先移除配置文件里的include配置,
接着把user nginx修改为 user work,使用work用户执行nginx进程;
然后http配置节里的server配置如下:
server { listen 80; # 监听端口 server_name localhost; # 主机头,如果只有一个server配置,这个主机头会忽略 location / { # 默认路径指向 root /home/work/web; # 站点根目录 index index.html index.htm; # 站点的默认首页文件 } error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } location ~ \.php$ { # php请求路径正则 root /home/work/web; # php请求的文件根目录 fastcgi_pass 127.0.0.1:9000; # php-fpm的监听端口 # 下一行的$document_root就是上面的root配置 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }注:如果不修改nginx的运行用户,那么在访问站点下的文件时,可能会报403错误。
奇怪的是,不改运行用户时,我用命令 chmod -R 777 /home/work/web 设置了最大权限,访问站点时依旧提示403错误,有大侠知道不?
第4步、配置php-fpm的运行用户:
php-fpm的配置文件位置: /etc/php-fpm.conf,里面有一句: include=/etc/php-fpm.d/*.conf
再打开包含的配置文件: /etc/php-fpm.d/www.conf,找到user=apache,把它改成user=work
注:如果不修改php-fpm的运行用户,那么在访问php文件时,会一直报:File not found 错误,同样我设置了目录的777权限也不行,坑啊
第5步、启动php-fpm服务和nginx服务:
service php-fpm restart
service nginx restart
好了,到这里配置全部完成了,在站点下放一个index.php文件,然后通过命令行:curl http://127.0.0.1/index.php访问一下试试吧。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。