准备篇
1.配置防火墙,开启80端口、3306端口
1 vim /etc/sysconfig/iptables
2 -A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT #允许80端口通过防火墙
3 -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT #允许3306端口通过防火墙
service iptables restart
#重启防火墙,使配置生效
2.关闭SELINUX(这个和服务器安全相关,先关闭。相关介绍:https://wiki.centos.org/zh/HowTos/SELinux)
1
2
3
4
5
6
|
vim /etc/selinux/config #SELINUX=enforcing #注释掉 #SELINUXTYPE=targeted #注释掉 SELINUX=disabled #增加 :wq #保存退出 shutdown -r now #重启系统 |
3.安装第三方源
1)安装EPEL仓库
yum install -y epel-release
如果以上命令不起作用:
CentOS/RHEL 7
rpm -Uvh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
CentOS/RHEL 6
rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
2)安装IUS仓库
CentOS 6
rpm -Uvh https://centos6.iuscommunity.org/ius-release.rpm
CentOS 7
rpm -Uvh https://centos7.iuscommunity.org/ius-release.rpm
错误处理:
1.安装IUS仓库出错:curl: (35) SSL connect error。这个问题在RHEL 6.1 -> RHEL 6.4应该都会出现,原因是curl使用了REST API。解决:
yum update nss
2.结果问题1没解决,出另一个问题:Error: Cannot retrieve metalink for repository: epel. Please verify its path and try again。解决:
vim /etc/yum.repos.d/CentOS-Base.repo
把有mirrorlist的都注释掉,有baseurl的都去掉注释,然后再进行步骤1,再安装IUS仓库。修改如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
[epel] name=Extra Packages for Enterprise Linux 6 - $basearch baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch failovermethod=priority enabled=1 gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 [epel-debuginfo] name=Extra Packages for Enterprise Linux 6 - $basearch - Debug baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch/debug #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-debug-6&arch=$basearch failovermethod=priority enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 gpgcheck=1 [epel-source] name=Extra Packages for Enterprise Linux 6 - $basearch - Source baseurl=http://download.fedoraproject.org/pub/epel/6/SRPMS #mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-source-6&arch=$basearch failovermethod=priority enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6 gpgcheck=1 |
查看仓库列表,看看是否安装成功了:
yum repolist
1
2
3
4
5
6
7
8
9
|
ius | 2.3 kB 00:00 ius /primary_db | 183 kB 00:00 repo id repo name status base CentOS-6 - Base 5,062 epel Extra Packages for Enterprise Linux 6 - i386 9,992 extras CentOS-6 - Extras 39 ius IUS Community Packages for Enterprise Linux 6 - i386 329 updates CentOS-6 - Updates 382 repolist: 15,804 |
安装仓库成功。接下来安装nginx,mysql,php。
安装篇
查看即将要安装的软件的版本:
yum list nginx mysql php
结果:
1
2
3
4
5
6
7
8
9
10
11
|
[root@localhost ~] # yum list nginx mysql php Loaded plugins: fastestmirror, security Loading mirror speeds from cached hostfile * base: mirrors.163.com * extras: mirrors.163.com * ius: hkg.mirror.rackspace.com * updates: mirrors.163.com Available Packages mysql.i686 5.1.73-7.el6 base nginx.i686 1.10.1-1.el6 epel php.i686 5.3.3-48.el6_8 updates |
mysql和php的版本都有些旧,他们都来源于mirrors.163.com这个源。而epel和ius源的软件版本一般比较新。
使用以下命令列出所有mysql和php的版本:
yum list mysql* php*
这会列出一大堆像这样的结果,接下来只要选择需要安装的软件版本就好:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
软件名字 软件版本 #软件所在仓库<br> php56u.i686 5.6.26-1.ius.centos6 ius mysql55.i686 5.5.52-1.ius.centos6 ius 安装nginx yum remove httpd* php* #删除系统自带的软件包 yum install nginx #安装nginx 根据提示输入y进行安装 chkconfig nginx on #设置nginx开机启动 service nginx start #启动nginx 安装MySQL yum remove mysql* #删除系统已经安装的mysql yum list mysql* #列出mysql所有版本,找到要安装的版本的名字 yum install mysql57u* #我安装的是mysql5.7.15。输入Y即可自动安装,直到安装完成 service mysqld start #启动MySQL chkconfig mysqld on #设为开机启动 |
安装PHP
1
2
3
4
|
yum install php56u-fpm php56u-mbstring php56u-bcmath php56u-mcrypt php56u-xmlrpc php56u-pdo php56u-xml php56u-xmlrpc php56u-mysqlnd php56u-gd php56u-opcache #安装php5.6及扩展 chkconfig php-fpm on #设置php-fpm开机启动 service php-fpm start #启动php-fpm |
配置篇
nginx的配置文件是/etc/nginx下的nginx.conf。在nginx.conf文件的最后一行可以看到: include /etc/nginx/conf.d/*.conf; 它把 /etc/nginx/conf.d目录下后缀为.conf的文件都包含进来了,所以只要在/etc/nginx/conf.d/这个目录下配置一个.conf文件就行了。以下是我的配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
# # The default server # server { listen 80; server_name n.com; root /usr/share/nginx/html; index index.php index.html; # Load configuration files for the default server block. location / { try_files $uri $uri/ /index.php?$args; } location ~ .*\.(php)?$ { expires -1s; try_files $uri =404; fastcgi_split_path_info ^(.+\.php)(/.+)$; include fastcgi_params; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_pass 127.0.0.1:9000; } error_page 404 /404.html; location = /40x.html { } error_page 500 502 503 504 /50x.html; location = /50x.html { } } |
重启nginx:
service nginx restart
在/usr/share/nginx/html/这个目录下新建一个index.php
1
2
|
cd /usr/share/nginx/html #进入html目录 vim index.php #新建index.php,加上phpinfo(); |
浏览器访问:centos的ip地址/index.php。完成!