1、操做系統級環境及軟件版本php
操做系統:CentOS release 6.5 (Final)minimalcss
內核版本:2.6.32-431.el6.x86_64html
MySQL版本:MySQL-5.6.28mysql
nginx版本:nginx-1.8.1linux
php版本:php-5.6.19nginx
2、安裝MySQL-5.6.28web
獲取地址:http://mirrors.sohu.com/mysql/自行選擇想要的版本sql
mysql-5.6.28-linux-glibc2.5-x86_64.tar.gz這個版本是官方編譯好的版本,解壓後直接初始化便可使用,若是使用源碼編譯安裝須要注意的是MySQL5.5版本之後要用cmake進行編譯,編譯時須要事先安裝cmake。數據庫
解壓mysql-5.6.28-linux-glibc2.5-x86_64.tar.gzvim
# tar -zxvf mysql-5.6.28-linux-glibc2.5-x86_64.tar.gz
將解壓後的文件移動到/usr/local/下並命名爲mysql
# mv mysql-5.6.28-linux-glibc2.5-x86_64 /usr/local/mysql
建立mysql用戶沒有家目錄,而且不能登陸
# useradd -M mysql -s /sbin/nologin
建立數據庫文件存儲位置
# mkdir -p /database/mysql
將全部者和所屬組改成mysql
# chown -R mysql.mysql /database/mysql/
初始化數據庫
# ./scripts/mysql_install_db --user=mysql --datadir=/database/mysql
將mysql的二進制bin目錄添加到用戶的環境變量中
# vim ~/.bash_profile
將/usr/local/mysql/bin添加到PATH中
# source ~/.bash_profile
配置mysql的環境而且開機自啓動
# cp mysql.server /etc/init.d/mysqld
必定要執行這個,不然後悔莫及,不解釋
# sed -i 's#^datadir=#datadir=/database/mysql#' /etc/init.d/mysqld
# chkconfig --add mysqld
# chkconfig mysqld on
編輯mysql的配置文件
# vim /usr/local/mysql/my.cnf
添加以下內容不配置主從的狀況下的配置:
basedir=/usr/local/mysql
datadir=/database/mysql/data
port=3306
socket=/tmp/mysql.sock
lower_case_table_names=1
key_buffer_size=256M
sort_buffer_size=1M
read_buffer_size=1M
read_rnd_buffer_size=4M
myisam_sort_buffer_size=64M
thread_cache_size=16
query_cache_size=16M
thread_concurrency=4
interactive_timeout=8
wait_timeout=8
slow_query_log=on
long_query_time=1
slow-query-log-file=/database/mysql/slow.log
具體參數參考MySQL經常使用配置
3、安裝php
安裝php以前先安裝差很少用到的包
# yum -y install openssl-devel bzip2-devel libxml2-devel curl-devel libpng-devel libjpeg-devel freetype-devel libtool-ltdl-devel perl-devel
安裝epel-release擴展源
rpm -ivh " http://www.lishiming.net/data/attachment/forum/epel-release-6-8_64.noarch.rpm "
# yum -y install libmcrypt-devel
建立php-fpm用戶
# useradd -M php-fpm -s /sbin/nologin
# tar zxvf php-5.6.19.tar.gz
# cd php-5.6.19
# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=/usr/local/mysql/ --with-mysql-sock=/tmp/mysql.sock --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --disable-ipv6
# make -j 2
# make install
# cp php.ini-production /usr/local/php/etc/php.ini
將php-fpm添加到系統服務並設置爲開機自啓動
# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
# chmod 755 /etc/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on
# cd /usr/local/php/etc/
# mv php-fpm.conf.default php-fpm.conf
檢查php-fpm的位置文件是否正確
# /usr/local/php/sbin/php-fpm -t
啓動php-fpm
# service php-fpm start
4、安裝nginx
# tar -zxvf nginx-1.8.1.tar.gz
# cd nginx-1.8.1
# ./configure --prefix=/usr/local/nginx --with-pcre
# make -j 2
# make install
啓動nginx
# /usr/local/nginx/sbin/nginx
去配置文件裏將php的配置項打開
# vim /usr/local/nginx/conf/nginx.conf
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
include fastcgi_params;
}
從新加載nginx配置文件
# /usr/local/nginx/sbin/nginx -s reload
在/usr/local/nginx/html目錄先能夠建立php的信息頁進行測試五5、php-fpm經常使用跟配置
[global]
pid = /usr/local/php/var/run/php-fpm.pid
error_log = /usr/local/php/var/log/php-fpm.log
[www]
listen = /tmp/www.sock
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
slowlog = /tmp/phpslow.log
request_slowlog_timeout = 1
6、常見的502錯誤
主要是由於nginx對php-fpm的sock沒有讀寫權限形成的,還有一點就是在搭建discuz論壇的時候discuz目錄下的權限應該對php-fpm用戶有度讀寫的權限才能夠,並非nginx。
# chown -R php-fpm:php-fpm /web/discuz/
7、nginx用戶認證
在discuz的配置文件中加入下面的內容
location ~ .*admin\.php$ {
auth_basic "fanjinbao auth";
auth_basic_user_file /usr/local/nginx/conf/.htpasswd;
include fastcgi_params;
fastcgi_pass unix:/tmp/discuz.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /web/discuz$fastcgi_script_name;
}
.htpasswd文件須要藉助於apahce的密碼生成工具才能夠哦
8、nginx域名跳轉
在discuz.conf的server中添加以下內容:
if ($host != 'www.discuz.com')
{
rewrite ^/(.*)$ http://www.discuz.com/$1 permanent;
}
9、nginx不記錄指定文件類型日誌
在discuz.conf的server中添加以下內容:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
access_log off;
}
location ~ (static|cache)
{
access_log off;
}
10、nginx的日誌切割腳本
#!/bin/bash
d=`date -d "-1 day" +%F`
[ -d /tmp/nginx_log ] || mkdir /tmp/nginx_log
mv /web/discuz.log /tmp/nginx_log/$d.log
/etc/init.d/nginxd reload > /dev/null
cd /tmp/nginx_log/
gzip -f $d.log
11、nginx配置靜態文件過時時間
location ~ \.(js|css)
{
access_log off;
expires 2h;
}
12、nginx配置防盜鏈
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
access_log off;
expires 15d;
valid_referers none blocked *.discuz.com *.fansik.com;
if ($invalid_referer)
{
return 403;
}
}
測試防盜鏈是否配置成功可使用curl命令進行測試:
# curl -e "http://www.baidu.com/111" -x127.0.0.1:80 'http://www.discuz.com/static/image/common/logo.png' -I
這個返回的狀態碼確定是403
# curl -e "http://www.fansik.com/111" -x127.0.0.1:80 'http://www.discuz.com/static/image/common/logo.png' -I
這個返回的狀態碼確定是200
12、nginx的訪問控制
直接在配置文件(或者location中)添加
allow 127.0.0.1;
deny 1.1.1.1;
十3、nginx禁止指定user_agent
if ($http_user_agent ~* 'curl|baidu|11111')
{
return 403;
}
~*:不區分大小寫
十4、nginx代理和負載
upstream baidu{
server 61.135.169.125:80;
server 61.135.169.121:80;
}
server {
listen 80;
server_name www.baidu.com;
location / {
proxy_pass http://baidu/;
proxy_set_header Host $host;
}
}