一、安裝軟件依賴包:
yum -y groupinstall "Development Tools" "Server Platform Deveopment"
yum -y install openssl-devel pcre-develphp
二、在全部的主機上面都操做,下載nginx包:
cd /usr/local/src/
[root@node1 src]# yum install wget –y ##安裝wget工具html
三、下載nginx包:
[root@node1 src]# wget http://nginx.org/download/nginx-1.12.0.tar.gznode
四、添加nginx運行的用戶:
[root@node1 sbin]# useradd nginxmysql
5解壓nginx包,而且安裝:
[root@node1 src]# tar zxvf nginx-1.12.0.tar.gz
[root@node1 src]# cd nginx-1.12.0/nginx
六、安裝nginx包:
[root@node1 nginx-1.12.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_flv_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcreweb
###編譯安裝sql
[root@node1 nginx-1.12.0]# make && make install數據庫
六、而後咱們能夠啓動nginx:
[root@node2 nginx]# cd /usr/local/nginx/sbin/
[root@node1 sbin]# ./nginx瀏覽器
##假如已經存在進程:
[root@node2 sbin]# ps -ef | grep nginx | awk '{print $2}' | xargs kill -9
kill: 向 9132 發送信號失敗: 沒有那個進程ssh
七、咱們能夠查看咱們的IP,而後訪問web界面查看一下:
[root@node1 sbin]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 119.29.11.175 netmask 255.255.192.0 broadcast 10.104.191.255
ether 52:54:00:9b:4b:a0 txqueuelen 1000 (Ethernet)
RX packets 113077 bytes 123521930 (117.7 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 45620 bytes 4211893 (4.0 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
八、查看一下是否監聽到端口:
[root@node1 sbin]# netstat -ntlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 8035/nginx: master
訪問web:
##以上步驟在每臺上面都執行:
Setup2:
一、下載依賴包:
cd /usr/local/src
[root@node2 src]# yum -y install libmcrypt-devel bzip2-devel gcc openssl-devel php-mcrypt libmcrypt libxml2-devel libjpeg-devel libpng-devel freetype-devel
二、下載Php包:
[root@node2 src]# wget http://cn2.php.net/distributions/php-5.5.38.tar.gz
三、安裝php包:
[root@node2 src]# tar zxvf php-5.5.38.tar.gz
[root@node2 src]# cd php-5.5.38/
[root@node2 php-5.5.38]# ./configure --prefix=/usr/local/php --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-openssl --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --with-mcrypt --with-bz2 --enable-fpm --with-gd
要顯示成這樣纔是正常的:
四、開始編譯安裝:
[root@node2 php-5.5.38]# make && make install
##注意要編譯沒有報錯:
五、開始一些配置步驟:
[root@node2 php-5.5.38]# cp /usr/local/src/php-5.5.38/php.ini-production /usr/local/php/etc/php.ini
[root@node2 php-5.5.38]# mv /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
六、建立Php用戶:
[root@node2 php-5.5.38]# useradd -M -s /sbin/nologin php
七、修改相關配置:
[root@node2 php-5.5.38]# sed -i -e 's\;pid = run/php-fpm.pid\pid = run/php-fpm.pid\g' -e 's\nobody\php\g' -e 's\listen = 127.0.0.1:9000\listen = 0.0.0.0:9000\g' /usr/local/php/etc/php-fpm.conf
[root@node2 php-5.5.38]# sed -i 's\;daemonize = yes\daemonize = no\g' /usr/local/php/etc/php-fpm.conf
八、啓動php:
[root@node2 php-5.5.38]# /usr/local/php/sbin/php-fpm &
九、查看一下是否已經啓動了php:
[root@node2 php-5.5.38]# netstat -ntlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:111 0.0.0.0: LISTEN 1/systemd
tcp 0 0 0.0.0.0:80 0.0.0.0: LISTEN 31587/nginx: master
tcp 0 0 0.0.0.0:22 0.0.0.0: LISTEN 734/sshd
tcp 0 0 0.0.0.0:9000 0.0.0.0: LISTEN 1114/php-fpm: maste
tcp6 0 0 :::111 ::: LISTEN 14694/rpcbind
tcp6 0 0 :::22 ::: LISTEN 734/sshd
##注意是9000端口:
Setup3:
[root@node2 php-5.5.38]# yum install mariadb-server mariadb –y
二、啓動mysql:
systemctl start mariadb
二、設置root帳戶,用戶名密碼:
[root@node2 php-5.5.38]# mysql_secure_installation
Enter current password for root (enter for none):
OK, successfully used password, moving on...
Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.
Set root password? [Y/n] Y
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
... Success!
By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them. This is intended only for testing, and to make the installation
go a bit smoother. You should remove them before moving into a
production environment.
Remove anonymous users? [Y/n]
... Success!
Normally, root should only be allowed to connect from 'localhost'. This
ensures that someone cannot guess at the root password from the network.
Disallow root login remotely? [Y/n]
... Success!
By default, MariaDB comes with a database named 'test' that anyone can
access. This is also intended only for testing, and should be removed
before moving into a production environment.
Remove test database and access to it? [Y/n]
Reload privilege tables now? [Y/n]
... Success!
Thanks for using MariaDB!
四、創意一個wordpress數據庫:
[root@node2 php-5.5.38]# mysql -uroot -p123456 -e "create database wordpress"
[root@node2 php-5.5.38]# mysql -uroot -p123456 -e "show databases"
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| wordpress |
+--------------------+
##驗證擁有數據庫了便可。
給數據庫受權:
[root@node2 conf]# mysql -uroot -p123456 -e "grant all privileges on . to 'root'@'%' identified by '123456'; FLUSH PRIVILEGES;"
Setup4:
在web01,web02上面設置nginx相關web相關服務,而後上傳wordpress代碼:
[root@node2 php-5.5.38]# mkdir /web
[root@node2 php-5.5.38]# cd /web/
[root@node2 web]# tar zxvf /usr/local/src/wordpress-4.7.2-zh_CN.tar.gz -C /web/
[root@node2 web]# cp –r wordpress/* /web
[root@node2 web]# cp wordpress/wp-admin wordpress/wp-content wordpress/wp-includes -r /web
二、上傳配置文件到nginx目錄,我已經配置好,從本機上傳便可:
[root@node2 web]# cd /usr/local/nginx/conf/
[root@node2 web]# rm nginx.conf
[root@node2 web]# rz ##上傳文件到目錄下
###咱們看一下咱們應該如何配置:#########
location /{
root /web;
index index.php index.html index.htm;
}
location ~ .php$ {
root /web;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
三、而後啓動nginx:
[root@node2 conf]# /usr/local/nginx/sbin/nginx
要是已經存在服務會提示:
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
就執行一下操做:
[root@node2 conf]# /usr/local/nginx/sbin/nginx -s reload
五、而後輸入瀏覽器地址:IP/index.php便可: